/* ============================================================
   KORA BRANDING — modern design system
   ============================================================ */
:root{
  --black:#0c0d10;
  --ink:#15171c;
  --charcoal:#1c1f26;
  --yellow:#ffd21f;
  --yellow-deep:#e6b400;
  --yellow-soft:#fff4cc;
  --gray-700:#3a3f4a;
  --gray-600:#565d6b;
  --gray-500:#717886;
  --gray-400:#9aa0ad;
  --gray-300:#d6dae1;
  --gray-200:#e7eaef;
  --gray-100:#f1f3f6;
  --gray-50:#f8f9fb;
  --white:#ffffff;
  --surface:#ffffff;
  --border:#e6e9ef;
  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;
  --shadow-sm:0 2px 8px rgba(15,18,25,.06);
  --shadow:0 14px 40px rgba(15,18,25,.10);
  --shadow-lg:0 30px 70px rgba(15,18,25,.18);
  --maxw:1220px;
  --body:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --display:"Plus Jakarta Sans","Inter",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.section{padding:92px 0}
.section--tight{padding:60px 0}
.bg-gray{background:var(--gray-50)}
.bg-black{background:var(--black);color:var(--white)}
.bg-mesh{background:
  radial-gradient(1100px 480px at 88% -10%, rgba(255,210,31,.16), transparent 60%),
  radial-gradient(760px 420px at -5% 110%, rgba(255,210,31,.08), transparent 55%),
  var(--black);}
.center{text-align:center}

h1,h2,h3,h4{font-family:var(--display);line-height:1.1;font-weight:800;letter-spacing:-.02em;color:var(--ink)}
h1{font-size:clamp(2.3rem,5.2vw,4rem)}
h2{font-size:clamp(1.8rem,3.6vw,2.8rem)}
h3{font-size:1.2rem;letter-spacing:-.01em}
p{color:var(--gray-600)}
.lead{font-size:1.18rem;color:var(--gray-500);max-width:660px;line-height:1.6}
.bg-black p,.bg-mesh p,.bg-black .lead{color:#c4c9d4}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:.74rem;font-weight:800;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);background:var(--yellow);padding:7px 15px;border-radius:50px;margin-bottom:20px}
.bg-black .eyebrow,.bg-mesh .eyebrow{color:var(--ink)}
.section-head{max-width:740px;margin:0 0 52px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);font-weight:700;font-size:1rem;
  padding:14px 26px;border-radius:50px;cursor:pointer;border:2px solid transparent;transition:transform .18s,box-shadow .18s,background .18s,color .18s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn--primary{background:var(--yellow);color:var(--ink);box-shadow:0 8px 22px rgba(255,210,31,.35)}
.btn--primary:hover{background:#ffdb47;transform:translateY(-2px);box-shadow:0 12px 28px rgba(255,210,31,.45)}
.btn--dark{background:var(--ink);color:#fff}
.btn--dark:hover{background:#000;transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--gray-300)}
.btn--ghost:hover{border-color:var(--ink);transform:translateY(-2px)}
.btn--ghost-light{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.28)}
.btn--ghost-light:hover{background:#fff;color:var(--ink);border-color:#fff;transform:translateY(-2px)}
.btn--wa{background:#25D366;color:#fff}
.btn--wa:hover{background:#1da851;transform:translateY(-2px)}
.btn--lg{padding:16px 32px;font-size:1.06rem}
.btn--sm{padding:10px 18px;font-size:.9rem}

/* ---------- Top bar ---------- */
.topbar{background:var(--black);color:#cfd3db;font-size:.84rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:16px;height:42px}
.topbar a:hover{color:var(--yellow)}
.topbar .tb-right{display:flex;gap:20px;align-items:center}
.topbar .tb-promo{color:var(--yellow);font-weight:600}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px;gap:24px}
.brand{display:flex;align-items:center;flex:0 0 auto}
.brand-logo{height:46px;width:auto;max-width:none;flex:none;display:block}
.footer .brand-logo{height:52px}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links>li>a{display:inline-flex;align-items:center;gap:5px;padding:10px 11px;border-radius:10px;font-weight:600;font-size:.93rem;color:var(--gray-700);transition:.15s;white-space:nowrap}
.nav-links>li>a:hover,.nav-links>li>a.active{background:var(--gray-100);color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:10px}
.has-dropdown{position:relative}
.dropdown{position:absolute;top:calc(100% + 10px);left:0;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);min-width:280px;padding:10px;opacity:0;visibility:hidden;transform:translateY(10px);transition:.18s;list-style:none}
.has-dropdown:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown li a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:.92rem;font-weight:500;color:var(--gray-700)}
.dropdown li a:hover{background:var(--yellow-soft);color:var(--ink)}
.dropdown li a::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--yellow-deep);flex:0 0 auto}
.dropdown{max-height:min(74vh,560px);overflow-y:auto}
.dropdown .dh{font-size:.68rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-400);padding:11px 12px 5px;pointer-events:none}
.dropdown .dh:first-child{padding-top:4px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:26px;height:3px;background:var(--ink);border-radius:3px;transition:.2s}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden}
.hero .container{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;padding:84px 24px 88px}
.hero h1 .hl{color:transparent;-webkit-text-stroke:0;background:linear-gradient(100deg,var(--yellow),#ffb800);-webkit-background-clip:text;background-clip:text}
.hero p{font-size:1.22rem;margin:22px 0 30px;max-width:560px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-trust{margin-top:26px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-size:.92rem;color:var(--gray-500)}
.hero-trust .stars{color:var(--yellow-deep);letter-spacing:2px}
.hero-visual{position:relative}
.hero-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/4.4}
.hero-media img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);padding:14px 18px;display:flex;align-items:center;gap:12px}
.hero-badge .ic{width:42px;height:42px;border-radius:11px;background:var(--yellow);display:grid;place-items:center;flex:0 0 auto}
.hero-badge .ic svg{width:22px;height:22px;stroke:var(--ink)}
.hero-badge b{font-family:var(--display);font-size:1.05rem;display:block;line-height:1.1}
.hero-badge span{font-size:.78rem;color:var(--gray-500)}
.hero-badge.b1{left:-26px;top:36px}
.hero-badge.b2{right:-22px;bottom:40px}

/* ---------- Trust strip ---------- */
.trust{background:var(--yellow)}
.trust .container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;padding:20px 24px}
.trust div{display:flex;align-items:center;gap:10px;font-weight:700;font-family:var(--display);color:var(--ink);font-size:.97rem}
.trust svg{width:22px;height:22px;flex:0 0 auto;stroke:var(--ink)}

