/* Mapla Biotech — main stylesheet */

:root {
  --display: 'DM Serif Display', Georgia, serif;
  --body: 'Manrope', system-ui, sans-serif;
  --bg: #FAFBF7; --bg-alt: #F2F4EC; --surface: #FFFFFF;
  --ink: #0E2A1E; --ink-soft: #3B5A46; --muted: #6B7A6E;
  --line: rgba(14,42,30,.09);
  --brand: #1E6B3A; --brand-deep: #0F4A25; --brand-soft: #3FA66B;
  --accent: #D98B3A; --accent-soft: #E8B274;
  --grad-b: radial-gradient(circle at 30% 20%, rgba(63,166,107,.22), transparent 55%),
            radial-gradient(circle at 80% 70%, rgba(217,139,58,.15), transparent 60%);
}
body.mapla-style-lab {
  --bg:#0C1512; --bg-alt:#101E19; --surface:#13241E;
  --ink:#ECF4EE; --ink-soft:#B8CCBF; --muted:#7A9083;
  --line: rgba(236,244,238,.08);
  --brand:#4DD892; --brand-deep:#2E9C68; --brand-soft:#8BEAB6;
  --accent:#F2B872; --accent-soft:#F7D2A0;
  --grad-b: radial-gradient(circle at 20% 20%, rgba(77,216,146,.18), transparent 55%),
            radial-gradient(circle at 85% 75%, rgba(242,184,114,.12), transparent 60%);
}
body.mapla-style-nature {
  --bg:#F6F1E8; --bg-alt:#EDE4D1; --surface:#FFFBF2;
  --ink:#1F2B1A; --ink-soft:#3F5034; --muted:#6B7A60;
  --line: rgba(31,43,26,.10);
  --brand:#3E7B3A; --brand-deep:#255624; --brand-soft:#6FA867;
  --accent:#C97A3A; --accent-soft:#E3A473;
  --grad-b: radial-gradient(circle at 25% 25%, rgba(62,123,58,.2), transparent 55%),
            radial-gradient(circle at 80% 75%, rgba(201,122,58,.16), transparent 55%);
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin:0; padding:0; background:var(--bg); color:var(--ink); font-family:var(--body); -webkit-font-smoothing:antialiased; }
::selection { background: var(--brand); color:#fff; }
img { max-width:100%; height:auto; display:block; }

.mapla-container { max-width:1400px; margin:0 auto; padding:0 48px; }

/* Nav */
.mapla-nav{position:fixed;top:0;left:0;right:0;z-index:50;padding:14px 48px;display:flex;align-items:center;justify-content:space-between;gap:24px;transition:all .3s;border-bottom:1px solid transparent;background:color-mix(in oklab, var(--bg) 90%, transparent);backdrop-filter:blur(10px);}
.mapla-nav.is-scrolled{background:color-mix(in oklab, var(--bg) 94%, transparent);backdrop-filter:blur(14px) saturate(1.2);border-bottom:1px solid var(--line);}
.mapla-nav__brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0;}
.mapla-nav__brand img,.mapla-nav__brand .custom-logo{height:36px!important;width:auto!important;max-width:40px;object-fit:contain;}
.mapla-nav__mark{height:36px;width:36px;object-fit:contain;}
.mapla-nav__name{font-family:var(--display);font-size:20px;font-weight:600;color:var(--ink);letter-spacing:-.01em;white-space:nowrap;}
.mapla-nav__name em{font-style:normal;color:var(--brand);font-weight:400;}
.mapla-nav__links{display:flex;align-items:center;gap:28px;flex-wrap:nowrap;}
.mapla-nav__menu{list-style:none;margin:0;padding:0;display:flex;gap:24px;flex-wrap:nowrap;align-items:center;}
.mapla-nav__menu li{list-style:none;margin:0;padding:0;}
.mapla-nav__menu li > ul,.mapla-nav__menu .sub-menu,.mapla-nav__menu .children{display:none!important;}
.mapla-nav__menu a{position:relative;color:var(--ink-soft);text-decoration:none;font-size:14px;font-weight:500;white-space:nowrap;padding:6px 2px;transition:color .2s;display:inline-block;}
.mapla-nav__menu a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--brand);transform:scaleX(0);transform-origin:center;transition:transform .35s cubic-bezier(.4,0,.2,1);border-radius:2px;}
.mapla-nav__menu a:hover{color:var(--brand);}
.mapla-nav__menu a:hover::after{transform:scaleX(1);}
.mapla-nav__menu a:active{transform:scale(.94);transition:transform .08s;}
.mapla-nav__menu a.is-current{color:var(--brand);}
.mapla-nav__menu a.is-current::after{transform:scaleX(1);}
.mapla-nav__menu a.is-flash{animation:maplaNavFlash .5s ease-out;}
@keyframes maplaNavFlash{0%{background:color-mix(in oklab, var(--brand) 18%, transparent);}100%{background:transparent;}}
.mapla-nav__lang{display:flex;gap:2px;border:1px solid var(--line);border-radius:999px;padding:3px;flex-shrink:0;}
.mapla-lang{padding:4px 12px;border-radius:999px;font-size:12px;font-weight:600;text-decoration:none;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.08em;}
.mapla-lang.is-active{background:var(--ink);color:var(--bg);}

