/* ===========================================================
   CV Pro — Creative Modern UI
   White + gray + black base · light-neon accents
   Marketplace layout · animated icons · fully responsive
   Keeps every original class & CSS-var name (PHP-safe).
   Developed for whitecoder.lk
   =========================================================== */

:root{
  /* surfaces */
  --bg:#FFFFFF;
  --page:#F5F6F8;
  --soft:#F1F3F6;
  --soft-2:#FAFBFC;
  --card:#FFFFFF;
  --ink-surface:#0C0E14;        /* black sections */

  /* ink */
  --text:#0C0E14;
  --ink:#0C0E14;
  --muted:#5B616E;
  --faint:#9AA0AC;

  /* lines */
  --border:rgba(12,14,20,.08);
  --border-strong:rgba(12,14,20,.14);

  /* monochrome accent system — white / gray / black */
  --accent:#111317;            /* near-black primary */
  --accent-hover:#000000;
  --accent-press:#000000;
  --accent-soft:rgba(17,19,23,.06);
  --accent-ring:rgba(17,19,23,.16);
  --accent-2:#6B7280;          /* mid gray */
  --neon-green:#111317;
  --neon-pink:#111317;
  --neon-lime:#6B7280;
  --grad:linear-gradient(135deg,#1B1D22 0%,#3A3D44 100%);
  --grad-2:linear-gradient(135deg,#0C0E14 0%,#3A3D44 100%);
  --grad-3:linear-gradient(135deg,#3A3D44 0%,#6B7280 100%);
  /* aliases kept so older rules referencing these keep working */
  --flame:linear-gradient(135deg,#1B1D22,#3A3D44);
  --flame-deep:linear-gradient(135deg,#0C0E14,#1B1D22);

  /* status */
  --success:#12B981;
  --warning:#F59E0B;
  --danger:#FF3B5C;
  --whatsapp:#25D366;

  /* neon glows */
  --glow:0 10px 28px rgba(17,19,23,.18);
  --glow-cyan:0 10px 28px rgba(17,19,23,.14);

  /* radii */
  --radius:16px;--radius-sm:11px;--radius-lg:22px;--pill:999px;

  /* depth */
  --shadow-sm:0 1px 2px rgba(12,14,20,.05);
  --shadow:0 8px 26px rgba(12,14,20,.07), 0 2px 8px rgba(12,14,20,.04);
  --shadow-lg:0 22px 54px rgba(12,14,20,.14), 0 8px 20px rgba(12,14,20,.07);
  --shadow-accent:0 10px 26px rgba(17,19,23,.16);

  /* motion */
  --ease:cubic-bezier(.16,1,.3,1);
  --t-fast:.25s var(--ease);--t:.45s var(--ease);

  --maxw:1240px;--header-h:60px;--bottomnav-h:60px;
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-display:-apple-system,BlinkMacSystemFont,"SF Pro Display","Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--text);background:var(--page);line-height:1.55;letter-spacing:-.01em;
  overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4,.brand{font-family:var(--font-display);line-height:1.12;letter-spacing:-.02em;font-weight:700}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}
.muted{color:var(--muted)}.center{text-align:center}
section{padding:42px 0}
@media(max-width:640px){section{padding:26px 0}}
::selection{background:var(--accent-ring);color:var(--accent-press)}
main{display:block}
@media(max-width:900px){body{padding-bottom:calc(var(--bottomnav-h) + env(safe-area-inset-bottom,0px))}}

/* gradient text utility */
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* top progress bar */
#cv-progress{position:fixed;top:0;left:0;height:3px;width:0;z-index:300;background:var(--grad);box-shadow:var(--glow);opacity:0;transition:width .3s ease,opacity .4s ease}
#cv-progress.go{opacity:1}

/* ---------- Buttons ---------- */
.btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:inherit;font-weight:640;font-size:15px;letter-spacing:-.01em;border:1px solid transparent;border-radius:var(--pill);
  padding:11px 22px;cursor:pointer;white-space:nowrap;transition:transform var(--t),box-shadow var(--t),background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}
.btn:active{transform:scale(.96)}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-accent)}
.btn-primary:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 16px 34px rgba(17,19,23,.18)}
.btn-outline{background:#fff;color:var(--text);border-color:var(--border-strong)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn-wa{background:var(--whatsapp);color:#fff;box-shadow:0 8px 20px rgba(37,211,102,.28)}
.btn-wa:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 14px 28px rgba(37,211,102,.34)}
.btn-danger{background:var(--danger);color:#fff}
.btn-ghost{background:transparent;color:var(--muted)}
.btn-ghost:hover{color:var(--text);background:var(--soft)}
.btn-sm{padding:8px 14px;font-size:13px}.btn-block{width:100%}.btn-lg{padding:14px 28px;font-size:16px}
.btn .ripple{position:absolute;border-radius:50%;transform:scale(0);pointer-events:none;background:rgba(255,255,255,.5);animation:ripple .6s var(--ease)}
.btn-outline .ripple,.btn-ghost .ripple{background:var(--accent-ring)}
@keyframes ripple{to{transform:scale(2.6);opacity:0}}

/* ===========================================================
   ANIMATED ICON LIBRARY (payments + notifications + status)
   =========================================================== */
.ai{display:inline-grid;place-items:center;flex-shrink:0}
.ai-badge{width:84px;height:84px;border-radius:50%;display:grid;place-items:center;position:relative}
.ai-badge.green{background:rgba(18,185,129,.12);color:var(--success)}
.ai-badge.violet{background:var(--accent-soft);color:var(--accent)}
.ai-badge.cyan{background:rgba(34,227,255,.12);color:#0bb6d6}
.ai-badge::after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid currentColor;opacity:.25;animation:ai-ring 2s var(--ease) infinite}
@keyframes ai-ring{0%{transform:scale(.85);opacity:.5}100%{transform:scale(1.25);opacity:0}}

/* animated check (draws on) */
.ai-check path{stroke-dasharray:30;stroke-dashoffset:30;animation:ai-draw .7s var(--ease) .15s forwards}
@keyframes ai-draw{to{stroke-dashoffset:0}}
/* spinner */
.ai-spin{width:22px;height:22px;border:2.5px solid var(--accent-ring);border-top-color:var(--accent);border-radius:50%;animation:ai-rot .8s linear infinite}
@keyframes ai-rot{to{transform:rotate(360deg)}}
/* bell swing (notifications) */
.ai-bell{transform-origin:top center;animation:ai-swing 2.4s var(--ease) infinite}
@keyframes ai-swing{0%,60%,100%{transform:rotate(0)}70%{transform:rotate(12deg)}80%{transform:rotate(-9deg)}90%{transform:rotate(5deg)}}
.ai-dot{animation:ai-blink 1.4s ease-in-out infinite}
@keyframes ai-blink{0%,100%{opacity:1}50%{opacity:.35}}
/* card payment shimmer */
.ai-card{position:relative;overflow:hidden}
.ai-card::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(110deg,transparent,rgba(255,255,255,.65),transparent);animation:ai-shine 2.4s var(--ease) infinite}
@keyframes ai-shine{to{left:130%}}
/* success burst */
.ai-burst::before,.ai-burst::after{content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--success);opacity:0;animation:ai-burst 1.4s var(--ease) infinite}
.ai-burst::after{animation-delay:.5s}
@keyframes ai-burst{0%{transform:scale(.8);opacity:.6}100%{transform:scale(1.6);opacity:0}}

/* ===========================================================
   HEADER
   =========================================================== */
.site-header{position:sticky;top:0;z-index:120;background:rgba(255,255,255,.9);
  -webkit-backdrop-filter:saturate(180%) blur(16px);backdrop-filter:saturate(180%) blur(16px);
  border-bottom:1px solid var(--border);transition:box-shadow var(--t-fast)}
.site-header.scrolled{box-shadow:0 4px 20px rgba(12,14,20,.07)}
.site-header .container{min-height:var(--header-h);display:flex;align-items:center;gap:16px;padding-top:8px;padding-bottom:8px;flex-wrap:wrap}
.brand{font-size:21px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;letter-spacing:-.03em;flex-shrink:0}
.brand .dot{width:10px;height:10px;border-radius:50%;background:var(--grad);box-shadow:var(--glow);transition:transform var(--t)}
.brand:hover .dot{transform:scale(1.25) rotate(20deg)}