/* ---------- Category / media cards ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.cat-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.cat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}
.cat-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:transparent}
.cat-card .media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--gray-100)}
.cat-card .media img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.cat-card:hover .media img{transform:scale(1.06)}
.cat-card .media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(12,13,16,.55));opacity:.9}
.cat-card .tag{position:absolute;top:14px;left:14px;z-index:2;background:rgba(255,255,255,.92);color:var(--ink);font-size:.72rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:50px}
.cat-card .body{padding:22px 24px 26px;display:flex;flex-direction:column;flex:1}
.cat-card h3{margin-bottom:7px}
.cat-card p{font-size:.95rem;flex:1}
.cat-card .more{margin-top:16px;font-family:var(--display);font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:gap .2s}
.cat-card:hover .more{gap:12px;color:var(--yellow-deep)}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:26px;text-align:center}
.stats .num{font-family:var(--display);font-size:clamp(2.1rem,4.4vw,3.2rem);font-weight:800;color:var(--yellow);line-height:1}
.stats .lbl{color:#c4c9d4;font-weight:500;margin-top:8px}

/* ---------- Why-us feature cards ---------- */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;transition:.2s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.feature .ic{width:54px;height:54px;border-radius:14px;background:var(--yellow);display:grid;place-items:center;margin-bottom:18px}
.feature .ic svg{width:28px;height:28px;stroke:var(--ink)}
.feature h3{margin-bottom:8px}
.feature p{font-size:.95rem}
a.feature{text-decoration:none;color:inherit;cursor:pointer;display:flex;flex-direction:column}
a.feature p{flex:1}
.feature .more{margin-top:14px;font-family:var(--display);font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:7px;transition:gap .2s}
a.feature:hover .more{gap:12px;color:var(--yellow-deep)}
/* event service detail */
.evs-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.evs-includes{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:12px 24px;margin-top:8px}
.evs-includes li{display:flex;gap:10px;align-items:flex-start;font-size:.96rem;color:var(--gray-700)}
.evs-includes li svg{width:20px;height:20px;stroke:var(--yellow-deep);fill:none;stroke-width:2.4;flex:0 0 auto;margin-top:2px}
.evs-related{display:flex;flex-wrap:wrap;gap:10px}
.evs-related a{font-size:.88rem;font-weight:600;padding:8px 15px;border-radius:50px;background:var(--gray-100);color:var(--gray-700);transition:.15s}
.evs-related a:hover{background:var(--yellow);color:var(--ink)}
@media(max-width:880px){.evs-hero{grid-template-columns:1fr;gap:30px}.evs-includes{grid-template-columns:1fr}}