.mapla-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;border-radius:999px;font-size:14px;font-weight:600;text-decoration:none;border:none;cursor:pointer;font-family:var(--body);}
.mapla-btn--primary{background:var(--brand);color:#fff;}
.mapla-btn--dark{background:var(--ink);color:var(--bg);padding:16px 28px;font-size:15px;}
.mapla-btn--ghost{background:transparent;border:1px solid var(--line);color:var(--ink);padding:16px 28px;font-size:15px;}

/* Hero */
.mapla-hero{position:relative;min-height:100vh;padding:140px 48px 80px;overflow:hidden;}
.mapla-hero__bg{position:absolute;inset:0;background:var(--grad-b);pointer-events:none;}
.mapla-hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;}
.mapla-eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;}
.mapla-eyebrow > span:not(.mapla-dot){width:24px;height:1px;background:var(--accent);}
.mapla-eyebrow--badge{padding:7px 14px;border-radius:999px;background:color-mix(in oklab, var(--brand) 10%, transparent);border:1px solid color-mix(in oklab, var(--brand) 25%, transparent);color:var(--brand);}
.mapla-dot{width:6px;height:6px;background:var(--brand);border-radius:999px;}
.mapla-hero__title{font-family:var(--display);font-size:72px;line-height:1.02;letter-spacing:-.035em;font-weight:500;color:var(--ink);margin:24px 0;}
.mapla-hero__title em{font-style:italic;color:var(--brand-deep);font-weight:400;}
.mapla-hero__sub{font-size:18px;line-height:1.6;color:var(--ink-soft);max-width:520px;margin:0;text-wrap:pretty;}
.mapla-hero__ctas{display:flex;gap:14px;margin-top:36px;}
.mapla-hero__stats{margin-top:48px;padding-top:28px;border-top:1px solid var(--line);display:flex;gap:32px;}
.mapla-ministat__k{font-family:var(--display);font-size:32px;font-weight:500;color:var(--brand-deep);letter-spacing:-.02em;}
.mapla-ministat__v{font-size:12px;color:var(--muted);margin-top:4px;max-width:160px;line-height:1.4;}
.mapla-hero__visual{aspect-ratio:1/1;width:100%;}

/* Sections */
.mapla-h2{font-family:var(--display);font-size:44px;line-height:1.1;letter-spacing:-.025em;font-weight:500;color:var(--ink);margin:0 0 16px;}
.mapla-h2--tight{font-size:48px;line-height:1.08;text-wrap:balance;margin:16px 0;}
.mapla-lead{font-size:17px;color:var(--ink-soft);line-height:1.6;margin:0;text-wrap:pretty;}
.mapla-section-head{max-width:640px;margin-bottom:56px;}
.mapla-section-head--narrow{max-width:720px;margin-bottom:64px;}

.mapla-stats{padding:100px 48px;background:var(--bg-alt);}
.mapla-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.mapla-stat{padding:36px 28px;background:var(--surface);border-radius:16px;border:1px solid var(--line);}
.mapla-stat__k{font-family:var(--display);font-size:54px;font-weight:500;color:var(--brand-deep);letter-spacing:-.035em;line-height:1;}
.mapla-stat__v{font-size:14px;color:var(--ink-soft);margin-top:16px;line-height:1.5;text-wrap:pretty;}

.mapla-about{padding:120px 48px;background:var(--bg);}
.mapla-about__intro{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;margin-bottom:80px;}
.mapla-about__body p{font-size:17px;line-height:1.65;color:var(--ink-soft);margin:0 0 20px;text-wrap:pretty;}
.mapla-about__body p:last-child{margin-bottom:0;}
.mapla-timeline{position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:60px;}
.mapla-timeline::before{content:'';position:absolute;left:0;right:0;top:28px;height:1px;background:var(--line);}
.mapla-timeline__item{position:relative;padding-top:56px;}
.mapla-timeline__dot{position:absolute;top:21px;left:0;width:14px;height:14px;border-radius:999px;background:var(--bg);border:2px solid var(--brand);box-shadow:0 0 0 6px var(--bg);}
.mapla-timeline__y{font-size:12px;font-weight:700;color:var(--accent);letter-spacing:.1em;}
.mapla-timeline__t{font-family:var(--display);font-size:20px;color:var(--ink);margin:6px 0 8px;font-weight:500;}
.mapla-timeline__d{font-size:13px;color:var(--muted);line-height:1.5;text-wrap:pretty;}

/* Process */
.mapla-process{padding:120px 48px;background:var(--bg-alt);overflow:hidden;}
.mapla-process__grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.mapla-process__diagram{aspect-ratio:1/1;}
.mapla-step{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;padding:22px 24px;margin-bottom:12px;border-radius:14px;background:transparent;border:1px solid var(--line);cursor:pointer;transition:all .3s;text-align:left;width:100%;font-family:inherit;}
.mapla-step.is-active{background:var(--surface);border-color:var(--brand);}
.mapla-step__n{font-family:var(--display);font-size:28px;font-weight:500;color:var(--muted);letter-spacing:-.02em;line-height:1;}
.mapla-step.is-active .mapla-step__n{color:var(--brand);}
.mapla-step__t{font-family:var(--display);font-size:20px;font-weight:500;color:var(--ink);margin-bottom:4px;}
.mapla-step__d{font-size:14px;color:var(--ink-soft);line-height:1.55;text-wrap:pretty;}

/* Products */
.mapla-products{padding:120px 48px;background:var(--bg);}
.mapla-filter{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:32px;align-items:center;}
.mapla-filter__label{font-size:12px;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;margin-right:8px;}
.mapla-filter__btn{padding:8px 16px;border-radius:999px;background:transparent;color:var(--ink-soft);border:1px solid var(--line);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;}
.mapla-filter__btn.is-active{background:var(--ink);color:var(--bg);border-color:var(--ink);}
.mapla-products__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.mapla-product{background:var(--surface);border-radius:18px;padding:28px;border:1px solid var(--line);transition:transform .3s,box-shadow .3s,border-color .2s;position:relative;overflow:hidden;}
.mapla-product:hover{transform:translateY(-6px);border-color:var(--brand);box-shadow:0 20px 40px -20px color-mix(in oklab, var(--brand) 40%, transparent);}
.mapla-product[hidden]{display:none;}
.mapla-product__visual{aspect-ratio:16/10;border-radius:12px;margin-bottom:24px;position:relative;overflow:hidden;background:linear-gradient(135deg, color-mix(in oklab, var(--brand-soft) 20%, transparent) 0%, color-mix(in oklab, var(--accent) 15%, transparent) 100%);border:1px solid var(--line);}
.mapla-granule{position:absolute;width:20px;height:20px;border-radius:999px;background:var(--brand-soft);opacity:.7;}
.mapla-granule.is-accent{background:var(--accent);}
.mapla-product__cat{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;}
.mapla-product__name{font-family:var(--display);font-size:24px;color:var(--ink);margin:8px 0 10px;font-weight:500;letter-spacing:-.01em;}
.mapla-product__d{font-size:14px;color:var(--ink-soft);line-height:1.55;text-wrap:pretty;min-height:66px;margin:0;}
.mapla-product__tags{display:flex;gap:6px;margin-top:20px;flex-wrap:wrap;}
.mapla-tag{padding:4px 10px;border-radius:999px;background:color-mix(in oklab, var(--brand) 10%, transparent);border:1px solid color-mix(in oklab, var(--brand) 20%, transparent);color:var(--brand-deep);font-size:11px;font-weight:500;}
.mapla-product__cta{margin-top:24px;padding-top:20px;border-top:1px solid var(--line);}
.mapla-product__cta a{color:var(--brand);font-weight:600;font-size:13px;text-decoration:none;display:inline-flex;align-items:center;gap:8px;}

