/* ============================================================
   ROSH Plastic — landing page styles
   Brand: PT Roshan Strategi Nusantara · navy #05244d
   Display: Bricolage Grotesque · Body: Plus Jakarta Sans
   Blue (steel) = brand accent · Green = WhatsApp action only
   ============================================================ */
:root{
  --navy:#05244d;
  --navy-d:#041a39;
  --navy-700:#0c3a72;
  --navy-600:#15498a;
  --steel:#3f7fc4;
  --sky:#7fb0ec;
  /* warm marigold accent — script words + line-art doodles */
  --amber:#e3a23a;
  --amber-d:#c9842a;
  --accent:#e3a23a;
  --ink:#1f2533;
  --slate:#6b6353;
  --slate-l:#928a78;
  --bg:#ffffff;
  /* warm "paper" neutrals */
  --paper:#f4ebd9;
  --paper-2:#efe5d1;
  --bg-soft:#efe5d1;
  --bg-soft2:#e7dbc2;
  --line:#e4d9c1;
  --line-d:#d6c8a9;
  --wa:#22c55e;
  --wa-d:#16a34a;
  --wa-ink:#06351a;
  --f-display:"Bricolage Grotesque", system-ui, sans-serif;
  --f-script:"Caveat", "Bricolage Grotesque", cursive;
  --f-body:"Plus Jakarta Sans", system-ui, sans-serif;
  --container:1200px;
  --radius:16px;
  --r-sm:10px;
  --r-lg:24px;
  /* navy-tinted shadows — single light source, top-down */
  --shadow-sm:0 2px 10px rgba(5,36,77,0.06);
  --shadow-card:0 6px 24px -10px rgba(5,36,77,0.18);
  --shadow:0 18px 44px -16px rgba(5,36,77,0.26);
  --shadow-lg:0 40px 80px -24px rgba(5,36,77,0.34);
  /* z-index scale */
  --z-fab:55;
  --z-nav:60;
  --z-scrim:65;
  --z-menu:70;
  --z-grain:120;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
body{
  margin:0;font-family:var(--f-body);color:var(--ink);background:var(--paper);
  font-size:17px;line-height:1.62;-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;line-height:1.02;letter-spacing:-0.025em;margin:0;text-wrap:balance;}
p{margin:0;text-wrap:pretty;}

/* visible keyboard focus — accessibility */
a:focus-visible,button:focus-visible,.btn:focus-visible,.faq-q:focus-visible{
  outline:2.5px solid var(--steel);outline-offset:3px;border-radius:6px;
}

/* skip link */
.skip-link{position:fixed;top:-60px;left:16px;z-index:200;background:var(--navy);color:#fff;
  font-family:var(--f-display);font-weight:600;font-size:14px;padding:10px 16px;border-radius:10px;transition:top .2s;}
.skip-link:focus{top:16px;}

/* paper-grain overlay — breaks digital flatness, reads like printed stock */
.grain{position:fixed;inset:0;z-index:var(--z-grain);pointer-events:none;opacity:0.07;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------- script accent + hand-drawn decorations ---------- */
/* handwritten word inside a headline (marigold), reference-style */
.script{font-family:var(--f-script);font-weight:700;font-style:normal;color:#bd7a12;
  letter-spacing:0;line-height:0.8;display:inline-block;transform:rotate(-3deg);
  padding:0 .06em;font-size:1.18em;}
.h-sec .script{font-size:1.22em;}
.hero h1 .script{font-size:1.05em;}
/* on dark navy bands, brighten the marigold for contrast */
.on-navy .script,.hero h1 .script{color:var(--amber);}

/* line-art doodle wrapper — navy ink sketches, low presence */
.doodle{position:absolute;pointer-events:none;color:var(--navy);opacity:.13;z-index:0;}
.doodle svg{width:100%;height:100%;display:block;}
.doodle.amber{color:var(--amber);opacity:.9;}
.sec-head{position:relative;}
/* little marigold sparkle sitting above a section title */
.spark{display:flex;color:var(--amber);width:40px;height:26px;margin-bottom:12px;}
.spark svg{width:100%;height:100%;}

/* postage-stamp photo frame — perforated white mount, holes show paper behind.
   Degrades gracefully to a clean white mount where mask-composite is unsupported. */
.stamp{position:relative;background:#fdfaf2;padding:14px;
  box-shadow:0 24px 54px -18px rgba(5,36,77,0.5);
  --r:6px;        /* perforation radius */
  --g:17px;       /* spacing between perforations */
  -webkit-mask:
    radial-gradient(var(--r) at 50% 0,#0000 96%,#000) 50% 0/var(--g) 100% repeat-x,
    radial-gradient(var(--r) at 50% 100%,#0000 96%,#000) 50% 100%/var(--g) 100% repeat-x,
    radial-gradient(var(--r) at 0 50%,#0000 96%,#000) 0 50%/100% var(--g) repeat-y,
    radial-gradient(var(--r) at 100% 50%,#0000 96%,#000) 100% 50%/100% var(--g) repeat-y;
  mask:
    radial-gradient(var(--r) at 50% 0,#0000 96%,#000) 50% 0/var(--g) 100% repeat-x,
    radial-gradient(var(--r) at 50% 100%,#0000 96%,#000) 50% 100%/var(--g) 100% repeat-x,
    radial-gradient(var(--r) at 0 50%,#0000 96%,#000) 0 50%/100% var(--g) repeat-y,
    radial-gradient(var(--r) at 100% 50%,#0000 96%,#000) 100% 50%/100% var(--g) repeat-y;
  -webkit-mask-composite:source-in;
  mask-composite:intersect;
}
.stamp > *{border-radius:2px;overflow:hidden;display:block;}
.stamp::after{content:"";position:absolute;inset:9px;border:1.5px dashed rgba(5,36,77,0.16);pointer-events:none;}
.stamp-tilt{transform:rotate(-3.2deg);}
.stamp-tilt-r{transform:rotate(2.4deg);}

/* ---- hand-drawn illustration placements ----
   art-*.png are navy line-art on white; mix-blend multiply drops the white
   so only the linework sits on the cream sections. Decorative → hidden on small screens. */
.section-art{position:absolute;pointer-events:none;z-index:0;mix-blend-mode:multiply;}
.section-art img{display:block;width:100%;height:auto;}
.products,.brands-section,#industri,#faq,#testimoni{position:relative;overflow:hidden;}
.products .container,.brands-section .container,#industri .container,#faq .container,#testimoni .container,.delivery .container{position:relative;z-index:1;}
/* Jakarta (Monas) skyline — full-bleed backdrop behind the Industri cards.
   Anchored to the section bottom at natural ratio (~2.21:1 → ~45vw tall) so Monas
   rises up toward the heading while the buildings sit in the floor below the cards. */
#industri{padding-bottom:18vw;}
.art-skyline{left:0;bottom:0;width:100%;height:auto;opacity:.28;}
.art-skyline img{display:block;width:100%;height:auto;}
/* delivery rider — armada internal (kept left so it sits on cream, not behind the navy card) */
/* truck parked bottom-right, in the floor below the navy area card; flipped to face left */
.art-rider{right:3%;bottom:8px;width:min(440px,38%);opacity:.42;}
.art-rider img{transform:scaleX(-1);}
/* thinwall stack — tightly-cropped (~1.16:1), sits top-right of the products band */
.art-stack{right:1%;top:40px;width:min(420px,30%);opacity:.5;}
/* street delivery scene — full-bleed band anchored to the FAQ floor; faint so the
   accordion text stays readable over the empty sky in the upper part of the image */
.art-street{left:0;right:0;bottom:-13vw;width:100%;opacity:.22;}
#faq{padding-bottom:14vw;}
/* floating packaging clusters flanking the brand cards (portrait line-art, 1024x1536).
   Big & bold: ~half the illustration tucks BEHIND the outermost card (cards sit
   above via container z-index), the other half spills into the gutter / off-screen.
   left offset = container half (600) + half the art width (360) so the inner edge
   lands roughly at the card's far edge. Hidden on small screens (≤1024) below. */
.art-float-right{right:calc(50% - 600px - 210px);top:50%;transform:translateY(-50%);width:720px;opacity:.38;}
/* thinwall cluster on the right of the testimonials section (moved from brands) */
.art-testi-right{right:calc(50% - 600px - 210px);top:50%;transform:translateY(-50%);width:720px;opacity:.38;}
@media (max-width:1024px){ .section-art{display:none;} .brands-section{padding-bottom:96px;} #industri{padding-bottom:72px;} #testimoni{padding-top:84px;} .delivery{padding-bottom:64px;} }

.container{max-width:var(--container);margin:0 auto;padding:0 28px;}
.section{padding:104px 0 116px;}
.section-tight{padding:72px 0;}

/* ---------- type helpers ---------- */
.overline{font-family:var(--f-display);font-weight:600;font-size:13px;letter-spacing:0.16em;text-transform:uppercase;color:var(--amber-d);}
.eyebrow-rule{display:inline-flex;align-items:center;gap:11px;}
.eyebrow-rule::before{content:"";width:26px;height:2px;background:currentColor;border-radius:2px;}
.h-sec{font-size:clamp(33px,4.4vw,52px);color:var(--navy);letter-spacing:-0.03em;}
.h-sec.on-navy{color:#fff;}
.lead{font-size:19px;color:var(--slate);line-height:1.6;max-width:62ch;}
.lead.on-navy{color:rgba(255,255,255,0.82);}
.center{text-align:center;}
/* section heads — left-aligned editorial, breaks the centered-everything look */
.sec-head{max-width:760px;margin:0 0 60px;}
.sec-head.center{margin-left:0;margin-right:auto;text-align:left;}
.sec-head .overline{display:inline-block;margin-bottom:18px;}
.sec-head .h-sec{margin-bottom:16px;}
.sec-head .lead{margin:0;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--f-display);
  font-weight:600;font-size:16px;letter-spacing:0;border:none;cursor:pointer;
  padding:15px 28px;border-radius:12px;
  transition:transform .16s cubic-bezier(.2,.7,.3,1), box-shadow .2s, background .2s, color .2s, border-color .2s;white-space:nowrap;}
.btn:hover{transform:translateY(-2px);}
.btn:active{transform:translateY(0) scale(.985);}
.btn svg{width:20px;height:20px;flex:0 0 auto;}
.btn-wa{background:var(--wa);color:#fff;box-shadow:0 10px 26px -8px rgba(34,197,94,0.55);}
.btn-wa:hover{background:#27d06a;box-shadow:0 16px 34px -10px rgba(34,197,94,0.6);}
.btn-ghost{background:rgba(255,255,255,0.04);color:#fff;border:1.5px solid rgba(255,255,255,0.45);backdrop-filter:blur(2px);}
.btn-ghost:hover{background:rgba(255,255,255,0.12);border-color:#fff;}
.btn-ghost-d{background:transparent;color:var(--navy);border:1.5px solid var(--line-d);}
.btn-ghost-d:hover{background:var(--bg-soft);border-color:var(--navy);}
.btn-navy{background:var(--navy);color:#fff;box-shadow:var(--shadow-sm);}
.btn-navy:hover{background:var(--navy-700);}
.btn-pill{border-radius:999px;padding:13px 24px;font-size:15px;}
.btn-sm{padding:11px 18px;font-size:14.5px;border-radius:9px;}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:var(--z-nav);transition:background .25s, box-shadow .25s, padding .25s;}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:22px 28px;max-width:1340px;margin:0 auto;}
.nav-logo-link{text-decoration:none;display:flex;align-items:center;}
.nav-logo-img{height:46px;width:auto;display:block;transition:height .25s;}
.nav.scrolled .nav-logo-img{height:40px;}
.nav-logo-txt{display:flex;flex-direction:column;line-height:1;gap:2px;}
.nl-main{font-family:var(--f-display);font-weight:800;font-size:28px;letter-spacing:0.02em;text-transform:uppercase;color:#fff;font-style:italic;padding-bottom:4px;border-bottom:2.5px solid rgba(255,255,255,0.9);}
.nl-sub{font-family:var(--f-display);font-weight:600;font-size:9px;letter-spacing:0.32em;text-transform:uppercase;color:rgba(255,255,255,0.65);margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none;margin:0;padding:0;}
.nav-links a{font-family:var(--f-display);font-weight:500;font-size:15px;color:#fff;opacity:0.82;transition:opacity .15s, color .15s;position:relative;padding:4px 0;}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--sky);transition:right .25s cubic-bezier(.2,.7,.3,1);border-radius:2px;}
.nav-links a:hover{opacity:1;}
.nav-links a:hover::after{right:0;}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav.scrolled{background:rgba(5,36,77,0.94);backdrop-filter:saturate(140%) blur(12px);box-shadow:0 10px 30px -12px rgba(4,26,57,0.6);}
.nav.scrolled .nav-inner{padding:14px 28px;}
.nav-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.nav-burger span{display:block;width:24px;height:2.4px;background:#fff;border-radius:2px;margin:5px 0;transition:.25s;}

/* mobile menu */
.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--navy);z-index:var(--z-menu);
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.1,1);padding:30px 28px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-lg);}
.mobile-menu.open{transform:translateX(0);}
.mobile-menu a{font-family:var(--f-display);font-weight:600;font-size:19px;color:#fff;padding:14px 0;border-bottom:1px solid rgba(255,255,255,0.12);}
.mobile-menu .btn{margin-top:18px;}
.mm-close{align-self:flex-end;background:none;border:none;color:#fff;font-size:30px;cursor:pointer;line-height:1;margin-bottom:8px;}
.scrim{position:fixed;inset:0;background:rgba(4,26,57,0.5);z-index:var(--z-scrim);opacity:0;pointer-events:none;transition:opacity .3s;}
.scrim.open{opacity:1;pointer-events:auto;}

/* hero wave decoration */
.hero-deco-waves{position:absolute;bottom:70px;left:0;width:520px;height:130px;pointer-events:none;}
.hero-deco-waves svg{width:100%;height:100%;}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100dvh;background:var(--navy);overflow:hidden;display:flex;flex-direction:column;}
.hero-bg{position:absolute;inset:0;background-image:url(assets/hero-kitchen.png);background-size:cover;background-position:right center;}
.hero-overlay{position:absolute;inset:0;
  background:linear-gradient(100deg,var(--navy-d) 0%,rgba(4,26,57,0.94) 32%,rgba(5,36,77,0.6) 55%,rgba(5,36,77,0.12) 78%),
             radial-gradient(120% 90% at 12% 0%, rgba(63,127,196,0.28), transparent 55%);}
.hero-grid{position:absolute;inset:0;background-image:radial-gradient(rgba(127,176,236,0.10) 1px,transparent 1px);background-size:34px 34px;
  -webkit-mask-image:linear-gradient(90deg,#000 0%,transparent 60%);mask-image:linear-gradient(90deg,#000 0%,transparent 60%);}
.hero-content{position:relative;flex:1;display:flex;align-items:center;}
.hero-content .container{width:100%;}
.hero-inner{max-width:680px;color:#fff;padding-top:120px;padding-bottom:60px;}
.hero .overline{color:var(--sky);display:inline-block;margin-bottom:22px;font-weight:600;letter-spacing:0.18em;}
.hero h1{font-size:clamp(42px,6.2vw,78px);color:#fff;line-height:0.98;letter-spacing:-0.035em;}
.hero-sub{font-size:clamp(17px,1.5vw,20px);color:rgba(255,255,255,0.85);margin-top:26px;max-width:58ch;line-height:1.55;}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;}
.hero-stats{position:relative;border-top:1px solid rgba(255,255,255,0.14);display:grid;grid-template-columns:repeat(4,1fr);
  background:linear-gradient(0deg, rgba(4,26,57,0.55), transparent);backdrop-filter:blur(2px);}
.hero-stat{padding:26px 28px;color:#fff;border-left:1px solid rgba(255,255,255,0.14);position:relative;}
.hero-stat::before{content:"";position:absolute;left:-1px;top:0;width:36px;height:2px;background:var(--sky);opacity:0;transition:opacity .3s;}
.hero-stat:hover::before{opacity:1;}
.hero-stat:first-child{border-left:none;}
.hero-stat .n{font-family:var(--f-display);font-weight:700;font-size:27px;letter-spacing:-0.025em;font-variant-numeric:tabular-nums;}
.hero-stat .l{font-size:13.5px;color:rgba(255,255,255,0.66);margin-top:6px;}
.hero-stats .container{display:contents;}

/* ---------- trust bar ---------- */
.trust{background:var(--bg-soft);border-bottom:1px solid var(--line);overflow:hidden;}
.trust-header{display:flex;align-items:center;justify-content:center;padding:9px 0 4px;}
.trust-label{font-family:var(--f-display);font-weight:600;font-size:13px;letter-spacing:0.12em;text-transform:uppercase;color:var(--slate);white-space:nowrap;}
/* ticker */
.trust-ticker{position:relative;overflow:hidden;padding:6px 0 10px;
  -webkit-mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);
  mask-image:linear-gradient(to right,transparent 0%,#000 8%,#000 92%,transparent 100%);}
.trust-track{display:flex;align-items:center;gap:30px;width:max-content;
  animation:trust-ticker 24s linear infinite;}
.trust-ticker:hover .trust-track{animation-play-state:paused;}
.trust-logo-wrap{display:flex;align-items:center;justify-content:center;width:98px;height:45px;flex-shrink:0;
  filter:saturate(0) opacity(0.65);transition:filter .3s;}
.trust-logo-wrap:hover{filter:saturate(1) opacity(1);}
.trust-logo-wrap img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;}
.trust-logo-lg{width:146px;height:68px;}
@keyframes trust-ticker{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:72px;align-items:center;}
.about-copy .overline{display:inline-block;margin-bottom:18px;}
.about-copy h2{margin-bottom:20px;}
.about-copy p + p{margin-top:18px;}
.about-entity{margin-top:30px;padding:22px 24px;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);}
.about-entity .k{font-size:13px;letter-spacing:0.06em;text-transform:uppercase;color:var(--slate-l);font-weight:600;}
.about-entity .v{font-family:var(--f-display);font-weight:700;color:var(--navy);font-size:18px;margin-top:4px;}
.about-entity .a{font-size:14.5px;color:var(--slate);margin-top:10px;}
.about-visual{position:relative;}
.about-visual .panel{position:relative;background:var(--navy);border-radius:22px;overflow:hidden;aspect-ratio:4/3.4;box-shadow:var(--shadow-lg);}
.about-visual .panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
.about-visual .panel .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,36,77,0) 40%,rgba(4,26,57,0.55));}
.about-visual .dots{position:absolute;top:-22px;right:-22px;width:120px;height:96px;color:var(--steel);opacity:0.5;
  background-image:radial-gradient(currentColor 2px,transparent 2px);background-size:18px 18px;z-index:-1;}
.about-visual .tag{position:absolute;left:24px;bottom:22px;color:#fff;}
.about-visual .tag .o{font-family:var(--f-display);font-weight:700;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--sky);}
.about-visual .tag .t{font-family:var(--f-display);font-weight:800;font-size:21px;margin-top:6px;}
.about-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:30px;}
.about-mini .m .n{font-family:var(--f-display);font-weight:700;font-size:30px;color:var(--navy);font-variant-numeric:tabular-nums;}
.about-mini .m .l{font-size:13.5px;color:var(--slate);margin-top:4px;}

/* ---------- shared card base ---------- */
.brand-card,.prod-card,.testi-card,.ind-card{
  background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-card);
  position:relative;transition:transform .22s cubic-bezier(.2,.7,.3,1), box-shadow .22s, border-color .22s;
}
.brand-card:hover,.prod-card:hover,.ind-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-d);}

/* ---------- brands section ---------- */
.brands-section{background:var(--bg-soft);padding-bottom:48px;}
.products{padding-top:48px;padding-bottom:48px;}
#industri{padding-top:48px;}
#testimoni{padding-top:48px;padding-bottom:48px;}
.delivery{padding-top:48px;}
.brands-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.brand-card{border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;}
/* accent top-line reveal on hover */
.brand-card::before,.prod-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--amber),var(--amber-d));transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.2,.7,.3,1);z-index:2;}
.brand-card:hover::before,.prod-card:hover::before{transform:scaleX(1);}
.brand-logo-area{height:180px;display:flex;align-items:center;justify-content:center;padding:20px 24px;background:radial-gradient(120% 120% at 50% 0%, #fff 0%, var(--bg-soft2) 100%);position:relative;overflow:hidden;}
.brand-logo-area img{max-height:145px;max-width:90%;width:auto;object-fit:contain;}
.brand-tag{position:absolute;top:14px;right:14px;font-family:var(--f-display);font-weight:600;font-size:11.5px;letter-spacing:0.04em;padding:5px 11px;border-radius:7px;white-space:nowrap;}
.brand-tag.halal{background:#dcfce7;color:#166534;}
.brand-tag.premium{background:#fef9c3;color:#854d0e;}
.brand-tag.antibocor{background:#dbeafe;color:#1e40af;}
.brand-body{padding:28px 26px 30px;flex:1;display:flex;flex-direction:column;}
.brand-body h3{font-size:24px;color:var(--navy);margin-bottom:10px;}
.brand-body .desc{font-size:14.5px;color:var(--slate);line-height:1.6;}
.brand-prodlist{margin-top:auto;padding-top:18px;display:flex;flex-wrap:wrap;gap:7px;}
.brand-prodlist span{font-family:var(--f-display);font-weight:500;font-size:12.5px;color:var(--navy-700);background:var(--bg-soft);padding:5px 11px;border-radius:7px;border:1px solid var(--line);}
.brands-cta{text-align:center;margin-top:52px;}

/* ---------- testimonials ---------- */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.testi-card{border-radius:var(--r-lg);padding:36px 32px;display:flex;flex-direction:column;gap:20px;}
/* feature the first quote in inverted navy for rhythm */
.testi-card:first-child{background:var(--navy);border-color:transparent;color:#fff;box-shadow:var(--shadow);}
.testi-card:first-child .testi-quote{color:rgba(255,255,255,0.92);}
.testi-card:first-child .testi-quote-mark{color:var(--sky);opacity:0.5;}
.testi-card:first-child .testi-author{border-top-color:rgba(255,255,255,0.16);}
.testi-card:first-child .testi-avatar{background:rgba(255,255,255,0.10);border-color:rgba(255,255,255,0.2);color:#fff;}
.testi-card:first-child .tname{color:#fff;}
.testi-card:first-child .trole{color:rgba(255,255,255,0.6);}
.testi-card:not(:first-child):hover{transform:translateY(-4px);box-shadow:var(--shadow);}
.testi-stars{display:flex;gap:3px;}
.testi-stars svg{width:17px;height:17px;fill:#f5a623;color:#f5a623;}
.testi-body{flex:1;}
.testi-quote-mark{font-family:var(--f-script);font-weight:700;font-size:64px;color:var(--amber);opacity:0.5;line-height:0.5;margin-bottom:4px;}
.testi-quote{font-size:15.5px;color:var(--ink);line-height:1.68;}
.testi-author{display:flex;align-items:center;gap:14px;padding-top:18px;border-top:1px solid var(--line);}
.testi-avatar{width:46px;height:46px;border-radius:14px;background:var(--bg-soft2);border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-family:var(--f-display);font-weight:700;font-size:16px;color:var(--navy);}
.testi-info .tname{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--navy);}
.testi-info .trole{font-size:13px;color:var(--slate);margin-top:2px;}

/* ---------- products ---------- */
.products{background:var(--bg-soft);}
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.prod-card{border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;}
.prod-media{position:relative;height:240px;background:radial-gradient(120% 100% at 50% 14%,#fcfdff 0%,#e9f0f9 100%);display:flex;align-items:center;justify-content:center;padding:28px;}
.prod-media img{max-height:100%;width:auto;object-fit:contain;filter:drop-shadow(0 18px 24px rgba(5,36,77,0.16));transition:transform .3s cubic-bezier(.2,.7,.3,1);}
.prod-card:hover .prod-media img{transform:scale(1.05) translateY(-4px);}
.prod-tag{position:absolute;top:16px;left:16px;font-family:var(--f-display);font-weight:600;font-size:11.5px;letter-spacing:0.06em;text-transform:uppercase;white-space:nowrap;
  background:rgba(5,36,77,0.92);color:#fff;padding:6px 12px;border-radius:8px;z-index:3;backdrop-filter:blur(4px);}
.prod-body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1;}
.prod-body h3{font-size:23px;color:var(--navy);}
.prod-body .desc{font-size:15px;color:var(--slate);margin-top:9px;line-height:1.55;}
.prod-sizes{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px;}
.prod-sizes span{font-family:var(--f-display);font-weight:500;font-size:12.5px;color:var(--navy-700);background:var(--bg-soft2);padding:5px 11px;border-radius:7px;white-space:nowrap;font-variant-numeric:tabular-nums;}
.prod-foot{margin-top:auto;padding-top:22px;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.prod-link{font-family:var(--f-display);font-weight:600;font-size:14.5px;color:var(--wa-d);display:inline-flex;align-items:center;gap:7px;transition:gap .15s, color .15s;}
.prod-link:hover{gap:11px;color:var(--wa);}
.prod-link svg{width:17px;height:17px;}
.prod-note{text-align:center;margin-top:44px;font-size:15px;color:var(--slate);}

/* ---------- video showcase ---------- */
.showcase{background:var(--navy);position:relative;overflow:hidden;}
.showcase::before{content:"";position:absolute;top:-60px;left:-40px;width:280px;height:200px;
  background-image:radial-gradient(rgba(127,176,236,0.16) 2px,transparent 2px);background-size:22px 22px;pointer-events:none;}
.showcase::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 85% 50%, rgba(63,127,196,0.18), transparent 60%);pointer-events:none;}
.showcase-grid{display:grid;grid-template-columns:1fr 340px;gap:88px;align-items:center;position:relative;}
.showcase-copy .overline{color:var(--sky);display:inline-block;margin-bottom:18px;}
.showcase-copy h2{color:#fff;margin-bottom:18px;}
.showcase-copy p{color:rgba(255,255,255,0.78);max-width:54ch;}
.showcase-copy ul{list-style:none;margin:28px 0 0;padding:0;display:flex;flex-direction:column;gap:14px;}
.showcase-copy ul li{display:flex;align-items:center;gap:12px;font-size:15.5px;color:rgba(255,255,255,0.85);}
.showcase-copy ul li svg{width:20px;height:20px;flex:0 0 auto;color:var(--wa);}
.showcase-cta{margin-top:36px;}
.reel-frame{position:relative;flex:0 0 auto;margin:0;}
.reel-glow{position:absolute;inset:-80px;background:radial-gradient(circle at 50% 50%,rgba(227,162,58,0.20),transparent 65%);pointer-events:none;z-index:0;}
/* polaroid-style photo mount — matte border, script caption, gentle tilt that straightens on hover */
.reel-wrap{position:relative;z-index:1;margin:0;background:#fdfaf4;
  padding:15px 15px 50px;border-radius:3px;
  box-shadow:0 1px 0 rgba(255,255,255,.7) inset,
             0 2px 5px rgba(5,36,77,.14),
             0 34px 64px -26px rgba(0,0,0,.6);
  transform:rotate(-2deg);
  transition:transform .45s cubic-bezier(.2,.7,.3,1), box-shadow .45s;}
.reel-wrap:hover{transform:rotate(0) translateY(-5px);
  box-shadow:0 2px 5px rgba(5,36,77,.14),0 46px 84px -28px rgba(0,0,0,.7);}
.reel-wrap video{display:block;width:100%;aspect-ratio:9/16;object-fit:cover;border-radius:2px;background:#0b1f3a;}
.photo-cap{position:absolute;left:14px;right:14px;bottom:14px;text-align:center;
  font-family:var(--f-script);font-weight:700;font-size:23px;line-height:1;color:var(--navy);opacity:.92;}

/* ---------- why / value props (navy band) ---------- */
.why{background:var(--navy);position:relative;overflow:hidden;}
.why::before{content:"";position:absolute;top:-80px;right:-60px;width:300px;height:220px;
  background-image:radial-gradient(rgba(127,176,236,0.22) 2px,transparent 2px);background-size:22px 22px;}
.why .sec-head .overline{color:var(--sky);}
.why-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;}
.why-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.10);border-radius:16px;padding:28px 22px;transition:background .2s, transform .2s;}
.why-card:hover{background:rgba(255,255,255,0.08);transform:translateY(-4px);}
.why-ico{width:52px;height:52px;border-radius:13px;background:rgba(127,176,236,0.16);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.why-ico svg{width:26px;height:26px;color:var(--sky);}
.why-card h3{color:#fff;font-size:18px;margin-bottom:9px;letter-spacing:-0.01em;}
.why-card p{font-size:14px;color:rgba(255,255,255,0.66);line-height:1.5;}

/* ---------- industries ---------- */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.ind-card{border-radius:var(--radius);padding:30px 26px;}
.ind-card:hover{border-color:var(--amber);}
.ind-ico{width:54px;height:54px;border-radius:15px;background:linear-gradient(160deg,var(--bg-soft),var(--bg-soft2));display:flex;align-items:center;justify-content:center;margin-bottom:20px;color:var(--navy);transition:background .25s, color .25s;}
.ind-card:hover .ind-ico{background:var(--navy);color:#fff;}
.ind-ico svg{width:27px;height:27px;}
.ind-card h3{font-size:20px;color:var(--navy);margin-bottom:10px;}
.ind-card p{font-size:14.5px;color:var(--slate);line-height:1.55;}
.ind-card .tags{margin-top:14px;font-size:13px;color:var(--slate-l);font-weight:500;}

/* ---------- delivery ---------- */
.delivery{background:var(--bg-soft);position:relative;overflow:hidden;padding-bottom:100px;}
.del-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;}
.del-feats{display:flex;flex-direction:column;gap:20px;margin-top:34px;}
.del-feat{display:flex;gap:18px;align-items:flex-start;}
.del-feat .fi{width:50px;height:50px;flex:0 0 auto;border-radius:14px;background:var(--navy);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-card);}
.del-feat .fi svg{width:25px;height:25px;color:var(--sky);}
.del-feat h3{font-size:18px;color:var(--navy);margin-bottom:4px;}
.del-feat p{font-size:15px;color:var(--slate);}
.del-card{background:var(--navy);border-radius:var(--r-lg);padding:44px 40px;color:#fff;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;}
.del-card::after{content:"";position:absolute;right:-50px;bottom:-50px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(127,176,236,0.2),transparent 70%);}
.del-card .overline{color:var(--sky);}
.del-card h3{font-size:27px;color:#fff;margin:14px 0 8px;}
.del-card p{color:rgba(255,255,255,0.78);font-size:15.5px;max-width:46ch;}
.area-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px;}
.area-chips span{font-family:var(--f-display);font-weight:500;font-size:14px;padding:9px 16px;border-radius:999px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.16);color:#fff;}
.del-card .free{margin-top:28px;display:inline-flex;align-items:center;gap:10px;background:var(--wa);color:#fff;font-family:var(--f-display);font-weight:700;font-size:15px;padding:12px 20px;border-radius:12px;box-shadow:0 10px 26px -8px rgba(34,197,94,0.5);}
.del-card .free svg{width:19px;height:19px;}

/* ---------- FAQ ---------- */
.faq-wrap{max-width:840px;margin:0 auto;}
.faq-item{border-bottom:1px solid var(--line);transition:padding .25s;}
.faq-item.open{background:linear-gradient(180deg, var(--bg-soft), transparent);border-radius:14px 14px 0 0;}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:26px 8px;font-family:var(--f-display);font-weight:600;font-size:19px;color:var(--navy);transition:color .2s;}
.faq-q:hover{color:var(--steel);}
.faq-q .pm{flex:0 0 auto;width:32px;height:32px;border-radius:9px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;transition:background .2s,transform .25s;}
.faq-q .pm svg{width:17px;height:17px;color:var(--navy);transition:transform .25s, color .2s;}
.faq-item.open .faq-q .pm{background:var(--navy);}
.faq-item.open .faq-q .pm svg{color:#fff;transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease;}
.faq-a p{padding:0 8px 26px;color:var(--slate);font-size:16px;line-height:1.62;max-width:680px;}

/* ---------- contact ---------- */
.contact{background:var(--navy);position:relative;overflow:hidden;}
.contact::before{content:"";position:absolute;left:-60px;bottom:-60px;width:280px;height:200px;
  background-image:radial-gradient(rgba(127,176,236,0.16) 2px,transparent 2px);background-size:22px 22px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:stretch;position:relative;}
.contact-copy .overline{color:var(--sky);display:inline-block;margin-bottom:18px;}
.contact-copy h2{color:#fff;margin-bottom:18px;}
.contact-copy .lead{color:rgba(255,255,255,0.82);}
.contact-actions{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 36px;}
.contact-list{display:flex;flex-direction:column;gap:20px;}
.contact-row{display:flex;gap:16px;align-items:flex-start;}
.contact-row .ci{width:46px;height:46px;flex:0 0 auto;border-radius:13px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.10);display:flex;align-items:center;justify-content:center;}
.contact-row .ci svg{width:22px;height:22px;color:var(--sky);}
.contact-row .ck{font-family:var(--f-display);font-weight:600;font-size:13px;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.55);}
.contact-row .cv{color:#fff;font-size:16px;margin-top:3px;line-height:1.45;font-variant-numeric:tabular-nums;}
.contact-map{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);min-height:380px;border:1px solid rgba(255,255,255,0.12);}
.contact-map iframe{width:100%;height:100%;min-height:380px;border:0;display:block;filter:grayscale(0.2) contrast(1.02);}

/* ---------- footer ---------- */
.footer{background:var(--navy);color:#fff;padding:0;}
.foot-compact{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:44px 0;flex-wrap:wrap;}
.foot-logo-txt{display:flex;flex-direction:column;line-height:1;gap:2px;}
.flt-main{font-family:var(--f-display);font-weight:800;font-size:26px;letter-spacing:0.02em;text-transform:uppercase;color:#fff;font-style:italic;padding-bottom:3px;border-bottom:2px solid rgba(255,255,255,0.85);}
.flt-sub{font-family:var(--f-display);font-weight:600;font-size:8.5px;letter-spacing:0.32em;text-transform:uppercase;color:rgba(255,255,255,0.6);margin-top:3px;}
.foot-brand-legal{font-size:13px;color:rgba(255,255,255,0.50);margin-top:7px;letter-spacing:0.01em;}
.foot-nav{display:flex;align-items:center;gap:26px;flex-wrap:wrap;}
.foot-nav a{font-family:var(--f-display);font-weight:500;font-size:14px;color:rgba(255,255,255,0.70);transition:color .15s;}
.foot-nav a:hover{color:#fff;}
.foot-wa-btn{width:46px;height:46px;border-radius:14px;background:var(--wa);display:flex;align-items:center;justify-content:center;color:#fff;flex:0 0 auto;transition:transform .15s,box-shadow .15s;}
.foot-wa-btn:hover{transform:scale(1.08);box-shadow:0 8px 22px -6px rgba(34,197,94,0.6);}
.foot-wa-btn svg{width:22px;height:22px;}
.foot-bar{background:var(--navy-d);border-top:1px solid rgba(255,255,255,0.08);}
.foot-bar .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding-top:18px;padding-bottom:18px;flex-wrap:wrap;}
.foot-bar p{font-size:13px;color:rgba(255,255,255,0.45);margin:0;}
.foot-bar .links{display:flex;gap:20px;}
.foot-bar .links a{font-size:13px;color:rgba(255,255,255,0.52);transition:color .15s;}
.foot-bar .links a:hover{color:#fff;}

/* ---------- floating WA ---------- */
.fab{position:fixed;right:24px;bottom:24px;z-index:var(--z-fab);display:flex;align-items:center;gap:11px;
  background:var(--wa);color:#fff;font-family:var(--f-display);font-weight:600;font-size:15px;
  padding:14px 20px 14px 16px;border-radius:999px;box-shadow:0 14px 34px -8px rgba(34,197,94,0.6);
  transition:transform .15s, box-shadow .15s;}
.fab:hover{transform:translateY(-2px) scale(1.02);}
.fab:active{transform:translateY(0) scale(.98);}
.fab svg{width:24px;height:24px;}
.fab .pulse{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;
  background:var(--wa);animation:fabpulse 2.2s ease-out infinite;z-index:-1;}
@keyframes fabpulse{0%{opacity:.6;transform:translateY(-50%) scale(1);}70%,100%{opacity:0;transform:translateY(-50%) scale(2.4);}}

/* ---------- scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s cubic-bezier(.2,.7,.3,1), transform .7s cubic-bezier(.2,.7,.3,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.08s;} .reveal.d2{transition-delay:.16s;} .reveal.d3{transition-delay:.24s;} .reveal.d4{transition-delay:.32s;}

/* ---------- responsive ---------- */
@media (max-width:1024px){
  .nav-links{display:none;}
  .nav-burger{display:block;}
  .nav-cta .btn:not(.nav-burger){display:none;}
  .why-grid{grid-template-columns:repeat(3,1fr);}
  .ind-grid{grid-template-columns:repeat(2,1fr);}
  .prod-grid{grid-template-columns:repeat(2,1fr);}
  .about-grid,.del-grid,.contact-grid{grid-template-columns:1fr;gap:44px;}
  .about-visual{max-width:520px;}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px;}
  .brands-grid{grid-template-columns:1fr;}
  .testi-grid{grid-template-columns:1fr;}
  .showcase-grid{grid-template-columns:1fr;gap:48px;}
  .reel-frame{max-width:300px;margin:0 auto;width:100%;}
}
@media (max-width:680px){
  .section{padding:72px 0 80px;}
  .container{padding:0 20px;}
  .sec-head{margin-bottom:44px;}
  .hero-inner{padding-top:104px;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-stat:nth-child(3){border-left:none;}
  .hero-stat{border-top:1px solid rgba(255,255,255,0.14);}
  .hero-stat:first-child,.hero-stat:nth-child(2){border-top:none;}
  .why-grid{grid-template-columns:1fr 1fr;}
  .prod-grid{grid-template-columns:1fr;}
  .ind-grid{grid-template-columns:1fr;}
  .about-mini{gap:12px;}
  .trust-header{justify-content:flex-start;}
  .foot-top{grid-template-columns:1fr;}
  .foot-bottom{flex-direction:column;align-items:flex-start;}
  .fab span.txt{display:none;}
  .fab{padding:15px;}
}

/* respect reduced-motion preference */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important;}
  .reveal{opacity:1;transform:none;}
}