/* ---------- Steps ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px 26px 26px}
.step .n{position:absolute;top:-18px;left:26px;width:42px;height:42px;border-radius:12px;background:var(--ink);color:var(--yellow);font-family:var(--display);font-weight:800;font-size:1.1rem;display:grid;place-items:center}
.step h3{margin:16px 0 7px;font-size:1.1rem}
.step p{font-size:.93rem}

/* ---------- Work gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery .shot{position:relative;border-radius:var(--radius-sm);overflow:hidden;aspect-ratio:1/1;background:var(--gray-100)}
.gallery .shot.wide{grid-column:span 2;aspect-ratio:2/1}
.gallery .shot img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery .shot:hover img{transform:scale(1.07)}

/* ---------- Logos ---------- */
.logos{display:flex;flex-wrap:wrap;gap:16px 42px;justify-content:center;align-items:center}
.logos span{font-family:var(--display);font-weight:800;color:var(--gray-400);font-size:1.05rem}

/* ---------- Testimonials ---------- */
.tgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.tcard{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow-sm)}
.tcard .stars{color:var(--yellow-deep);font-size:1.05rem;letter-spacing:2px;margin-bottom:14px}
.tcard p{color:var(--gray-700);font-style:italic}
.tcard .who{margin-top:18px;display:flex;align-items:center;gap:12px}
.tcard .who .av{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--yellow);font-family:var(--display);font-weight:800;display:grid;place-items:center;flex:0 0 auto}
.tcard .who b{font-family:var(--display);font-size:.96rem;display:block}
.tcard .who span{font-size:.83rem;color:var(--gray-500)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:var(--ink);color:#fff;border-radius:var(--radius-lg);padding:54px;display:flex;justify-content:space-between;align-items:center;gap:28px;flex-wrap:wrap}
.cta-band::before{content:"";position:absolute;right:-80px;top:-80px;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,210,31,.30),transparent 65%)}
.cta-band>div{position:relative;z-index:1}
.cta-band h2{color:#fff;max-width:620px}
.cta-band p{color:#c4c9d4;margin-top:10px;max-width:560px}
.cta-band.yellow{background:var(--yellow)}
.cta-band.yellow h2{color:var(--ink)}
.cta-band.yellow p{color:#5a4d12}
.cta-band.yellow::before{background:radial-gradient(circle,rgba(255,255,255,.5),transparent 65%)}

/* ---------- Footer ---------- */
.footer{background:var(--black);color:#aeb4c0;padding:72px 0 28px}
.footer a:hover{color:var(--yellow)}
.fgrid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.25fr;gap:42px}
.footer h4{font-family:var(--display);color:#fff;font-size:1.02rem;margin-bottom:16px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:.92rem}
.footer .fdesc{margin:18px 0;font-size:.93rem;max-width:300px;line-height:1.6}
.fcontact li{display:flex;gap:10px;align-items:flex-start;font-size:.92rem}
.fsocial{display:flex;gap:10px;margin-top:8px}
.fsocial a{width:38px;height:38px;border-radius:10px;background:#1a1d24;display:grid;place-items:center;transition:.2s}
.fsocial a:hover{background:var(--yellow)}
.fsocial svg{width:18px;height:18px;fill:#cfd3db}
.fsocial a:hover svg{fill:var(--ink)}
.fbar{border-top:1px solid #20242c;margin-top:52px;padding-top:24px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.85rem;color:#7c828f}

/* ---------- Inner page hero ---------- */
.page-hero{position:relative;overflow:hidden;padding:72px 0;background:
  radial-gradient(1100px 480px at 88% -10%, rgba(255,210,31,.16), transparent 60%),
  radial-gradient(760px 420px at -5% 110%, rgba(255,210,31,.08), transparent 55%),
  var(--black)}
.page-hero .crumb{font-size:.85rem;color:#aeb4c0;margin-bottom:12px}
.page-hero .crumb a:hover{color:var(--yellow)}
.page-hero h1{color:#fff}
.page-hero p{color:#c4c9d4;margin-top:14px;max-width:660px;font-size:1.12rem}

/* ---------- Products page ---------- */
.prodnav{position:sticky;top:80px;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);padding:12px 0}
.prodnav .container{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}
.prodnav .container::-webkit-scrollbar{display:none}
.prodnav a{white-space:nowrap;font-size:.88rem;font-weight:600;padding:9px 15px;border-radius:50px;background:var(--gray-100);color:var(--gray-700);transition:.15s}
.prodnav a:hover{background:var(--yellow);color:var(--ink)}
.prod-cat{margin-bottom:64px;scroll-margin-top:150px}
.prod-cat-head{display:flex;align-items:center;gap:16px;margin-bottom:26px;padding-bottom:16px;border-bottom:3px solid var(--yellow)}
.prod-cat-head .ic{width:50px;height:50px;border-radius:13px;background:var(--ink);display:grid;place-items:center;flex:0 0 auto}
.prod-cat-head .ic svg{width:26px;height:26px;stroke:var(--yellow)}
.prod-items{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pitem{border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;transition:.18s;display:flex;flex-direction:column;background:#fff}
.pitem:hover{border-color:var(--yellow);box-shadow:var(--shadow);transform:translateY(-4px)}
.pitem .media{aspect-ratio:3/2;background:var(--gray-100);overflow:hidden}
.pitem .media img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pitem:hover .media img{transform:scale(1.06)}
.pitem .body{padding:15px 16px 17px;display:flex;flex-direction:column;gap:5px;flex:1}
.pitem h4{font-family:var(--display);font-size:1rem;font-weight:700}
.pitem p{font-size:.84rem;flex:1}
.pitem a{margin-top:8px;font-size:.85rem;font-weight:700;color:var(--ink);display:inline-flex;align-items:center;gap:5px;font-family:var(--display)}
.pitem a:hover{color:var(--yellow-deep)}

/* ---------- About ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.media-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3}
.media-frame img{width:100%;height:100%;object-fit:cover}

/* ---------- FAQ ---------- */
.faq{max-width:860px;margin:0 auto}
.faq-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px;overflow:hidden;background:#fff}
.faq-q{width:100%;text-align:left;background:#fff;border:0;padding:21px 24px;font-family:var(--display);font-size:1.05rem;font-weight:700;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq-q:hover{background:var(--gray-50)}
.faq-q .plus{flex:0 0 auto;width:28px;height:28px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;font-weight:800;transition:.2s}
.faq-item.open .plus{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .28s ease;background:var(--gray-50)}
.faq-a p{padding:0 24px 22px}
.faq-item.open .faq-a{max-height:420px}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.form-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow)}
.field{margin-bottom:18px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1px solid var(--gray-300);border-radius:11px;font-family:inherit;font-size:.96rem;transition:.15s;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--yellow-deep);box-shadow:0 0 0 3px rgba(255,210,31,.28)}
.field textarea{resize:vertical;min-height:120px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.info-block{margin-bottom:24px}
.info-block h3{font-size:1.05rem;margin-bottom:6px;display:flex;align-items:center;gap:10px}
.info-block .ic{width:42px;height:42px;border-radius:11px;background:var(--yellow);display:grid;place-items:center;flex:0 0 auto}
.info-block .ic svg{width:22px;height:22px;stroke:var(--ink)}
.info-block p{color:var(--gray-700);font-size:.96rem;margin-left:52px}
.info-block p a:hover{color:var(--yellow-deep)}
.map-embed{border:0;width:100%;height:280px;border-radius:var(--radius);margin-top:8px}
.form-success{display:none;background:#e9f9ef;border:1px solid #25D366;color:#13703c;padding:14px 18px;border-radius:11px;margin-bottom:18px;font-weight:600}

/* ---------- Product detail / configurator ---------- */
.product-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.gallery-main{border-radius:var(--radius);overflow:hidden;aspect-ratio:4/3;background:var(--gray-100);box-shadow:var(--shadow)}
.gallery-main img{width:100%;height:100%;object-fit:cover}
.gallery-thumbs{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap}
.gallery-thumbs img{width:88px;height:66px;object-fit:cover;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:.15s}
.gallery-thumbs img:hover{border-color:var(--gray-300)}
.gallery-thumbs img.active{border-color:var(--yellow-deep)}
.product-tag{display:inline-block;background:var(--yellow-soft);color:#7a6200;font-weight:700;font-size:.74rem;letter-spacing:.06em;text-transform:uppercase;padding:5px 12px;border-radius:50px;margin-bottom:12px}
/* "From" prices */
.price-from{margin-top:8px;font-family:var(--display);font-weight:800;font-size:.9rem;color:var(--ink)}
.price-from::before{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--yellow-deep);margin-right:7px;vertical-align:middle}
.price-block{margin:14px 0 4px;padding:14px 16px;background:var(--yellow-soft);border:1px solid #f0dca0;border-radius:12px}
.price-block .pf{display:block;font-family:var(--display);font-weight:800;font-size:1.35rem;color:var(--ink);line-height:1.1}
.price-block small{display:block;margin-top:5px;font-size:.82rem;color:#7a6200}
.product-info h1{font-size:clamp(1.8rem,3.4vw,2.4rem);margin-bottom:8px}
.product-info .short{font-size:1.1rem;color:var(--gray-600);margin-bottom:18px}
.specs-table{width:100%;border-collapse:collapse;margin-top:8px}
.specs-table td{padding:10px 0;border-bottom:1px solid var(--border);font-size:.93rem;vertical-align:top;color:var(--gray-700)}
.specs-table td:first-child{font-weight:600;width:36%;color:var(--ink)}
.config{position:sticky;top:100px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.config h3{font-size:1.15rem;margin-bottom:4px}
.config .step-note{font-size:.85rem;color:var(--gray-500);margin-bottom:18px}
.opt-group{margin-bottom:18px}
.opt-group .lbl{font-family:var(--display);font-weight:700;font-size:.9rem;margin-bottom:9px;display:flex;align-items:center;gap:8px}
.opt-group .lbl .n{width:20px;height:20px;border-radius:50%;background:var(--ink);color:var(--yellow);font-size:.7rem;display:grid;place-items:center;flex:0 0 auto}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{border:1.5px solid var(--gray-300);background:#fff;border-radius:50px;padding:8px 14px;font-size:.86rem;cursor:pointer;transition:.15s;font-weight:600;color:var(--gray-700)}
.chip:hover{border-color:var(--ink)}
.chip.active{background:var(--yellow);border-color:var(--yellow);color:var(--ink)}
.summary{background:var(--gray-50);border:1px dashed var(--gray-300);border-radius:12px;padding:16px 18px;margin:8px 0 18px}
.summary h4{font-family:var(--display);font-size:.95rem;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.summary ul{list-style:none;font-size:.9rem;color:var(--gray-700);display:flex;flex-direction:column;gap:6px}
.summary li{display:flex;justify-content:space-between;gap:14px}
.summary li b{color:var(--ink);font-weight:700;text-align:right}
.config .field{margin-bottom:14px}
.breadcrumb-bar{background:#fff;border-bottom:1px solid var(--border);padding:14px 0}
.breadcrumb-bar .container{font-size:.88rem;color:var(--gray-500)}
.breadcrumb-bar a:hover{color:var(--yellow-deep)}

/* ---------- Basket: header icon + badge ---------- */
.basket-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:12px;border:1.5px solid var(--gray-300);background:#fff;cursor:pointer;transition:.15s}
.basket-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.basket-btn svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:2}
.basket-badge{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:50px;background:var(--ink);color:var(--yellow);font-family:var(--display);font-size:.72rem;font-weight:800;display:none;align-items:center;justify-content:center}
.basket-badge.show{display:flex}

/* ---------- Basket drawer ---------- */
.drawer-overlay{position:fixed;inset:0;background:rgba(12,13,16,.5);opacity:0;visibility:hidden;transition:.25s;z-index:200}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:420px;max-width:92vw;background:#fff;box-shadow:var(--shadow-lg);transform:translateX(100%);transition:transform .28s ease;z-index:201;display:flex;flex-direction:column}
.drawer.open{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--border)}
.drawer-head h3{font-size:1.2rem}
.drawer-close{background:none;border:0;cursor:pointer;font-size:1.6rem;line-height:1;color:var(--gray-500);padding:4px 8px;border-radius:8px}
.drawer-close:hover{background:var(--gray-100);color:var(--ink)}
.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}
.drawer-foot{border-top:1px solid var(--border);padding:18px 22px;display:flex;flex-direction:column;gap:10px}
.basket-empty{text-align:center;color:var(--gray-500);padding:50px 10px}
.basket-empty svg{width:54px;height:54px;stroke:var(--gray-300);fill:none;stroke-width:1.6;margin-bottom:14px}

/* basket line item */
.bitem{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.bitem:last-child{border-bottom:0}
.bitem .thumb{width:64px;height:64px;border-radius:10px;object-fit:cover;flex:0 0 auto;background:var(--gray-100)}
.bitem .info{flex:1;min-width:0}
.bitem .info h4{font-family:var(--display);font-size:1rem;margin-bottom:4px}
.bitem .specs{font-size:.82rem;color:var(--gray-500);line-height:1.5}
.bitem .row{display:flex;align-items:center;justify-content:space-between;margin-top:10px;gap:10px}
.qty-ctrl{display:inline-flex;align-items:center;border:1px solid var(--gray-300);border-radius:50px;overflow:hidden}
.qty-ctrl button{width:30px;height:30px;border:0;background:#fff;cursor:pointer;font-size:1.1rem;line-height:1;color:var(--ink)}
.qty-ctrl button:hover{background:var(--gray-100)}
.qty-ctrl span{min-width:30px;text-align:center;font-weight:700;font-size:.9rem}
.bprice{margin-top:6px;font-family:var(--display);font-weight:700;font-size:.85rem;color:var(--ink)}
.basket-subtotal{display:flex;align-items:baseline;justify-content:space-between;gap:12px}
.basket-subtotal span{font-size:.9rem;color:var(--gray-500)}
.basket-subtotal b{font-family:var(--display);font-size:1.25rem;color:var(--ink)}
.basket-note{font-size:.78rem;color:var(--gray-500);margin:2px 0 6px;line-height:1.4}
.bitem .remove{background:none;border:0;color:var(--gray-400);cursor:pointer;font-size:.82rem;font-weight:600;text-decoration:underline}
.bitem .remove:hover{color:#d23b3b}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:300;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{background:var(--ink);color:#fff;padding:13px 20px;border-radius:50px;font-weight:600;font-size:.92rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(14px);transition:.25s}
.toast.show{opacity:1;transform:none}
.toast .tick{width:22px;height:22px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;font-weight:800;flex:0 0 auto}

/* ---------- Product action buttons ---------- */
.config-actions{display:flex;gap:12px;margin-top:6px}
.config-actions .btn{flex:1;justify-content:center}
@media(max-width:420px){.config-actions{flex-direction:column}}

/* ---------- Quote page ---------- */
.quote-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.quote-summary{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius);padding:24px}
.quote-summary h3{font-size:1.15rem;margin-bottom:14px}
.qline{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--border)}
.qline:last-of-type{border-bottom:0}
.qline .thumb{width:56px;height:56px;border-radius:9px;object-fit:cover;flex:0 0 auto;background:var(--gray-100)}
.qline .info h4{font-family:var(--display);font-size:.98rem}
.qline .specs{font-size:.8rem;color:var(--gray-500);line-height:1.45}
.qline .remove{background:none;border:0;color:var(--gray-400);cursor:pointer;font-size:.8rem;text-decoration:underline}
.qline .remove:hover{color:#d23b3b}
.phone-row{display:grid;grid-template-columns:108px 1fr;gap:10px}
.file-drop{border:1.6px dashed var(--gray-300);border-radius:12px;padding:22px;text-align:center;cursor:pointer;transition:.15s;color:var(--gray-500)}
.file-drop:hover{border-color:var(--yellow-deep);background:var(--gray-50)}
.file-drop svg{width:30px;height:30px;stroke:var(--gray-400);fill:none;stroke-width:1.8;margin-bottom:6px}
.file-drop b{color:var(--ink)}
.file-list{list-style:none;margin-top:12px;display:flex;flex-direction:column;gap:8px}
.file-list li{display:flex;align-items:center;gap:10px;background:var(--gray-50);border:1px solid var(--border);border-radius:9px;padding:8px 12px;font-size:.86rem}
.file-list li .fx{margin-left:auto;color:var(--gray-400);cursor:pointer;font-weight:700}
.file-list li .fx:hover{color:#d23b3b}
.hint{font-size:.86rem;color:var(--gray-500);text-align:center;margin-top:10px}
.form-note{text-align:center;font-size:.95rem;color:var(--ink);font-weight:600;margin-top:12px}
.alt-action{margin-top:22px;padding-top:20px;border-top:1px solid var(--border);text-align:center}

/* ---------- Loading spinner on buttons ---------- */
.btn.loading{position:relative;color:transparent!important;pointer-events:none}
.btn.loading::after{content:"";position:absolute;width:18px;height:18px;border:2.5px solid rgba(0,0,0,.25);border-top-color:var(--ink);border-radius:50%;animation:spin .7s linear infinite}
.btn--dark.loading::after,.btn--wa.loading::after{border-color:rgba(255,255,255,.35);border-top-color:#fff}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- Big success panel ---------- */
.success-panel{display:none;text-align:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:46px 30px;box-shadow:var(--shadow)}
.success-panel.show{display:block}
.success-panel .big-tick{width:74px;height:74px;border-radius:50%;background:var(--yellow);color:var(--ink);display:grid;place-items:center;margin:0 auto 18px;font-size:2.2rem;font-weight:800}
.success-panel h2{margin-bottom:10px}
.success-panel p{max-width:460px;margin:0 auto 22px}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:20px;bottom:20px;z-index:150;width:60px;height:60px;border-radius:50%;background:#25D366;box-shadow:0 10px 26px rgba(37,211,102,.45);display:flex;align-items:center;justify-content:center;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}
.wa-float svg{width:32px;height:32px;fill:#fff}
.wa-float .wa-pulse{position:absolute;inset:0;border-radius:50%;background:#25D366;opacity:.5;animation:wapulse 2.4s infinite}
@keyframes wapulse{0%{transform:scale(1);opacity:.5}70%{transform:scale(1.6);opacity:0}100%{opacity:0}}
@media(max-width:560px){.wa-float{width:54px;height:54px;right:16px;bottom:16px}.wa-float svg{width:28px;height:28px}}

/* ---------- Accessibility: focus rings ---------- */
a:focus-visible,button:focus-visible,.btn:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.basket-btn:focus-visible{outline:3px solid rgba(255,210,31,.65);outline-offset:2px;border-radius:6px}

/* ---------- Language switcher ---------- */
.lang-switch{display:inline-flex;align-items:center;gap:2px;margin-left:6px}
.lang-switch button{background:none;border:0;color:#9aa0ad;font-size:.78rem;font-weight:700;cursor:pointer;padding:2px 7px;border-radius:6px;font-family:var(--display)}
.lang-switch button:hover{color:#fff}
.lang-switch button.active{color:var(--yellow)}
.lang-switch .sep{color:#3a3f4a;font-size:.7rem}

/* ---------- Sticky mobile CTA bar ---------- */
.mobile-cta{position:fixed;left:0;right:0;bottom:0;z-index:140;display:none;gap:10px;padding:9px 12px;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);border-top:1px solid var(--border)}
.mobile-cta .btn{flex:1;justify-content:center;padding:13px 10px}
@media(max-width:760px){.mobile-cta{display:flex}.wa-float{bottom:80px}}

/* ---------- Blog / resources ---------- */
.post-meta{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--gray-500);margin-bottom:6px}
.post-tag{display:inline-block;background:var(--yellow-soft);color:#7a6200;font-weight:700;font-size:.72rem;letter-spacing:.05em;text-transform:uppercase;padding:4px 11px;border-radius:50px}
.article{max-width:760px;margin:0 auto}
.article .lede{font-size:1.18rem;color:var(--gray-600);line-height:1.6;margin:14px 0 26px}
.article h2{font-size:1.5rem;margin:34px 0 12px}
.article h3{font-size:1.18rem;margin:24px 0 8px}
.article p{margin:0 0 16px;line-height:1.75}
.article ul,.article ol{margin:0 0 18px;padding-left:22px;line-height:1.75}
.article li{margin-bottom:8px}
.article .callout{background:var(--gray-50);border:1px solid var(--border);border-left:4px solid var(--yellow-deep);border-radius:0 12px 12px 0;padding:16px 20px;margin:22px 0}
.article .callout p{margin:0}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .hero .container{grid-template-columns:1fr;gap:40px}
  .hero-media{aspect-ratio:16/11;max-width:560px}
  .cat-grid,.tgrid,.features{grid-template-columns:repeat(2,1fr)}
  .stats,.steps{grid-template-columns:repeat(2,1fr)}
  .prod-items{grid-template-columns:repeat(2,1fr)}
  .gallery{grid-template-columns:repeat(2,1fr)}
  .fgrid{grid-template-columns:1fr 1fr}
  .split,.contact-grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .product-wrap{grid-template-columns:1fr;gap:32px}
  .config{position:static}
  .quote-grid{grid-template-columns:1fr;gap:28px}
}
@media(max-width:1024px){
  .nav-links{position:absolute;top:80px;left:0;right:0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:10px 16px 20px;border-bottom:1px solid var(--border);box-shadow:var(--shadow);display:none;max-height:calc(100vh - 80px);overflow-y:auto}
  .nav-links.open{display:flex}
  .nav-links>li>a{padding:14px 10px}
  .dropdown{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-left:2px solid var(--yellow);border-radius:0;margin:4px 0 8px 10px;padding:0 0 0 8px;min-width:0}
  .burger{display:flex}
  .nav-cta .btn:not(.burger){display:none}
  .topbar .tb-right .hide-sm{display:none}
  .hero-badge{display:none}
}
@media(max-width:560px){
  .cat-grid,.cat-grid.cols-2,.tgrid,.features,.stats,.steps,.prod-items,.gallery,.fgrid{grid-template-columns:1fr}
  .section{padding:62px 0}
  .cta-band{padding:34px}
  .gallery .shot.wide{grid-column:span 1;aspect-ratio:1/1}
}