.hdr-search{flex:1;min-width:0;display:flex;align-items:center;gap:8px;background:var(--soft);border:1.5px solid transparent;border-radius:var(--pill);padding:7px 7px 7px 16px;transition:border-color var(--t-fast),background var(--t-fast),box-shadow var(--t-fast)}
.hdr-search:focus-within{background:#fff;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring)}
.hdr-search input{flex:1;min-width:0;border:none;outline:none;background:transparent;font-family:inherit;font-size:14.5px;color:var(--text)}
.hdr-search input::placeholder{color:var(--faint)}
.hdr-search .go{flex-shrink:0;border:none;cursor:pointer;background:var(--grad);color:#fff;border-radius:var(--pill);height:36px;padding:0 18px;font-weight:700;font-size:13.5px;display:inline-flex;align-items:center;gap:6px;transition:transform var(--t-fast),box-shadow var(--t-fast)}
.hdr-search .go:hover{box-shadow:var(--glow)}.hdr-search .go:active{transform:scale(.95)}

.nav{display:flex;gap:2px}
.nav a{position:relative;color:var(--muted);font-weight:560;font-size:14px;padding:7px 11px;border-radius:9px;transition:color var(--t-fast),background var(--t-fast)}
.nav a:hover{color:var(--text);background:var(--soft)}
.nav a.active{color:var(--accent)}
.header-right{display:flex;align-items:center;gap:6px;flex-shrink:0}
.hdr-ic{position:relative;width:42px;height:42px;border-radius:12px;display:grid;place-items:center;color:var(--text);transition:background var(--t-fast),color var(--t-fast)}
.hdr-ic:hover{background:var(--soft);color:var(--accent)}
.hdr-ic .badge{position:absolute;top:5px;right:5px;min-width:16px;height:16px;padding:0 4px;border-radius:9px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;display:grid;place-items:center}

.hamburger{display:none;background:none;border:none;cursor:pointer;width:42px;height:42px;border-radius:11px}
.hamburger:hover{background:var(--soft)}
.hamburger span{display:block;width:21px;height:2px;background:var(--text);border-radius:2px;margin:5px auto;transition:transform var(--t-fast),opacity var(--t-fast)}
.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

.mobile-menu{position:fixed;inset:0 0 0 auto;width:min(82vw,340px);background:#fff;z-index:130;transform:translateX(100%);transition:transform .4s var(--ease);padding:22px 18px;overflow-y:auto;box-shadow:var(--shadow-lg)}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{display:block;padding:15px 6px;font-size:17px;font-weight:560;border-bottom:1px solid var(--border)}
.mobile-menu a:hover{color:var(--accent)}
.mobile-menu .btn{margin-top:16px}

@media(max-width:900px){
  :root{--header-h:auto}
  .nav,.header-right .desktop-only{display:none}
  .hamburger{display:block}
  .site-header .container{gap:10px}
  .hdr-search{order:3;flex-basis:100%}
}

/* ===========================================================
   PROMO CAROUSEL
   =========================================================== */
.promo{padding:16px 0 8px}
.carousel{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.carousel-track{display:flex;transition:transform .6s var(--ease)}
.slide{position:relative;flex:0 0 100%;min-height:320px;display:flex;align-items:center;padding:48px 56px;color:#fff;overflow:hidden}
.slide .copy{position:relative;z-index:2;max-width:560px}
.slide .eyebrow{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:6px 14px;border-radius:var(--pill);font-size:12.5px;font-weight:700;margin-bottom:16px}
.slide h2{font-size:44px;font-weight:820;line-height:1.04;margin-bottom:12px;letter-spacing:-.03em;text-shadow:0 2px 22px rgba(0,0,0,.18)}
.slide p{font-size:17px;opacity:.95;margin-bottom:22px;max-width:440px}
.slide .btn-outline{background:#fff;color:#111317;border-color:#fff;font-weight:760}
.slide .btn-outline:hover{color:#000}
.slide .art{position:absolute;right:-30px;bottom:-26px;z-index:1;width:300px;opacity:.97;transform:rotate(-6deg);filter:drop-shadow(0 24px 44px rgba(0,0,0,.3));transition:transform .8s var(--ease)}
.carousel:hover .slide.is-active .art{transform:rotate(-2deg) translateY(-6px)}
.slide.s1{background:linear-gradient(130deg,#0C0E14 0%,#1B1D22 60%,#3A3D44 100%)}
.slide.s2{background:linear-gradient(130deg,#16181D 0%,#2A2D33 55%,#4B4F57 100%)}
.slide.s3{background:linear-gradient(130deg,#0C0E14 0%,#26282E 55%,#5B616E 120%)}
.slide::after{content:"";position:absolute;inset:0;z-index:1;background:radial-gradient(680px 300px at 88% 120%,rgba(255,255,255,.06),transparent 60%)}
.carousel-dots{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:8px;z-index:5}
.carousel-dots button{width:9px;height:9px;border-radius:50%;border:none;background:rgba(255,255,255,.5);cursor:pointer;padding:0;transition:width var(--t-fast),background var(--t-fast)}
.carousel-dots button.on{width:26px;border-radius:5px;background:#fff}
.carousel-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.9);border:none;cursor:pointer;display:grid;place-items:center;color:#111;box-shadow:var(--shadow);opacity:0;transition:opacity var(--t-fast),transform var(--t-fast)}
.carousel:hover .carousel-arrow{opacity:1}
.carousel-arrow:hover{transform:translateY(-50%) scale(1.08)}
.carousel-arrow.prev{left:14px}.carousel-arrow.next{right:14px}
.carousel-play{position:absolute;top:14px;right:14px;z-index:5;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.22);border:1px solid rgba(255,255,255,.35);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:#fff;cursor:pointer;display:grid;place-items:center;transition:transform var(--t-fast),background var(--t-fast)}
.carousel-play:hover{background:rgba(255,255,255,.35);transform:scale(1.08)}
@media(max-width:900px){
  .slide{padding:30px 22px;min-height:218px}
  .slide h2{font-size:27px}.slide p{font-size:14.5px;margin-bottom:16px}
  .slide .art{width:165px;right:-26px}
  .carousel-arrow{opacity:1;width:34px;height:34px;background:rgba(255,255,255,.82)}
  .carousel-arrow.prev{left:8px}.carousel-arrow.next{right:8px}
}

/* assurance strip */
.assurance{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:14px}
.assurance .a-item{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;transition:transform var(--t),box-shadow var(--t)}
.assurance .a-item:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.assurance .a-ic{width:40px;height:40px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex-shrink:0}
.assurance b{font-size:13.5px;display:block}.assurance span{font-size:12px;color:var(--muted)}
@media(max-width:760px){.assurance{grid-template-columns:repeat(2,1fr)}}

/* ===========================================================
   CATEGORY ICON RAIL
   =========================================================== */
.rail-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px 8px}
.cat-rail{display:flex;gap:6px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:2px;scrollbar-width:none}
.cat-rail::-webkit-scrollbar{display:none}
.cat-tile{scroll-snap-align:start;flex:0 0 auto;width:84px;display:flex;flex-direction:column;align-items:center;gap:9px;padding:6px 4px;border-radius:12px;transition:background var(--t-fast),transform var(--t-fast)}
.cat-tile:hover{background:var(--soft);transform:translateY(-3px)}
.cat-tile .ic{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.cat-tile:hover .ic{transform:scale(1.08) rotate(-3deg);box-shadow:var(--glow)}
.cat-tile span{font-size:12px;font-weight:560;color:var(--text);text-align:center;line-height:1.25;max-width:80px}
.cat-c0{background:linear-gradient(135deg,#1B1D22,#3A3D44)}
.cat-c1{background:linear-gradient(135deg,#26282E,#4B4F57)}
.cat-c2{background:linear-gradient(135deg,#3A3D44,#5B616E)}
.cat-c3{background:linear-gradient(135deg,#0C0E14,#2A2D33)}
.cat-c4{background:linear-gradient(135deg,#44474F,#6B7280)}
.cat-c5{background:linear-gradient(135deg,#1B1D22,#4B4F57)}
.cat-c6{background:linear-gradient(135deg,#0C0E14,#3A3D44)}
.cat-c7{background:linear-gradient(135deg,#2A2D33,#5B616E)}

/* ===========================================================
   SECTION / BLOCK HEADERS
   =========================================================== */
.block{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 16px 22px;margin-top:14px}
.block-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.block-head h2{font-size:21px;font-weight:780;letter-spacing:-.02em;display:flex;align-items:center;gap:9px}
.block-head .more{font-size:13.5px;color:var(--accent);font-weight:680;display:inline-flex;align-items:center;gap:4px;transition:gap var(--t-fast)}
.block-head .more:hover{gap:9px}
.sec-head{text-align:center;max-width:680px;margin:0 auto 26px}
.sec-head .eyebrow{display:inline-flex;align-items:center;gap:7px;color:var(--accent);font-weight:700;font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;margin-bottom:12px}
.sec-head h2{font-size:31px;font-weight:780;letter-spacing:-.025em;margin-bottom:10px}
.sec-head p{color:var(--muted);font-size:16px}
@media(max-width:640px){.sec-head h2{font-size:23px}.sec-head p{font-size:14.5px}}

/* ===========================================================
   FLASH SALE
   =========================================================== */
.flash{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-top:14px}
.flash-top{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:16px 18px;background:var(--grad);color:#fff}
.flash-top .ttl{display:flex;align-items:center;gap:9px;font-size:20px;font-weight:820;letter-spacing:-.02em}
.flash-top .bolt{animation:bolt 1.6s var(--ease) infinite;display:inline-block}
@keyframes bolt{0%,100%{transform:scale(1) rotate(0)}40%{transform:scale(1.18) rotate(-8deg)}}
.countdown{display:flex;align-items:center;gap:6px;font-weight:700}
.countdown .lbl{font-size:12.5px;opacity:.92;font-weight:600;margin-right:2px}
.cd-box{background:rgba(0,0,0,.3);border-radius:7px;min-width:30px;height:30px;display:grid;place-items:center;font-variant-numeric:tabular-nums;font-size:15px;font-weight:800}
.countdown .sep{font-weight:800}
.flash-top .more{margin-left:auto;color:#fff;font-weight:700;font-size:13.5px;display:inline-flex;align-items:center;gap:5px;opacity:.95}
.flash-rail{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;padding:16px}
@media(max-width:1100px){.flash-rail{grid-template-columns:repeat(4,1fr)}}
@media(max-width:900px){
  .flash-rail{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .flash-rail::-webkit-scrollbar{display:none}
  .flash-rail > *{scroll-snap-align:start;flex:0 0 46%}
}
@media(max-width:480px){.flash-top .ttl{font-size:17px}.cd-box{min-width:26px;height:26px;font-size:13px}}

/* ===========================================================
   PRODUCT GRID + CARD
   =========================================================== */
.grid{display:grid;gap:12px}
.grid-4,.grid-3,.grid-2{grid-template-columns:repeat(2,1fr)}
@media(min-width:560px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(3,1fr)}}
@media(min-width:820px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid{gap:16px}}
@media(min-width:1100px){.grid-4{grid-template-columns:repeat(5,1fr)}}

.tpl-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.tpl-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.tpl-thumb{position:relative;aspect-ratio:1/1;overflow:hidden;background:linear-gradient(135deg,#eef0f4,#e6e9ef)}
.tpl-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),opacity .5s ease;opacity:0}
.tpl-thumb img.loaded{opacity:1}
.tpl-card:hover .tpl-thumb img{transform:scale(1.07)}
.tpl-thumb::before{content:"";position:absolute;inset:0;background:linear-gradient(100deg,#eef0f4 30%,#f7f8fb 50%,#eef0f4 70%);background-size:200% 100%;animation:shimmer 1.3s linear infinite;z-index:0}
.tpl-thumb.ready::before{display:none}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.tpl-disc{position:absolute;top:0;left:0;z-index:3;background:var(--grad-2);color:#fff;font-size:12px;font-weight:800;padding:5px 9px;border-bottom-right-radius:12px;box-shadow:0 4px 12px rgba(17,19,23,.25)}
.tpl-disc small{display:block;font-size:8.5px;font-weight:700;opacity:.9;letter-spacing:.04em;line-height:1}
.tpl-badge{position:absolute;top:10px;left:10px;z-index:2;background:rgba(255,255,255,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text);font-size:11px;font-weight:700;padding:4px 9px;border-radius:var(--pill);box-shadow:var(--shadow-sm)}
.tpl-fav{position:absolute;top:8px;right:8px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.9);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;cursor:pointer;display:grid;place-items:center;color:var(--muted);box-shadow:var(--shadow-sm);transition:transform var(--t-fast),color var(--t-fast)}
.tpl-fav:hover{transform:scale(1.14);color:var(--accent)}
.tpl-fav:active{transform:scale(.9)}
.tpl-fav.on{color:var(--accent)}
.tpl-fav.on svg{fill:var(--accent);stroke:var(--accent);animation:pop .4s var(--ease)}
@keyframes pop{0%{transform:scale(1)}45%{transform:scale(1.4)}100%{transform:scale(1)}}
.tpl-body{padding:10px 11px 12px;display:flex;flex-direction:column;gap:6px;flex:1}
.tpl-body h3{font-size:14px;font-weight:560;line-height:1.35;letter-spacing:-.01em;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tpl-body h3 a{transition:color var(--t-fast)}
.tpl-body h3 a:hover{color:var(--accent)}
.tpl-tags{display:flex;gap:5px;flex-wrap:wrap}
.tag-mini{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:6px;background:var(--accent-soft);color:var(--accent)}
.tag-mini.gray{background:var(--soft);color:var(--muted)}
.rating{display:flex;align-items:center;gap:4px;color:#111317;font-size:12px;font-weight:600}
.rating .sold{color:var(--faint);font-weight:500;margin-left:2px}
.tpl-price{display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.tpl-price .now{font-weight:820;font-size:18px;color:var(--text);letter-spacing:-.02em}
.tpl-price s{color:var(--faint);font-weight:400;font-size:12px}
.tpl-meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto}
.tpl-actions{display:flex;gap:7px;padding:0 11px 11px}
.tpl-actions .btn{flex:1;padding:8px 10px;font-size:12.5px}
.tpl-actions .btn-outline{flex:0 0 42px;padding:8px 0}

/* ===========================================================
   CATEGORY FILTER CHIPS (listing)
   =========================================================== */
.cats{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:640px){.cats{flex-wrap:nowrap;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}.cats::-webkit-scrollbar{display:none}}
.cat-chip{flex:0 0 auto;background:#fff;border:1px solid var(--border-strong);border-radius:var(--pill);padding:8px 16px;font-weight:560;font-size:13.5px;color:var(--muted);transition:all var(--t-fast)}
.cat-chip:hover{color:var(--accent);border-color:var(--accent)}
.cat-chip.active{background:var(--grad);color:#fff;border-color:transparent;box-shadow:var(--shadow-accent)}

/* ===========================================================
   STATS BAND (black + neon)
   =========================================================== */
.stats-band{background:var(--ink-surface);border-radius:var(--radius-lg);padding:34px 24px;color:#fff;position:relative;overflow:hidden;margin-top:14px}
.stats-band::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.10),transparent 65%);top:-180px;left:-80px}
.stats-band::after{content:"";position:absolute;width:380px;height:380px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 65%);bottom:-200px;right:-60px}
.stats-grid{position:relative;z-index:1;display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat .num{font-size:38px;font-weight:840;letter-spacing:-.03em;background:linear-gradient(135deg,#fff,#AEB4C2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .lbl{color:#AEB4C2;font-size:13.5px;margin-top:4px}
@media(max-width:640px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:24px 12px}.stat .num{font-size:30px}}

/* ===========================================================
   FEATURES (why choose us) — animated icons
   =========================================================== */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:820px){.features{grid-template-columns:1fr}}
.feature{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:transparent}
.feature .fic{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;color:#fff;margin-bottom:14px;background:var(--grad);box-shadow:var(--shadow-accent);transition:transform var(--t)}
.feature:hover .fic{transform:scale(1.1) rotate(-4deg);box-shadow:var(--glow)}
.feature h4{font-size:17px;font-weight:700;margin-bottom:6px}
.feature p{color:var(--muted);font-size:14px}

/* ===========================================================
   PROCESS TIMELINE / STEPS
   =========================================================== */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media(max-width:820px){.steps{grid-template-columns:repeat(2,1fr)}}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:transform var(--t),box-shadow var(--t)}
.step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.step .n{width:42px;height:42px;border-radius:13px;background:var(--grad);color:#fff;font-weight:820;display:grid;place-items:center;font-size:17px;margin-bottom:12px;box-shadow:var(--shadow-accent)}
.step h4{font-size:16px;font-weight:680;margin-bottom:5px}
.step p{color:var(--muted);font-size:13.5px}

/* ===========================================================
   PACKAGES
   =========================================================== */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}
@media(max-width:820px){.packages{grid-template-columns:1fr}}
.pkg{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:26px;position:relative;transition:transform var(--t),box-shadow var(--t)}
.pkg:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.pkg.popular{border-color:transparent;box-shadow:var(--shadow-lg)}
.pkg.popular::before{content:"★ Most Popular";position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--grad);color:#fff;font-size:12px;font-weight:700;padding:6px 16px;border-radius:var(--pill);box-shadow:var(--shadow-accent);white-space:nowrap}
.pkg h3{font-size:20px;font-weight:720;margin-bottom:6px}
.pkg .price{font-size:34px;font-weight:820;letter-spacing:-.03em;margin:10px 0;color:var(--text)}
.pkg .price small{font-size:14px;color:var(--muted);font-weight:500}
.pkg ul{list-style:none;margin:18px 0;display:flex;flex-direction:column;gap:10px}
.pkg ul li{display:flex;gap:9px;font-size:14px;color:var(--text)}
.pkg ul li svg{color:var(--success);flex-shrink:0;margin-top:2px}

/* ===========================================================
   SHOWCASE strip
   =========================================================== */
.showcase{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:4px 2px 10px;scrollbar-width:none}
.showcase::-webkit-scrollbar{display:none}
.showcase .shot{scroll-snap-align:start;flex:0 0 auto;width:220px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:#fff;box-shadow:var(--shadow-sm);transition:transform var(--t),box-shadow var(--t)}
.showcase .shot:hover{transform:translateY(-5px) scale(1.02);box-shadow:var(--shadow-lg)}
.showcase .shot img{width:100%;height:auto;display:block}

/* ===========================================================
   OFFER STRIP / coupon
   =========================================================== */
.offer-strip{display:flex;align-items:center;gap:16px;flex-wrap:wrap;background:var(--ink-surface);color:#fff;border-radius:var(--radius-lg);padding:22px 26px;margin-top:14px;position:relative;overflow:hidden}
.offer-strip::after{content:"";position:absolute;inset:0;background:radial-gradient(500px 200px at 90% 120%,rgba(255,255,255,.08),transparent 60%)}
.offer-strip>*{position:relative;z-index:1}
.offer-strip .code{font-family:ui-monospace,Menlo,monospace;border:1.5px dashed rgba(255,255,255,.5);border-radius:10px;padding:8px 14px;font-weight:800;letter-spacing:.08em;color:#fff;background:rgba(255,255,255,.06)}
.offer-strip h3{font-size:20px;font-weight:780}
.offer-strip p{color:#AEB4C2;font-size:14px}

/* ===========================================================
   REVIEWS
   =========================================================== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}
.review{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;transition:transform var(--t),box-shadow var(--t)}
.review:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.review .stars{color:#111317;margin-bottom:10px}
.review p{font-size:14.5px;line-height:1.6}
.review .who{margin-top:14px;font-weight:680;font-size:13.5px;color:var(--muted)}

/* ===========================================================
   NEWSLETTER
   =========================================================== */
.newsletter{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:30px;text-align:center;margin-top:14px}
.newsletter h3{font-size:24px;font-weight:780;margin-bottom:6px}
.newsletter p{color:var(--muted);margin-bottom:18px}
.newsletter .nl-form{display:flex;gap:10px;max-width:460px;margin:0 auto}
.newsletter input{flex:1;border:1px solid var(--border-strong);border-radius:var(--pill);padding:12px 18px;font-family:inherit;font-size:15px;outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.newsletter input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring)}
@media(max-width:480px){.newsletter .nl-form{flex-direction:column}.newsletter input{width:100%}}

/* ===========================================================
   FAQ
   =========================================================== */
.faq-item{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px;background:#fff;overflow:hidden;transition:box-shadow var(--t)}
.faq-item.open{box-shadow:var(--shadow)}
.faq-q{width:100%;text-align:left;background:none;border:none;padding:16px 18px;font-size:15.5px;font-weight:680;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;font-family:inherit;color:var(--text)}
.faq-a{padding:0 18px;max-height:0;overflow:hidden;transition:max-height .4s var(--ease),padding .4s var(--ease);color:var(--muted)}
.faq-item.open .faq-a{padding:0 18px 16px;max-height:340px}
.faq-item.open .faq-q .chev{transform:rotate(180deg);color:var(--accent)}
.faq-q .chev{transition:transform var(--t),color var(--t-fast);flex-shrink:0}

/* ===========================================================
   CTA BAND
   =========================================================== */
.cta-band{position:relative;overflow:hidden;border-radius:var(--radius-lg);padding:48px 34px;text-align:center;color:#fff;background:var(--ink-surface);box-shadow:var(--shadow-lg)}
.cta-band::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.10),transparent 65%);top:-160px;right:-70px}
.cta-band::after{content:"";position:absolute;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 65%);bottom:-180px;left:-60px}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{font-size:33px;font-weight:820;margin-bottom:12px;color:#fff}
.cta-band p{opacity:.92;max-width:540px;margin:0 auto 24px;font-size:16px;color:#D7DBE5}
.cta-band .btn-outline{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);color:#fff}
.cta-band .btn-outline:hover{background:#fff;color:var(--accent);border-color:#fff}
@media(max-width:640px){.cta-band{padding:34px 20px}.cta-band h2{font-size:24px}}

/* ===========================================================
   FOOTER
   =========================================================== */
.site-footer{background:#fff;border-top:1px solid var(--border);padding:48px 0 26px;margin-top:14px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
.site-footer h5{font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--faint);margin-bottom:14px;font-weight:700}
.site-footer a{display:block;color:var(--muted);padding:5px 0;font-size:14px;transition:color var(--t-fast),transform var(--t-fast)}
.site-footer a:hover{color:var(--accent);transform:translateX(3px)}
.footer-bottom{border-top:1px solid var(--border);margin-top:34px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--faint);font-size:13px}
.footer-bottom b{background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:800}

/* ===========================================================
   MOBILE BOTTOM NAV
   =========================================================== */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:110;display:none;height:calc(var(--bottomnav-h) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:rgba(255,255,255,.96);-webkit-backdrop-filter:saturate(180%) blur(16px);backdrop-filter:saturate(180%) blur(16px);border-top:1px solid var(--border);box-shadow:0 -4px 20px rgba(12,14,20,.07)}
.bottom-nav a{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--muted);font-size:10.5px;font-weight:600;transition:color var(--t-fast)}
.bottom-nav a .bn-ic{position:relative;transition:transform var(--t-fast)}
.bottom-nav a.active{color:var(--accent)}
.bottom-nav a.active .bn-ic{transform:translateY(-2px);filter:drop-shadow(0 4px 10px rgba(109,94,247,.5))}
.bottom-nav a:active .bn-ic{transform:scale(.86)}
.bottom-nav a .badge{position:absolute;top:-4px;right:-8px;min-width:15px;height:15px;padding:0 4px;border-radius:8px;background:var(--accent);color:#fff;font-size:9px;font-weight:700;display:grid;place-items:center}
@media(max-width:900px){.bottom-nav{display:flex}}

/* Floating WhatsApp */
.fab-wa{position:fixed;right:16px;bottom:18px;z-index:100;width:54px;height:54px;border-radius:50%;background:var(--whatsapp);display:grid;place-items:center;box-shadow:0 12px 28px rgba(37,211,102,.4);transition:transform var(--t),box-shadow var(--t)}
.fab-wa::before{content:"";position:absolute;inset:0;border-radius:50%;background:var(--whatsapp);opacity:.45;z-index:-1;animation:pulse-ring 2.4s var(--ease) infinite}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.45}70%,100%{transform:scale(1.7);opacity:0}}
.fab-wa:hover{transform:scale(1.1) rotate(4deg)}
@media(max-width:900px){.fab-wa{bottom:calc(var(--bottomnav-h) + 16px + env(safe-area-inset-bottom,0px))}}

/* ===========================================================
   FORMS / inputs
   =========================================================== */
.field{margin-bottom:18px}
.field label{display:block;font-weight:660;font-size:14px;margin-bottom:7px;color:var(--text)}
.field label .req{color:var(--danger)}
.field .hint{font-size:13px;color:var(--muted);margin-top:5px}
.input,select.input,textarea.input{width:100%;font-family:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:#fff;outline:none;color:var(--text);transition:border-color var(--t-fast),box-shadow var(--t-fast)}
.input::placeholder,textarea.input::placeholder{color:var(--faint)}
.input:hover,select.input:hover,textarea.input:hover{border-color:var(--muted)}
.input:focus,select.input:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring)}
textarea.input{resize:vertical;min-height:100px}
.field-error{color:var(--danger);font-size:13px;margin-top:5px}
.searchbar{display:flex;gap:10px;background:#fff;border:1px solid var(--border-strong);border-radius:var(--pill);padding:7px 7px 7px 18px;box-shadow:var(--shadow-sm);max-width:580px;transition:box-shadow var(--t),border-color var(--t-fast)}
.searchbar:focus-within{box-shadow:var(--shadow);border-color:var(--accent)}
.searchbar input{flex:1;border:none;outline:none;font-size:15px;font-family:inherit;background:transparent;color:var(--text)}
.searchbar input::placeholder{color:var(--faint)}
@media(max-width:480px){.searchbar{border-radius:14px;flex-wrap:wrap;padding:10px}.searchbar input{width:100%}}

/* Auth card */
.auth-wrap{min-height:60vh;display:grid;place-items:center;padding:40px 16px}
.auth-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:34px;width:100%;max-width:440px;animation:rise-in .5s var(--ease) both}
@keyframes rise-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.auth-card h1{font-size:26px;font-weight:780;margin-bottom:6px}
.auth-card .sub{color:var(--muted);margin-bottom:24px;font-size:15px}
.auth-card .alt{text-align:center;margin-top:18px;font-size:14px;color:var(--muted)}
.auth-card .alt a{color:var(--accent);font-weight:680}

/* Alerts (with animated icon slot) */
.alert{display:flex;gap:10px;align-items:flex-start;padding:13px 16px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:14.5px;font-weight:500;animation:rise-in .4s var(--ease) both}
.alert .ai{margin-top:1px}
.alert-success{background:rgba(18,185,129,.1);color:#0A7A55;border:1px solid rgba(18,185,129,.25)}
.alert-error{background:rgba(255,59,92,.08);color:#C61E3C;border:1px solid rgba(255,59,92,.22)}
.alert-info{background:var(--accent-soft);color:var(--accent-press);border:1px solid var(--accent-ring)}

/* Pills */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:680;padding:5px 11px;border-radius:var(--pill)}
.pill-blue{background:var(--accent-soft);color:var(--accent)}
.pill-green{background:rgba(18,185,129,.12);color:var(--success)}
.pill-amber{background:#FFF6E6;color:#9A5B00}
.pill-red{background:rgba(255,59,92,.1);color:var(--danger)}
.pill-gray{background:var(--soft);color:var(--muted)}

/* breadcrumb */
.crumb{display:flex;gap:8px;color:var(--muted);font-size:14px;padding:18px 0}
.crumb a:hover{color:var(--accent)}

/* utilities */
.flex{display:flex}.between{justify-content:space-between}.center-y{align-items:center}.wrap{flex-wrap:wrap}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}
.mb-0{margin-bottom:0}.hidden{display:none}

/* toast (with animated icon) */
.cv-toast{display:flex;align-items:center;gap:10px;position:fixed;left:50%;bottom:90px;transform:translateX(-50%) translateY(24px);background:rgba(12,14,20,.95);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#fff;padding:12px 18px;border-radius:14px;font-size:14px;font-weight:500;box-shadow:0 16px 40px rgba(0,0,0,.35),var(--glow);z-index:200;opacity:0;pointer-events:none;transition:opacity .35s var(--ease),transform .35s var(--ease)}
.cv-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.cv-toast .ai{color:var(--accent-2)}

/* scroll reveal */
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.fade-up.in{opacity:1;transform:none}
html.js [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .6s var(--ease),transform .6s var(--ease);will-change:opacity,transform}
html.js [data-reveal].reveal-visible{opacity:1;transform:none}

/* content / legal pages */
.page-hero{background:#fff;border-bottom:1px solid var(--border);padding:42px 0 32px}
.page-hero h1{font-size:34px;font-weight:780;margin:0 0 8px}
.page-hero p{color:var(--muted);font-size:16px;max-width:660px;margin:0}
.prose{max-width:780px;margin:0 auto;padding:8px 0}
.prose h2{font-size:24px;font-weight:720;margin:32px 0 12px}
.prose h3{font-size:18px;font-weight:680;margin:24px 0 8px}
.prose p,.prose li{color:#33363F;font-size:15.5px;line-height:1.75}
.prose ul{margin:10px 0 10px 20px}.prose li{margin:6px 0}
.prose a{color:var(--accent)}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:start}
.contact-cards{display:grid;gap:14px}
.contact-card{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px;transition:transform var(--t),box-shadow var(--t)}
.contact-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.contact-card .ic{width:44px;height:44px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.contact-card h4{margin:0 0 3px;font-size:16px;font-weight:680}
.contact-card p,.contact-card a{margin:0;color:var(--muted);font-size:14.5px}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr}.page-hero h1{font-size:28px}}

.hero{padding:24px 0}
.hero .container{display:grid;grid-template-columns:1fr;gap:20px}
.hero h1{font-size:34px}.eyebrow{display:inline-flex;gap:8px;color:var(--accent);font-weight:700;font-size:13px;margin-bottom:12px}
.hero-mock{display:none}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{transition:none!important;animation:none!important;scroll-behavior:auto!important}
  html.js [data-reveal]{opacity:1!important;transform:none!important}
  .tpl-thumb img{opacity:1!important}.tpl-thumb::before{display:none!important}
}

/* ===========================================================
   PRELOADER (logo + loading animation)
   =========================================================== */
.preloader{position:fixed;inset:0;z-index:9999;background:#fff;display:grid;place-items:center;transition:opacity .5s var(--ease),visibility .5s var(--ease)}
.preloader.done{opacity:0;visibility:hidden}
.pl-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.pl-logo{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:800;font-size:24px;letter-spacing:-.02em;color:var(--ink);animation:pl-pulse 1.4s var(--ease) infinite}
.pl-logo-img{max-height:54px;width:auto;animation:pl-pulse 1.4s var(--ease) infinite}
.pl-dot{width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:var(--glow);animation:pl-spin 1.1s linear infinite}
@keyframes pl-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.97)}}
@keyframes pl-spin{to{transform:rotate(360deg)}}
.pl-bar{width:130px;height:4px;border-radius:4px;background:var(--soft);overflow:hidden}
.pl-bar span{display:block;height:100%;width:40%;border-radius:4px;background:var(--grad);animation:pl-slide 1.1s var(--ease) infinite}
@keyframes pl-slide{0%{transform:translateX(-120%)}100%{transform:translateX(360%)}}

/* ===========================================================
   LIVE SEARCH dropdown
   =========================================================== */
.hdr-search{position:relative}
.search-pop{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-lg);overflow:hidden;z-index:140;display:none}
.search-pop.show{display:block;animation:rise-in .25s var(--ease) both}
.search-pop a{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);transition:background var(--t-fast)}
.search-pop a:last-child{border-bottom:none}
.search-pop a:hover,.search-pop a.active{background:var(--soft)}
.search-pop .sp-thumb{width:40px;height:40px;border-radius:9px;object-fit:cover;background:var(--soft);flex-shrink:0}
.search-pop .sp-name{font-size:14px;font-weight:600;color:var(--text);line-height:1.2}
.search-pop .sp-meta{font-size:12px;color:var(--muted)}
.search-pop .sp-empty{padding:16px;text-align:center;color:var(--muted);font-size:14px}
.search-pop .sp-price{margin-left:auto;font-weight:800;font-size:14px;color:var(--text)}

/* ===========================================================
   STORE / templates page banner slider (mobile responsive)
   =========================================================== */
.store-hero{margin:14px 0}
.store-slide{min-height:200px;border-radius:var(--radius-lg)}
.store-slide h2{font-size:30px}
@media(max-width:640px){.store-slide{min-height:170px;padding:24px 20px}.store-slide h2{font-size:22px}}

/* social login buttons */
.social-auth{display:flex;flex-direction:column;gap:10px;margin:8px 0 4px}
.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:11px;border-radius:var(--pill);border:1px solid var(--border-strong);background:#fff;font-weight:600;font-size:14.5px;cursor:pointer;transition:background var(--t-fast),border-color var(--t-fast)}
.btn-social:hover{background:var(--soft);border-color:var(--muted)}
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--faint);font-size:13px;margin:18px 0}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--border)}

/* review form */
.review-form{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-top:16px}
.star-pick{display:flex;gap:4px;direction:rtl;justify-content:flex-end}
.star-pick input{display:none}
.star-pick label{font-size:26px;color:var(--border-strong);cursor:pointer;transition:color var(--t-fast)}
.star-pick label:hover,.star-pick label:hover ~ label,.star-pick input:checked ~ label{color:#111317}

/* ===========================================================
   CLARITY PASS — fluid headings (no oversized text on any
   screen), clearer buttons/tap-targets, package detail page.
   Appended last so it overrides without touching base rules.
   Developed for resume-whitecoder.lk
   =========================================================== */

/* Fluid headlines: scale smoothly between mobile and desktop so a
   heading can never render "too big" on a given viewport. */
.slide h2      { font-size:clamp(24px, 4.4vw, 44px); }
.sec-head h2   { font-size:clamp(21px, 3.2vw, 31px); }
.page-hero h1  { font-size:clamp(24px, 4vw, 40px); line-height:1.12; letter-spacing:-.02em; }
.cta-band h2   { font-size:clamp(22px, 3.4vw, 32px); }
.block-head h2 { font-size:clamp(18px, 2.4vw, 22px); }
h1 { overflow-wrap:break-word; }

/* Clearer, more legible buttons + reliable tap targets on touch */
.btn { font-weight:680; letter-spacing:-.01em; }
.btn-lg { font-weight:720; }
@media (max-width:760px){
  .btn      { min-height:46px; font-size:15px; }
  .btn-sm   { min-height:38px; font-size:13px; }
  .btn-block{ min-height:48px; }
  .nav a, .mobile-menu a { font-size:16px; }
}

/* ---- Package detail page ---- */
.pkg-detail{
  display:grid; grid-template-columns:340px 1fr; gap:40px; align-items:start;
}
.pkg-summary{ position:sticky; top:88px; }
.pkg-info .eyebrow{
  display:inline-flex; color:var(--accent); font-weight:700; font-size:12.5px;
  letter-spacing:.04em; text-transform:uppercase; margin-bottom:10px;
}
.pkg-info h1{ font-size:clamp(26px,3.6vw,38px); letter-spacing:-.02em; margin:0 0 12px; }
.pkg-h2{ font-size:clamp(19px,2.4vw,24px); letter-spacing:-.01em; margin:34px 0 14px; }
.pkg-list{ list-style:none; margin:0; padding:0; display:grid; gap:12px; }
.pkg-list li{
  display:flex; align-items:flex-start; gap:12px; background:var(--soft-2);
  border:1px solid var(--border); border-radius:14px; padding:14px 16px;
  font-size:15px; transition:transform var(--t-fast), box-shadow var(--t-fast);
}
.pkg-list li:hover{ transform:translateY(-2px); box-shadow:var(--shadow); }
.pkg-list li svg{ color:var(--success); flex-shrink:0; margin-top:1px; }
.pkg-meta{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; margin-top:18px;
  border-top:1px solid var(--border); padding-top:16px; }
.pkg-meta span{ display:block; font-size:11.5px; color:var(--muted); text-transform:uppercase; letter-spacing:.03em; }
.pkg-meta b{ font-size:14px; }
@media (max-width:860px){
  .pkg-detail{ grid-template-columns:1fr; gap:24px; }
  .pkg-summary{ position:static; }
}

/* ===========================================================
   PREMIUM AUTH PAGES (login / register) — split layout
   White form + charcoal brand panel. Fully responsive.
   =========================================================== */
.auth-split{
  display:grid; grid-template-columns:1.05fr 1fr; gap:0;
  max-width:1080px; margin:30px auto; padding:0 16px;
  min-height:min(78vh,640px);
}
.auth-split .auth-aside{
  position:relative; overflow:hidden; border-radius:var(--radius-lg) 0 0 var(--radius-lg);
  background:linear-gradient(155deg,#0C0E14 0%,#1B1D22 55%,#2C2F36 100%);
  color:#fff; padding:46px 42px; display:flex; align-items:center;
}
.auth-aside-inner{ position:relative; z-index:2; max-width:380px; }
.auth-aside .auth-logo{
  display:inline-flex; align-items:center; gap:9px; color:#fff;
  font-family:'Poppins',sans-serif; font-weight:760; font-size:18px; margin-bottom:30px;
}
.auth-aside .auth-logo .dot{ width:11px; height:11px; border-radius:50%;
  background:linear-gradient(135deg,#fff,#9AA0AC); box-shadow:0 0 0 4px rgba(255,255,255,.12); }
.auth-aside h2{
  font-size:clamp(22px,2.6vw,30px); line-height:1.18; letter-spacing:-.02em;
  font-weight:780; margin-bottom:24px;
}
.auth-points{ list-style:none; margin:0 0 28px; padding:0; display:grid; gap:13px; }
.auth-points li{ display:flex; align-items:flex-start; gap:11px; font-size:15px; color:#D7DBE5; }
.auth-points .ck{
  flex-shrink:0; width:22px; height:22px; border-radius:50%;
  background:rgba(255,255,255,.12); color:#fff; display:grid; place-items:center;
  font-size:12px; font-weight:800; border:1px solid rgba(255,255,255,.18);
}
.auth-trust{ display:flex; align-items:center; gap:10px; font-size:13.5px; color:#AEB3BE;
  border-top:1px solid rgba(255,255,255,.12); padding-top:18px; }
.auth-trust .stars{ color:#FBBF24; letter-spacing:2px; font-size:14px; }
.auth-aside-glow{ position:absolute; right:-90px; bottom:-90px; width:300px; height:300px; z-index:1;
  background:radial-gradient(circle,rgba(255,255,255,.10),transparent 65%); }

.auth-split .auth-main{
  background:#fff; border:1px solid var(--border); border-left:none;
  border-radius:0 var(--radius-lg) var(--radius-lg) 0; box-shadow:var(--shadow-lg);
  display:flex; align-items:center; justify-content:center; padding:42px 38px;
}
.auth-split .auth-card{
  background:transparent; border:none; box-shadow:none; padding:0;
  width:100%; max-width:380px; animation:none;
}
.auth-split .auth-card h1{ font-size:clamp(24px,3vw,29px); font-weight:800; letter-spacing:-.02em; margin-bottom:6px; }
.auth-split .auth-card .sub{ color:var(--muted); margin-bottom:22px; font-size:15px; }
.btn-social{ height:48px; }

@media (max-width:880px){
  .auth-split{ grid-template-columns:1fr; min-height:auto; margin:18px auto; }
  .auth-split .auth-aside{ display:none; }            /* keep phones focused on the form */
  .auth-split .auth-main{
    border-left:1px solid var(--border);
    border-radius:var(--radius-lg); padding:30px 22px;
  }
}

/* ===========================================================================
   ✦ CINEMATIC DARK THEME — v5  (Spaceship-inspired: near-black, charcoal
   rounded cards, huge bold white display type, muted-gray body, translucent
   pill buttons, generous negative space, auto-hiding header). Appended last
   so it overrides cleanly; every original class keeps a fallback. PHP-safe.
   =========================================================================== */
:root{
  /* surfaces — near-black + charcoal */
  --bg:#0A0A0C;
  --page:#0A0A0C;
  --soft:#141417;
  --soft-2:#1A1A1E;
  --card:#121215;
  --ink-surface:#0A0A0C;

  /* ink */
  --text:#FFFFFF;
  --ink:#FFFFFF;
  --muted:#9A9FA8;
  --faint:#6B6F78;

  /* hairlines on dark */
  --border:rgba(255,255,255,.09);
  --border-strong:rgba(255,255,255,.18);

  /* electric accent (echoes the blue hero) */
  --accent:#5B8DEF;
  --accent-hover:#7AA5F5;
  --accent-press:#4C7BE0;
  --accent-soft:rgba(91,141,239,.14);
  --accent-ring:rgba(91,141,239,.30);
  --accent-2:#7C5CFF;
  --grad:linear-gradient(135deg,#3B82F6 0%,#6366F1 55%,#7C3AED 100%);
  --grad-2:linear-gradient(135deg,#2563EB 0%,#4F46E5 100%);
  --grad-3:linear-gradient(135deg,#60A5FA 0%,#A855F7 100%);
  --flame:linear-gradient(135deg,#3B82F6,#7C3AED);
  --flame-deep:linear-gradient(135deg,#1D4ED8,#6D28D9);
  --neon-green:#5B8DEF;--neon-pink:#7C5CFF;--neon-lime:#60A5FA;

  /* glows + elevation tuned for dark */
  --glow:0 18px 50px rgba(59,130,246,.30);
  --glow-cyan:0 18px 50px rgba(124,92,255,.24);
  --shadow-sm:0 1px 2px rgba(0,0,0,.5);
  --shadow:0 16px 40px rgba(0,0,0,.45), 0 4px 14px rgba(0,0,0,.4);
  --shadow-lg:0 40px 90px rgba(0,0,0,.6), 0 14px 30px rgba(0,0,0,.45);
  --shadow-accent:0 16px 40px rgba(59,130,246,.32);

  /* rounder, more cinematic */
  --radius:22px;--radius-sm:14px;--radius-lg:30px;--pill:999px;

  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --font-display:'Plus Jakarta Sans','Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --maxw:1200px;
}

/* ---- base ---- */
html,body{background:var(--bg);}
body{font-family:var(--font);color:var(--text);line-height:1.6;letter-spacing:-.011em;
  background:radial-gradient(1200px 700px at 50% -10%,#15151B 0%,#0A0A0C 60%) no-repeat,var(--bg);}
h1,h2,h3,h4,h5,.brand{font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;color:#fff;}
a{color:inherit;}
.muted{color:var(--muted);}
.container{max-width:var(--maxw);padding:0 22px;}
section{padding:74px 0;}
@media(max-width:760px){section{padding:46px 0;}.container{padding:0 18px;}}
::selection{background:var(--accent-ring);color:#fff;}
hr{border-color:var(--border)!important;}

/* big, cinematic display headings */
.sec-head{max-width:760px;margin:0 auto 44px;}
.sec-head h2{font-size:clamp(28px,6vw,46px);line-height:1.05;font-weight:800;}
.sec-head p{color:var(--muted);font-size:clamp(15px,2vw,18px);}
.sec-head .eyebrow,.eyebrow{color:var(--accent)!important;font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:12.5px;}
.page-hero{padding:70px 0 30px;}
.page-hero h1{font-size:clamp(34px,8.5vw,60px);line-height:1.02;font-weight:800;}
.page-hero p{color:var(--muted);font-size:clamp(15px,2.2vw,19px);}
.block-head h2{font-size:clamp(20px,3vw,26px);}

/* ---- auto-hiding header (hide on scroll-down, show on scroll-up) ---- */
.site-header{
  background:rgba(10,10,12,.55);-webkit-backdrop-filter:saturate(160%) blur(18px);backdrop-filter:saturate(160%) blur(18px);
  border-bottom:1px solid transparent;
  transition:transform .45s var(--ease),background .35s var(--ease),border-color .35s var(--ease);
  will-change:transform;
}
.site-header.scrolled{background:rgba(10,10,12,.82);border-bottom-color:var(--border);}
.site-header.header-hidden{transform:translateY(-105%);}
.brand{color:#fff;font-weight:800;font-size:19px;letter-spacing:-.04em;}
.brand .dot{background:var(--grad);box-shadow:0 0 0 4px var(--accent-soft),0 0 18px rgba(59,130,246,.5);}
.nav a{color:var(--muted);font-weight:540;}
.nav a:hover,.nav a.active{color:#fff;}
.hdr-ic{color:var(--muted);}.hdr-ic:hover{color:#fff;}
.hamburger span{background:#fff;}
/* header search → translucent dark */
.hdr-search{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:var(--pill);}
.hdr-search input{background:transparent;color:#fff;}
.hdr-search input::placeholder{color:var(--faint);}
.hdr-search .go{background:var(--grad);color:#fff;border-radius:var(--pill);}
.search-pop{background:#141418;border:1px solid var(--border);box-shadow:var(--shadow-lg);}

/* mobile menu / bottom nav dark */
.mobile-menu{background:#0D0D10;border-left:1px solid var(--border);}
.mobile-menu a{color:#fff;border-bottom-color:var(--border);}
.bottom-nav{background:rgba(12,12,15,.9);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid var(--border);}
.bottom-nav a{color:var(--muted);}.bottom-nav a.active{color:#fff;}

/* ---- buttons: translucent pills + bright primary ---- */
.btn{font-family:var(--font);font-weight:620;border-radius:var(--pill);padding:13px 26px;font-size:15px;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease);}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-accent);border:none;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 50px rgba(59,130,246,.40);}
.btn-outline{background:rgba(255,255,255,.06);color:#fff;border:1px solid var(--border-strong);}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.35);color:#fff;transform:translateY(-2px);box-shadow:none;}
.btn-ghost{background:transparent;color:var(--muted);}
.btn-ghost:hover{background:rgba(255,255,255,.07);color:#fff;}
.btn-wa{background:#25D366;color:#06231A;font-weight:700;box-shadow:0 12px 30px rgba(37,211,102,.30);}
.btn-wa:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(37,211,102,.4);}
.btn-danger{background:#FF3B5C;color:#fff;}
.btn-lg{padding:16px 32px;font-size:16px;font-weight:700;}
.btn-sm{padding:9px 16px;font-size:13px;}
@media(max-width:760px){.btn{min-height:50px;}.btn-sm{min-height:40px;}}

/* ---- inputs / fields ---- */
.input,textarea.input,select.input{
  background:rgba(255,255,255,.04);border:1px solid var(--border-strong);border-radius:16px;color:#fff;
  padding:14px 16px;font-size:15px;transition:border-color .2s var(--ease),box-shadow .2s var(--ease),background .2s var(--ease);}
.input::placeholder{color:var(--faint);}
.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring);background:rgba(255,255,255,.06);}
.field label{color:#fff;font-weight:600;}
select.input option{background:#141418;color:#fff;}

/* ---- cards / surfaces: charcoal + big radius ---- */
.tpl-card,.block,.order-card,.feature,.pkg,.wiz-panel,.rail-card,.assurance .a-item,.auth-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);}
.tpl-card{overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .25s var(--ease);}
.tpl-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:rgba(255,255,255,.18);}
.tpl-body h3{color:#fff;}
.tpl-thumb{background:#0E0E11;}
.feature{padding:26px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .25s;}
.feature:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(255,255,255,.16);}
.feature h4{color:#fff;}

/* ---- packages ---- */
.packages{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:900px){.packages{grid-template-columns:1fr;max-width:460px;margin:0 auto;}}
.pkg{padding:32px 28px;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .25s;}
.pkg:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:rgba(255,255,255,.18);}
.pkg.popular{border:1.5px solid var(--accent);box-shadow:0 22px 60px rgba(59,130,246,.22);background:linear-gradient(180deg,rgba(59,130,246,.07),transparent 40%),var(--card);}
.pkg h3{color:#fff;}
.pkg .price{font-family:var(--font-display);font-size:38px;font-weight:800;letter-spacing:-.03em;color:#fff;margin:6px 0;}
.pkg ul li{color:var(--muted);}
.pkg ul li svg{color:var(--accent);}

/* ---- pills / tags / ratings ---- */
.pill{border-radius:var(--pill);}
.pill-blue,.pill.blue{background:var(--accent-soft);color:var(--accent-hover);}
.pill.green{background:rgba(37,211,102,.14);color:#34d399;}
.pill.amber{background:rgba(245,158,11,.14);color:#fbbf24;}
.tag-mini{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--border);}
.crumb,.crumb a{color:var(--muted);}.crumb a:hover{color:#fff;}

/* ---- hero carousel: cinematic, bigger ---- */
.slide{min-height:clamp(360px,52vh,520px);}
.slide h2{font-size:clamp(30px,7vw,56px);font-weight:800;letter-spacing:-.035em;}
.slide.s1{background:radial-gradient(900px 520px at 75% 10%,#1E3A8A 0%,#0B1530 45%,#07060C 100%);}
.slide.s2{background:radial-gradient(900px 520px at 25% 30%,#3B0764 0%,#190A2E 45%,#08060C 100%);}
.slide.s3{background:radial-gradient(900px 520px at 60% 90%,#0C4A6E 0%,#07223A 45%,#06070C 100%);}
.carousel{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);}
.carousel-arrow{background:rgba(0,0,0,.4);color:#fff;border:1px solid var(--border);}
.carousel-arrow:hover{background:rgba(0,0,0,.6);}
.carousel-dots button{background:rgba(255,255,255,.4);}
.carousel-dots button.on{background:#fff;}

/* ---- CTA band ---- */
.cta-band{background:linear-gradient(135deg,#10131C,#0A0A0C);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);}
.cta-band h2{color:#fff;font-size:clamp(24px,4vw,38px);}

/* ---- stats ---- */
.stat .num{font-family:var(--font-display);color:#fff;}
.stats-band,.stats-grid{color:#fff;}

/* ---- FAQ accordion (Spaceship-style: big heading, minimal rows) ---- */
.faq-item{border-bottom:1px solid var(--border);}
.faq-q{color:#fff;font-weight:600;}
.faq-a,.faq-item p{color:var(--muted);}

/* ---- footer ---- */
.site-footer{background:#0A0A0C;border-top:1px solid var(--border);}
.site-footer h5{color:#fff;}
.site-footer .muted,.site-footer p{color:var(--muted);}
.site-footer a{color:var(--muted);}.site-footer a:hover{color:#fff;}

/* ---- alerts ---- */
.alert{border-radius:14px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:#fff;}
.alert-success{background:rgba(37,211,102,.10);border-color:rgba(37,211,102,.3);color:#34d399;}
.alert-error{background:rgba(255,59,92,.10);border-color:rgba(255,59,92,.3);color:#ff7088;}
.alert-info{background:var(--accent-soft);border-color:var(--accent-ring);color:var(--accent-hover);}

/* ---- auth pages on dark (form panel) ---- */
.auth-split .auth-main{background:var(--card);border-color:var(--border);box-shadow:var(--shadow-lg);}
.auth-split .auth-card h1{color:#fff;}
.auth-split .auth-card .sub{color:var(--muted);}
.auth-aside{background:linear-gradient(155deg,#0E1224 0%,#161033 55%,#0A0A12 100%)!important;}
.btn-social{background:rgba(255,255,255,.05);border:1px solid var(--border-strong);color:#fff;}
.btn-social:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3);}
.auth-divider{color:var(--faint);}
.auth-divider::before,.auth-divider::after{background:var(--border);}

/* ---- preloader (dark) ---- */
.preloader{background:#0A0A0C;}
.pl-logo{color:#fff;}.pl-dot{background:var(--grad);}
.pl-bar{background:rgba(255,255,255,.1);}.pl-bar span{background:var(--grad);}

/* ---- misc surfaces ---- */
.dot{background:var(--grad);}
.cat-tile span{color:var(--muted);}
.cat-tile:hover{background:rgba(255,255,255,.05);}
.thumb-pick{border-color:var(--border)!important;}
.kv,.kv b,.mono{color:#fff;}
.empty{color:var(--muted);}

/* scroll reveal — slightly more cinematic rise */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
[data-reveal].reveal-visible{opacity:1;transform:none;}

/* ===========================================================================
   ✦ v5.1 — REMOVE ALL NON-TEXT WHITE
   Keep text white; convert every remaining white surface / fill / dot to dark
   or accent so nothing else reads as white on the dark theme.
   =========================================================================== */
/* page hero bands (about / faq / packages / contact / template) */
.page-hero{background:transparent;border-bottom:1px solid var(--border);}

/* all remaining white component surfaces -> charcoal card */
.cat-chip,.step,.showcase .shot,.review,.newsletter,.faq-item,
.contact-card,.review-form,.flash,.block,.order-card{
  background:var(--card)!important;border:1px solid var(--border);color:var(--text);}
.faq-item{border-radius:16px;}
.step h4,.review b,.newsletter h3,.contact-card b,.review-form h3,.showcase .shot{color:#fff;}
.cat-chip{color:var(--muted);}
.cat-chip.active,.cat-chip:hover{background:var(--accent-soft);color:var(--accent-hover);border-color:var(--accent-ring);}

/* homepage search bar -> dark glass (text stays white via .input) */
.searchbar{background:rgba(255,255,255,.05);border:1px solid var(--border-strong);}

/* template card badges / favourite button -> dark glass, white glyph */
.tpl-badge{background:rgba(0,0,0,.55);color:#fff;border:1px solid var(--border);}
.tpl-fav{background:rgba(0,0,0,.5);color:#fff;border:1px solid var(--border);}
.tpl-fav:hover,.tpl-fav.is-fav{color:#FF6B81;}

/* carousel dots: faint -> muted, active -> accent (not white) */
.carousel-dots button{background:rgba(255,255,255,.30);}
.carousel-dots button.on{background:var(--accent);}

/* light amber pill -> dark amber */
.pill-amber{background:rgba(245,158,11,.16);color:#FBBF24;}

/* outline/social buttons: glass, not white */
.btn-outline{background:rgba(255,255,255,.05);}
.btn-outline:hover{background:rgba(255,255,255,.10);}
.btn-social{background:rgba(255,255,255,.05);}

/* auth-aside logo dot: accent, not white gradient */
.auth-aside .auth-logo .dot{background:var(--grad)!important;box-shadow:0 0 0 4px rgba(91,141,239,.18);}

/* tpl thumbnail backdrop stays dark */
.tpl-thumb,.shot{background:#0E0E11;}

/* keep header search dark even on focus */
.hdr-search:focus-within{background:rgba(255,255,255,.08);border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-ring);}
.searchbar:focus-within{background:rgba(255,255,255,.08);border-color:var(--accent);}

/* CTA-band outline button: dark glass on hover, not white */
.cta-band .btn-outline{background:rgba(255,255,255,.06);border-color:var(--border-strong);color:#fff;}
.cta-band .btn-outline:hover{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.4);}

/* hero-slide button: glass, not white fill */
.slide .btn-outline{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.45);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-weight:700;}
.slide .btn-outline:hover{background:rgba(255,255,255,.24);color:#fff;}
/* hamburger lines: light gray, not pure white */
.hamburger span{background:var(--muted);}
.hamburger.active span{background:#fff;}