/* Videos */
.mapla-videos{padding:120px 48px;background:var(--bg);}
.mapla-videos__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.mapla-video-card{background:var(--surface);border-radius:18px;border:1px solid var(--line);overflow:hidden;}
.mapla-video-card__frame{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden;cursor:pointer;}
.mapla-video-card__frame img{width:100%;height:100%;object-fit:cover;}
.mapla-video-card__frame::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg, rgba(14,42,30,.25) 0%, rgba(14,42,30,.55) 100%);transition:opacity .3s;}
.mapla-video-card__frame.is-playing::before,.mapla-video-card__frame.is-playing .mapla-video-card__play{display:none;}
.mapla-video-card__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:76px;height:76px;border-radius:999px;background:rgba(255,255,255,.95);border:none;display:flex;align-items:center;justify-content:center;color:var(--brand-deep);box-shadow:0 20px 40px -10px rgba(0,0,0,.4);cursor:pointer;}
.mapla-video-card__meta{padding:22px 24px;}
.mapla-video-card__meta h3{font-family:var(--display);font-size:20px;color:var(--ink);font-weight:500;margin:0 0 6px;}
.mapla-video-card__meta p{font-size:14px;color:var(--ink-soft);margin:0;}

/* Sustainability */
.mapla-sustain{padding:120px 48px;background:var(--bg-alt);position:relative;overflow:hidden;}
.mapla-sustain__bg{position:absolute;inset:0;background:var(--grad-b);opacity:.5;}
.mapla-sustain > .mapla-container{position:relative;}
.mapla-sustain__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:80px;}
.mapla-pillar{padding:32px 28px;background:var(--surface);border-radius:16px;border:1px solid var(--line);}
.mapla-pillar__icon{width:44px;height:44px;border-radius:10px;background:color-mix(in oklab, var(--brand) 12%, transparent);display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--brand);}
.mapla-pillar__icon svg{width:22px;height:22px;}
.mapla-pillar h3{font-family:var(--display);font-size:20px;color:var(--ink);font-weight:500;margin:0 0 10px;line-height:1.2;}
.mapla-pillar p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin:0;text-wrap:pretty;}
.mapla-sdg{padding:56px 48px;border-radius:24px;background:var(--surface);border:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.mapla-sdg__label{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px;}
.mapla-sdg h3{font-family:var(--display);font-size:32px;color:var(--ink);font-weight:500;margin:0 0 12px;letter-spacing:-.02em;line-height:1.15;text-wrap:balance;}
.mapla-sdg p{font-size:16px;color:var(--ink-soft);margin:0;line-height:1.55;}
.mapla-sdg__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.mapla-sdg__tile{aspect-ratio:1/1;border-radius:12px;background:linear-gradient(135deg, var(--brand) 0%, var(--brand-deep) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;padding:14px;text-align:center;}
.mapla-sdg__tile-label{font-size:10px;font-weight:700;letter-spacing:.1em;opacity:.8;}
.mapla-sdg__tile-num{font-family:var(--display);font-size:42px;font-weight:600;line-height:1;}

/* Contact */
.mapla-contact{padding:120px 48px;background:var(--bg);}
.mapla-contact__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start;}
.mapla-contact__info{display:flex;flex-direction:column;gap:22px;margin-top:40px;}
.mapla-contact__row{padding-bottom:22px;border-bottom:1px solid var(--line);}
.mapla-contact__label{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;}
.mapla-contact__value{font-family:var(--display);font-size:20px;color:var(--ink);margin-top:6px;font-weight:500;}

/* Form container */
.mapla-form-wrap{position:relative;}
.mapla-form{background:var(--bg-alt);border-radius:20px;padding:40px;border:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr;gap:22px;}

/* Honeypot — MUST be invisible to real users */
.mapla-hp{position:absolute !important;left:-10000px !important;top:auto !important;width:1px !important;height:1px !important;overflow:hidden !important;}

/* Field block */
.mapla-field{display:flex;flex-direction:column;gap:8px;min-width:0;}
.mapla-field--full{grid-column:1 / -1;}
.mapla-field > label{display:block;font-family:var(--body);font-size:13px;font-weight:600;color:var(--ink);letter-spacing:.02em;text-transform:none;margin:0;}
.mapla-req{color:var(--accent);margin-left:2px;font-weight:600;}
.mapla-opt{color:var(--muted);font-weight:400;font-size:12px;text-transform:none;letter-spacing:normal;margin-left:4px;}

.mapla-field input[type="text"],
.mapla-field input[type="email"],
.mapla-field input[type="tel"],
.mapla-field select,
.mapla-field textarea{
  width:100%;box-sizing:border-box;
  padding:13px 16px;border-radius:10px;
  background:var(--bg);border:1px solid var(--line);
  font-family:var(--body);font-size:15px;color:var(--ink);
  outline:none;resize:vertical;
  transition:border-color .18s, box-shadow .18s, background .18s;
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
}
.mapla-field select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236B7A6E' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;
  cursor:pointer;
}
.mapla-field textarea{min-height:120px;line-height:1.5;}
.mapla-field input:focus,
.mapla-field select:focus,
.mapla-field textarea:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(30,107,58,.12);}

/* Autofill override — prevents browser's ugly yellow/blue autofill background */
.mapla-field input:-webkit-autofill,
.mapla-field input:-webkit-autofill:hover,
.mapla-field input:-webkit-autofill:focus,
.mapla-field textarea:-webkit-autofill{
  -webkit-box-shadow:0 0 0 1000px var(--bg) inset !important;
  -webkit-text-fill-color:var(--ink) !important;
  caret-color:var(--ink);
  transition:background-color 9999s ease-out 0s;
}

/* Field error state */
.mapla-field.is-invalid input,
.mapla-field.is-invalid select,
.mapla-field.is-invalid textarea{border-color:#C0392B;background:#FDF3F1;}
.mapla-field.is-invalid input:focus,
.mapla-field.is-invalid select:focus,
.mapla-field.is-invalid textarea:focus{box-shadow:0 0 0 3px rgba(192,57,43,.12);}
.mapla-field__err{font-size:12.5px;color:#C0392B;font-weight:500;min-height:0;line-height:1.4;}
.mapla-field__err:empty{display:none;}

/* Checkboxes (KVKK + marketing) */
.mapla-check{gap:10px;}
.mapla-check > label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:14px;font-weight:400;color:var(--ink);line-height:1.5;text-transform:none;letter-spacing:normal;}
.mapla-check input[type="checkbox"]{flex-shrink:0;width:18px;height:18px;margin-top:2px;accent-color:var(--brand);cursor:pointer;}
.mapla-check span{flex:1;}
.mapla-check a{color:var(--brand);text-decoration:underline;font-weight:500;}
.mapla-check a:hover{color:var(--brand-deep);}

/* Submit button */
.mapla-form__submit{justify-self:end;position:relative;min-width:160px;justify-content:center;}
.mapla-form__submit-spinner{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:mapla-spin .7s linear infinite;}
.mapla-form__submit.is-loading .mapla-form__submit-label,
.mapla-form__submit.is-loading svg{opacity:.4;}
.mapla-form__submit.is-loading .mapla-form__submit-spinner{display:inline-block;}
.mapla-form__submit:disabled{opacity:.75;cursor:not-allowed;}
@keyframes mapla-spin{to{transform:rotate(360deg);}}

/* Result cards (success / error) */
.mapla-form-result{background:var(--bg-alt);border-radius:20px;padding:48px 40px;border:1px solid var(--line);display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;}
.mapla-form-result--success{border-color:var(--brand-soft);background:#F2F9F4;color:var(--brand-deep);}
.mapla-form-result--success svg{color:var(--brand);}
.mapla-form-result--error{border-color:#E8B5AD;background:#FDF3F1;color:#7A1F12;}
.mapla-form-result--error svg{color:#C0392B;}
.mapla-form-result__title{font-family:var(--display);font-size:24px;font-weight:600;margin:0;}
.mapla-form-result__body{font-size:15px;line-height:1.55;max-width:420px;margin:0;color:inherit;opacity:.88;}
.mapla-form-result__actions{display:flex;flex-direction:column;align-items:center;gap:14px;margin-top:6px;}
.mapla-form-result__fallback{font-size:14px;color:inherit;opacity:.85;}
.mapla-form-result__fallback a{color:var(--brand);font-weight:600;text-decoration:underline;}
.mapla-form-result__fallback a:hover{color:var(--brand-deep);}

/* Footer */
.mapla-footer{padding:80px 48px 40px;background:var(--ink);color:var(--bg);}
.mapla-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:60px;margin-bottom:60px;}
.mapla-footer__brand-row{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
.mapla-footer__mark{width:36px;height:36px;background:#fff;border-radius:8px;padding:5px;object-fit:contain;flex-shrink:0;}
.mapla-footer__col a{color:var(--bg);opacity:.85;text-decoration:none;font-size:14px;cursor:pointer;transition:opacity .2s;}
.mapla-footer__col a:hover{opacity:1;color:var(--brand-soft);}

/* Legal modal */
.mapla-legal-modal{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;transition:opacity .25s;}
.mapla-legal-modal.is-open{opacity:1;}
.mapla-legal-modal[hidden]{display:none;}
.mapla-legal-modal__backdrop{position:absolute;inset:0;background:rgba(10,26,18,.72);backdrop-filter:blur(4px);}
.mapla-legal-modal__panel{position:relative;background:var(--bg);border-radius:16px;max-width:640px;width:100%;max-height:85vh;overflow-y:auto;padding:44px 44px 36px;box-shadow:0 30px 80px rgba(0,0,0,.35);transform:translateY(12px) scale(.98);transition:transform .3s cubic-bezier(.16,1,.3,1);}
.mapla-legal-modal.is-open .mapla-legal-modal__panel{transform:translateY(0) scale(1);}
.mapla-legal-modal__close{position:absolute;top:14px;right:14px;width:36px;height:36px;border:0;background:var(--surface);border-radius:50%;font-size:22px;line-height:1;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.mapla-legal-modal__close:hover{background:var(--brand);color:#fff;transform:rotate(90deg);}
.mapla-legal-modal__title{font-family:var(--display);font-size:28px;font-weight:500;color:var(--ink);margin:0 0 20px;letter-spacing:-.01em;}
.mapla-legal-modal__body{font-size:14.5px;line-height:1.7;color:var(--ink-soft);}
.mapla-legal-modal__body p{margin:0 0 14px;}
.mapla-legal-modal__body ul{margin:0 0 14px;padding-left:20px;}
.mapla-legal-modal__body li{margin-bottom:6px;}
.mapla-legal-modal__body a{color:var(--brand);text-decoration:underline;}
.mapla-legal-modal__body strong{color:var(--ink);font-weight:600;}
.mapla-footer__name{font-family:var(--display);font-size:22px;font-weight:500;}
.mapla-footer__name em{font-style:normal;opacity:.7;}
.mapla-footer__tag{font-size:15px;opacity:.7;line-height:1.6;max-width:320px;margin:0;}
.mapla-footer__col-title{font-size:11px;font-weight:700;opacity:.5;letter-spacing:.14em;text-transform:uppercase;margin-bottom:20px;}
.mapla-footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;}
.mapla-footer__col a{color:var(--bg);opacity:.85;text-decoration:none;font-size:14px;cursor:pointer;}
.mapla-footer__bottom{padding-top:24px;border-top:1px solid rgba(255,255,255,.13);display:flex;justify-content:space-between;font-size:13px;opacity:.6;}
.mapla-footer__social{margin-top:28px;}
.mapla-social{display:flex;gap:10px;flex-wrap:wrap;}
.mapla-social__link{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,.06);color:var(--bg);opacity:.85;transition:all .2s;border:1px solid rgba(255,255,255,.08);}
.mapla-social__link:hover{opacity:1;background:var(--brand);color:#fff;border-color:var(--brand);transform:translateY(-1px);}
.mapla-nav__social{display:flex;gap:6px;align-items:center;margin-right:4px;}
.mapla-nav__social a{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--ink);opacity:.65;transition:all .15s;}
.mapla-nav__social a:hover{opacity:1;color:var(--brand);background:var(--bg-alt);}
@media (max-width:720px){.mapla-nav__social{display:none;}}

/* Page header */
.mapla-page-header{padding:160px 48px 60px;background:var(--bg-alt);border-bottom:1px solid var(--line);}
.mapla-page-title{font-family:var(--display);font-size:56px;color:var(--ink);font-weight:500;letter-spacing:-.025em;margin:0;}
.mapla-article{padding:80px 48px;}
.mapla-article__content{max-width:820px;font-size:17px;line-height:1.7;color:var(--ink-soft);}

/* Reveal */
[data-mapla-reveal]{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1);}
[data-mapla-reveal].is-visible{opacity:1;transform:none;}

/* Responsive */
@media (max-width: 1200px){
  .mapla-nav__menu{gap:18px;}
  .mapla-nav__menu a{font-size:13px;}
  .mapla-nav__links{gap:18px;}
}
@media (max-width: 960px){
  .mapla-container,.mapla-hero,.mapla-stats,.mapla-about,.mapla-process,.mapla-products,.mapla-videos,.mapla-sustain,.mapla-contact,.mapla-footer,.mapla-nav,.mapla-page-header{padding-left:24px;padding-right:24px;}
  .mapla-hero__grid,.mapla-about__intro,.mapla-process__grid,.mapla-sdg,.mapla-contact__grid{grid-template-columns:1fr;gap:40px;}
  .mapla-hero__title{font-size:48px;}
  .mapla-h2,.mapla-h2--tight{font-size:32px;}
  .mapla-stats__grid,.mapla-products__grid,.mapla-videos__grid,.mapla-sustain__grid,.mapla-sdg__grid{grid-template-columns:repeat(2,1fr);}
  .mapla-timeline{grid-template-columns:1fr;}
  .mapla-timeline::before{left:6px;right:auto;top:0;bottom:0;width:1px;height:auto;}
  .mapla-timeline__item{padding-top:0;padding-left:32px;margin-bottom:24px;}
  .mapla-timeline__dot{top:4px;left:0;}
  .mapla-nav__links{gap:16px;}
  .mapla-nav__menu{display:none;}
  .mapla-form{grid-template-columns:1fr;padding:24px;gap:18px;}
  .mapla-field--full{grid-column:auto;}
  .mapla-form__submit{justify-self:stretch;}
  .mapla-footer__grid{grid-template-columns:1fr 1fr;gap:32px;}
}

/* Defensive: ensure [hidden] always works, even if other CSS overrides */
[hidden]{display:none !important;}
.mapla-form-result[hidden]{display:none !important;}

/* ========================================================================
   Mapla Blog styles — append to mapla.css
   ======================================================================== */

/* Archive header */
.mapla-archive-header{padding:120px 48px 40px;background:var(--bg-alt);border-bottom:1px solid var(--line);}
.mapla-archive-header .mapla-eyebrow{margin-bottom:16px;}
.mapla-archive-header .mapla-h1,
.mapla-archive-header .mapla-h1--tight{font-family:var(--display);font-size:56px;font-weight:500;line-height:1.05;letter-spacing:-1px;color:var(--ink);margin:0 0 16px;}
.mapla-archive-header .mapla-lead{font-size:18px;line-height:1.6;color:var(--muted);max-width:680px;margin:0;}

/* Archive list */
.mapla-archive{padding:60px 48px 120px;background:var(--bg);}
.mapla-archive__filter{margin-bottom:48px;}
.mapla-archive__filter .mapla-filter__btn{text-decoration:none;}
.mapla-archive__empty{text-align:center;padding:80px 0;color:var(--muted);}

/* Post grid */
.mapla-post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;}

/* Post card */
.mapla-post-card{background:var(--bg-alt);border-radius:16px;overflow:hidden;border:1px solid var(--line);transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s;}
.mapla-post-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(14,42,30,.08);}
.mapla-post-card__link{display:block;text-decoration:none;color:inherit;}
.mapla-post-card__visual{position:relative;aspect-ratio:16/10;background:var(--bg);overflow:hidden;}
.mapla-post-card__img{width:100%;height:100%;object-fit:cover;display:block;}
.mapla-post-card__placeholder{position:relative;width:100%;height:100%;background:linear-gradient(135deg,#F2F9F4 0%,#E8F2EC 100%);}
.mapla-post-card__placeholder .mapla-granule{position:absolute;width:18px;height:18px;border-radius:50%;background:var(--brand-soft);opacity:.5;}
.mapla-post-card__placeholder .mapla-granule.is-accent{background:var(--accent);opacity:.7;}
.mapla-post-card__body{padding:24px;}
.mapla-post-card__cat{font-size:11px;font-weight:700;color:var(--accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px;}
.mapla-post-card__title{font-family:var(--display);font-size:22px;font-weight:500;line-height:1.3;color:var(--ink);margin:0 0 12px;transition:color .2s;}
.mapla-post-card:hover .mapla-post-card__title{color:var(--brand);}
.mapla-post-card__excerpt{font-size:14.5px;line-height:1.55;color:var(--muted);margin:0 0 16px;}
.mapla-post-card__meta{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);letter-spacing:.02em;}
.mapla-post-card__sep{opacity:.5;}

/* Pagination */
.mapla-pagination{display:flex;justify-content:center;margin-top:60px;}
.mapla-pagination .nav-links,
.mapla-pagination .page-numbers{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.mapla-pagination a,
.mapla-pagination .current{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 14px;border-radius:10px;background:var(--bg-alt);border:1px solid var(--line);color:var(--ink);font-size:14px;font-weight:500;text-decoration:none;transition:all .15s;}
.mapla-pagination a:hover{background:var(--brand);color:#fff;border-color:var(--brand);}
.mapla-pagination .current{background:var(--brand);color:#fff;border-color:var(--brand);}

/* ========================================================================
   Single post
   ======================================================================== */
.mapla-post{background:var(--bg);}
.mapla-post__header{padding:120px 48px 48px;background:var(--bg-alt);border-bottom:1px solid var(--line);}
.mapla-post__header-inner{max-width:820px;margin:0 auto;}
.mapla-post__header .mapla-eyebrow{margin-bottom:20px;}
.mapla-post__title{font-family:var(--display);font-size:56px;font-weight:500;line-height:1.08;letter-spacing:-1px;color:var(--ink);margin:0 0 28px;}
.mapla-post__meta{display:flex;align-items:center;gap:10px;font-size:14px;color:var(--muted);flex-wrap:wrap;}
.mapla-post__sep{opacity:.5;}

.mapla-post__thumb{padding:0;background:var(--bg-alt);}
.mapla-post__thumb-img{display:block;width:100%;max-width:1040px;margin:0 auto;height:auto;border-radius:16px;box-shadow:0 8px 32px rgba(14,42,30,.08);transform:translateY(-30px);}

.mapla-post__body{padding:40px 48px 100px;}
.mapla-post__content{max-width:720px;margin:0 auto;font-size:17px;line-height:1.75;color:#2a3a2f;}
.mapla-post__content > *{margin-bottom:1.4em;}
.mapla-post__content h2{font-family:var(--display);font-size:34px;font-weight:500;line-height:1.2;color:var(--ink);margin:2em 0 .8em;letter-spacing:-.5px;}
.mapla-post__content h3{font-family:var(--display);font-size:24px;font-weight:500;line-height:1.25;color:var(--ink);margin:1.8em 0 .6em;}
.mapla-post__content h4{font-size:18px;font-weight:600;color:var(--ink);margin:1.6em 0 .5em;letter-spacing:.01em;}
.mapla-post__content p{margin:0 0 1.4em;}
.mapla-post__content a{color:var(--brand);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:color .15s;}
.mapla-post__content a:hover{color:var(--brand-deep);}
.mapla-post__content ul,
.mapla-post__content ol{padding-left:1.6em;margin:0 0 1.4em;}
.mapla-post__content ul li,
.mapla-post__content ol li{margin:0 0 .5em;}
.mapla-post__content blockquote{border-left:3px solid var(--brand);padding:4px 0 4px 24px;margin:1.6em 0;font-family:var(--display);font-size:22px;line-height:1.5;color:var(--brand-deep);font-style:italic;}
.mapla-post__content hr{border:0;border-top:1px solid var(--line);margin:2.5em 0;}
.mapla-post__content img{max-width:100%;height:auto;border-radius:12px;margin:1.5em 0;display:block;}
.mapla-post__content table{width:100%;border-collapse:collapse;margin:1.5em 0;font-size:15px;}
.mapla-post__content table th,
.mapla-post__content table td{padding:12px 16px;border:1px solid var(--line);text-align:left;vertical-align:top;}
.mapla-post__content table th{background:var(--bg-alt);font-weight:600;color:var(--ink);}
.mapla-post__content table tr:nth-child(even) td{background:var(--bg-alt);}
.mapla-post__content code{font-family:var(--mono, monospace);font-size:.88em;background:var(--bg-alt);padding:2px 6px;border-radius:4px;}
.mapla-post__content pre{background:var(--bg-alt);padding:20px;border-radius:10px;overflow-x:auto;font-size:14px;line-height:1.55;}
.mapla-post__content strong{font-weight:600;color:var(--ink);}

.mapla-post__tags{max-width:720px;margin:40px auto 0;display:flex;flex-wrap:wrap;gap:8px;padding-top:24px;border-top:1px solid var(--line);}

.mapla-post__share{max-width:720px;margin:32px auto 0;display:flex;align-items:center;gap:12px;}
.mapla-post__share-label{font-size:13px;font-weight:600;color:var(--muted);letter-spacing:.04em;}
.mapla-post__share-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;background:var(--bg-alt);border:1px solid var(--line);color:var(--muted);transition:all .15s;}
.mapla-post__share-btn:hover{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateY(-1px);}

.mapla-post__nav{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 48px;}
.mapla-post__nav-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.mapla-post__nav-link{display:flex;flex-direction:column;gap:6px;padding:20px 24px;background:var(--bg);border-radius:12px;border:1px solid var(--line);text-decoration:none;transition:all .2s;}
.mapla-post__nav-link:hover{border-color:var(--brand);transform:translateY(-2px);}
.mapla-post__nav-link--next{text-align:right;align-items:flex-end;}
.mapla-post__nav-dir{font-size:12px;font-weight:600;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;}
.mapla-post__nav-title{font-family:var(--display);font-size:17px;font-weight:500;color:var(--ink);line-height:1.3;}

.mapla-post__related{padding:80px 48px;background:var(--bg);}
.mapla-post__related .mapla-eyebrow{margin-bottom:12px;}
.mapla-post__related .mapla-h2--tight{margin-bottom:40px;}

/* Responsive */
@media (max-width: 960px){
  .mapla-archive-header{padding:80px 24px 32px;}
  .mapla-archive-header .mapla-h1,
  .mapla-archive-header .mapla-h1--tight{font-size:40px;}
  .mapla-archive{padding:40px 24px 80px;}
  .mapla-post-grid{grid-template-columns:repeat(2,1fr);gap:24px;}
  .mapla-post__header{padding:80px 24px 32px;}
  .mapla-post__title{font-size:36px;}
  .mapla-post__body{padding:30px 24px 60px;}
  .mapla-post__content{font-size:16px;}
  .mapla-post__content h2{font-size:26px;}
  .mapla-post__content h3{font-size:20px;}
  .mapla-post__nav{padding:32px 24px;}
  .mapla-post__nav-grid{grid-template-columns:1fr;gap:12px;}
  .mapla-post__nav-link--next{text-align:left;align-items:flex-start;}
  .mapla-post__related{padding:60px 24px;}
}
@media (max-width: 640px){
  .mapla-post-grid{grid-template-columns:1fr;}
  .mapla-post__title{font-size:28px;letter-spacing:-.5px;}
  .mapla-post__content{font-size:15.5px;line-height:1.7;}
}

/* =============================================================================
   MAPLA MOBILE RESPONSIVE PACK v1.1 (UTF-8 safe, ASCII comments)
   Append to the END of mapla.css. Does not replace existing rules.
   ============================================================================= */

/* Universal overflow protection */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
}
.mapla-hero,
.mapla-stats,
.mapla-about,
.mapla-process,
.mapla-products,
.mapla-videos,
.mapla-sustain,
.mapla-contact,
.mapla-footer,
.mapla-archive,
.mapla-archive-header,
.mapla-post {
  overflow-x: hidden;
}

/* =============================================================================
   HAMBURGER BUTTON (mobile nav toggle)
   ============================================================================= */
.mapla-nav__hamburger {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  background: transparent;
  border-radius: 10px;
  cursor: pointer;
  padding: 0;
  position: relative;
  flex-shrink: 0;
  transition: border-color .15s;
}
.mapla-nav__hamburger:hover {
  border-color: var(--brand);
}
.mapla-nav__hamburger > span {
  display: block;
  position: absolute;
  left: 12px;
  right: 12px;
  height: 2px;
  background: var(--ink);
  border-radius: 2px;
  transition: transform .25s cubic-bezier(.4,0,.2,1), opacity .2s, background .2s;
  transform-origin: center;
}
.mapla-nav__hamburger > span:nth-child(1) { top: 14px; }
.mapla-nav__hamburger > span:nth-child(2) { top: 21px; }
.mapla-nav__hamburger > span:nth-child(3) { top: 28px; }
.mapla-nav__hamburger.is-open > span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.mapla-nav__hamburger.is-open > span:nth-child(2) {
  opacity: 0;
}
.mapla-nav__hamburger.is-open > span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* =============================================================================
   TABLET AND BELOW (max-width 960px)
   ============================================================================= */
@media (max-width: 960px) {
  .mapla-container { padding: 0 20px; }
  .mapla-nav {
    padding: 12px 20px;
    z-index: 70;
  }

  /* Show hamburger */
  .mapla-nav__hamburger {
    display: block;
    position: relative;
    z-index: 71;
  }

  /* Open-state hamburger color change */
  .mapla-nav__hamburger.is-open {
    background: var(--bg);
    border-color: var(--brand);
  }
  .mapla-nav__hamburger.is-open > span {
    background: var(--brand);
  }

  /* Nav links become full-screen overlay */
  .mapla-nav__links {
    display: none;
    position: fixed;
    top: 0; left: 0; right: 0; bottom: 0;
    z-index: 60;
    background: var(--bg);
    flex-direction: column;
    align-items: stretch;
    justify-content: flex-start;
    padding: 80px 24px 40px;
    gap: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .mapla-nav__links.is-open {
    display: flex;
    animation: maplaMobileSlide .25s cubic-bezier(.16,1,.3,1);
  }
  @keyframes maplaMobileSlide {
    from { opacity: 0; transform: translateY(-10px); }
    to   { opacity: 1; transform: translateY(0); }
  }

  .mapla-nav__menu {
    display: flex !important;
    flex-direction: column;
    gap: 0;
    width: 100%;
    margin-bottom: 28px;
    list-style: none;
    padding: 0;
  }
  .mapla-nav__menu li {
    border-bottom: 1px solid var(--line);
    list-style: none;
  }
  .mapla-nav__menu a {
    display: block;
    width: 100%;
    padding: 16px 4px;
    font-size: 17px;
    font-weight: 500;
    color: var(--ink);
    text-decoration: none;
  }
  .mapla-nav__menu a::after { display: none; }
  .mapla-nav__menu a:hover,
  .mapla-nav__menu a.is-current {
    color: var(--brand);
    background: transparent;
  }

  .mapla-nav__social {
    display: flex !important;
    justify-content: center;
    gap: 14px;
    margin: 20px 0;
    padding: 20px 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
  }
  .mapla-nav__social a {
    width: 44px;
    height: 44px;
    background: var(--bg-alt);
    border-radius: 12px;
  }

  .mapla-nav__lang {
    align-self: center;
    margin-top: 8px;
  }

  .mapla-nav__cta {
    width: 100%;
    justify-content: center;
    margin-top: 16px;
    padding: 16px 20px;
    font-size: 16px;
  }

  /* Body scroll lock (iOS compatible) */
  body.mapla-nav-open {
    overflow: hidden !important;
    position: fixed;
    width: 100%;
    height: 100%;
  }
}

/* =============================================================================
   MOBILE (max-width 640px)
   ============================================================================= */
@media (max-width: 640px) {
  .mapla-container { padding: 0 16px; }
  .mapla-nav { padding: 10px 16px; }

  .mapla-nav__name { font-size: 17px; }
  .mapla-nav__brand img,
  .mapla-nav__brand .custom-logo,
  .mapla-nav__mark { height: 32px !important; width: 32px !important; }

  /* Hero */
  .mapla-hero {
    padding: 110px 16px 60px;
    min-height: auto;
  }
  .mapla-hero__grid {
    grid-template-columns: 1fr !important;
    gap: 40px !important;
  }
  .mapla-hero__title {
    font-size: 36px !important;
    line-height: 1.08 !important;
    letter-spacing: -0.02em;
    margin: 16px 0 !important;
    word-break: normal;
    overflow-wrap: break-word;
  }
  .mapla-hero__sub {
    font-size: 16px;
    line-height: 1.55;
    max-width: 100%;
  }
  .mapla-hero__ctas {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
    margin-top: 28px;
  }
  .mapla-hero__ctas .mapla-btn {
    width: 100%;
    justify-content: center;
    padding: 14px 20px;
    font-size: 15px;
  }
  .mapla-hero__stats {
    flex-direction: column;
    gap: 20px;
    margin-top: 32px;
  }
  .mapla-ministat__k { font-size: 26px; }
  .mapla-hero__visual { max-width: 320px; margin: 0 auto; }

  .mapla-eyebrow,
  .mapla-eyebrow--badge {
    font-size: 11px;
  }

  .mapla-h2,
  .mapla-h2--tight {
    font-size: 26px !important;
    line-height: 1.15 !important;
    letter-spacing: -0.01em;
  }
  .mapla-section-head,
  .mapla-section-head--narrow {
    margin-bottom: 32px;
  }
  .mapla-lead {
    font-size: 15px;
    line-height: 1.55;
  }

  .mapla-stats { padding: 60px 16px; }
  .mapla-stats__grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }
  .mapla-stat__k { font-size: 42px !important; }
  .mapla-stat__v { font-size: 14px; }

  .mapla-about { padding: 60px 16px; }
  .mapla-timeline__num { font-size: 14px; }
  .mapla-timeline__title { font-size: 16px; }
  .mapla-timeline__desc { font-size: 13.5px; }

  .mapla-process { padding: 60px 16px; }
  .mapla-process__grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  .mapla-process__diagram {
    aspect-ratio: 1/1;
    max-width: 320px;
    margin: 0 auto;
  }
  .mapla-step {
    padding: 16px 18px;
  }

  .mapla-products { padding: 60px 16px; }
  .mapla-products__grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }
  .mapla-product {
    padding: 24px 20px;
  }
  .mapla-product__visual {
    height: 140px;
    overflow: hidden;
  }
  .mapla-product__name {
    font-size: 20px !important;
    line-height: 1.2 !important;
    word-break: normal;
  }
  .mapla-product__d {
    font-size: 14px;
  }
  .mapla-product__tags {
    flex-wrap: wrap;
  }
  .mapla-filter {
    flex-wrap: wrap;
    gap: 8px;
  }
  .mapla-filter__label {
    width: 100%;
    margin-bottom: 8px;
    text-align: left;
  }
  .mapla-filter__btn {
    font-size: 13px;
    padding: 7px 14px;
  }

  .mapla-videos { padding: 60px 16px; }
  .mapla-videos__grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }

  .mapla-sustain { padding: 60px 16px; }
  .mapla-sustain__grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }
  .mapla-sdg__grid {
    grid-template-columns: repeat(2,1fr) !important;
    gap: 12px;
  }
  .mapla-sdg__tile-num { font-size: 30px !important; }

  .mapla-contact { padding: 60px 16px; }
  .mapla-contact__grid {
    gap: 32px !important;
  }
  .mapla-contact__value { font-size: 16px; }

  .mapla-form {
    padding: 20px !important;
    gap: 14px !important;
  }
  .mapla-field input,
  .mapla-field select,
  .mapla-field textarea {
    font-size: 16px;
    padding: 12px 14px;
  }
  .mapla-form__submit {
    width: 100%;
    justify-content: center;
  }

  .mapla-footer { padding: 50px 16px 30px; }
  .mapla-footer__grid {
    grid-template-columns: 1fr !important;
    gap: 28px;
    margin-bottom: 32px;
  }
  .mapla-footer__col a { font-size: 15px; }

  .mapla-archive-header { padding: 90px 16px 28px; }
  .mapla-archive-header .mapla-h1,
  .mapla-archive-header .mapla-h1--tight {
    font-size: 34px !important;
    line-height: 1.1;
  }
  .mapla-archive { padding: 30px 16px 60px; }
  .mapla-post-grid {
    grid-template-columns: 1fr !important;
    gap: 20px;
  }
  .mapla-archive__filter {
    flex-wrap: wrap;
    margin-bottom: 28px;
  }

  .mapla-post__header { padding: 90px 16px 28px; }
  .mapla-post__title {
    font-size: 26px !important;
    line-height: 1.12 !important;
    letter-spacing: -0.005em;
  }
  .mapla-post__meta {
    font-size: 13px;
    gap: 6px;
  }
  .mapla-post__body { padding: 24px 16px 50px; }
  .mapla-post__content {
    font-size: 15.5px;
    line-height: 1.7;
  }
  .mapla-post__content h2 {
    font-size: 22px !important;
    margin: 1.6em 0 .5em !important;
  }
  .mapla-post__content h3 {
    font-size: 18px !important;
  }
  .mapla-post__content table {
    font-size: 13px;
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .mapla-post__nav { padding: 24px 16px; }
  .mapla-post__nav-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }
  .mapla-post__nav-link--next {
    text-align: left !important;
    align-items: flex-start !important;
  }
  .mapla-post__related { padding: 50px 16px; }
  .mapla-post__share {
    flex-wrap: wrap;
  }
  .mapla-post__thumb-img {
    transform: translateY(-20px);
    border-radius: 10px;
  }

  .mapla-legal-modal__panel {
    max-height: 90vh;
    padding: 30px 20px 24px;
    border-radius: 12px;
    margin: 20px;
  }
}

/* =============================================================================
   EXTRA SMALL (max-width 380px)
   ============================================================================= */
@media (max-width: 380px) {
  .mapla-hero__title { font-size: 30px !important; }
  .mapla-h2, .mapla-h2--tight { font-size: 22px !important; }
  .mapla-nav__name { display: none; }
  .mapla-stat__k { font-size: 36px !important; }
  .mapla-post__title { font-size: 22px !important; }
}