/* =====================================================
   DialerNumber.xyz — Light WhatsApp-inspired theme
   Palette: WA green + chat-bubble cream + clean white
   ===================================================== */

:root{
  --wa-green:        #25D366;
  --wa-green-dark:   #128C7E;
  --wa-teal:         #075E54;
  --wa-bubble:       #DCF8C6;
  --wa-bubble-dark:  #c5edaa;
  --wa-blue:         #34B7F1;
  --wa-bg:           #ECE5DD;

  --bg:           #FFFFFF;
  --surface:      #FFFFFF;
  --surface-2:    #F7F9FA;
  --surface-3:    #EFF3F4;
  --line:         #E5E9EB;
  --line-soft:    #EEF2F4;
  --text:         #111B21;
  --text-soft:    #3B4A54;
  --muted:        #667781;

  --grad: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  --grad-soft: linear-gradient(135deg, #DCF8C6 0%, #c5edaa 100%);
  --grad-text: linear-gradient(90deg, #25D366 0%, #128C7E 50%, #075E54 100%);

  --r:14px; --r-sm:10px; --r-lg:18px;
  --shadow:0 8px 28px -10px rgba(7,94,84,.18), 0 2px 6px rgba(7,94,84,.06);
  --shadow-soft: 0 4px 14px -6px rgba(7,94,84,.1);
  --shadow-green: 0 10px 30px -10px rgba(37,211,102,.4);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{height:100%}
body{
  /* System-font stack — zero external requests, native rendering on every OS.
     Emoji fonts at the end so flags + symbols render reliably across Windows/Mac/Linux. */
  font-family:-apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, Roboto, 'Helvetica Neue', Arial,
              'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol', 'Noto Color Emoji', sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(900px 500px at 90% -10%, rgba(37,211,102,.06), transparent 60%),
    radial-gradient(700px 400px at -10% 30%, rgba(52,183,241,.04), transparent 60%);
  background-attachment:fixed;
  /* Sticky-footer pattern */
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
.site-footer{margin-top:auto !important}
a{color:var(--wa-green-dark);text-decoration:none}
a:hover{color:var(--wa-teal); text-decoration:underline}
img,svg{display:block;max-width:100%}
code{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:.92em; background:#f0f5f7; border:1px solid var(--line); padding:.1em .4em; border-radius:6px; color:var(--wa-teal); word-break:break-all}
hr{border:0;border-top:1px solid var(--line); margin:1rem 0}

.container{max-width:1200px; margin:0 auto; padding:0 1.25rem}
.container.narrow{max-width:820px}
.center{text-align:center}
.muted{color:var(--muted)}
.small{font-size:.875rem}
.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.5rem}
.pt-0{padding-top:0}

/* =================== TOP BAR =================== */
.topbar{background:var(--wa-teal); color:#e7f0ee; font-size:.82rem}
.topbar a{color:#fff; font-weight:600}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;padding:.45rem 1.25rem; flex-wrap:wrap; gap:.5rem}
.dot{display:inline-block;width:8px;height:8px;border-radius:50%; margin-right:.4rem; vertical-align:middle}
.dot-live{background:var(--wa-green); box-shadow:0 0 0 0 rgba(37,211,102,.6); animation:pulse 1.6s ease-out infinite}
.dot-warn{background:#f59e0b}
.dot-err{background:#ef4444}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.6)}70%{box-shadow:0 0 0 10px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* =================== HEADER =================== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
}
.header-inner{display:flex;align-items:center;gap:2rem;padding:.85rem 1.25rem}
.logo{display:flex;align-items:center;gap:.65rem;color:var(--text);font-weight:700;letter-spacing:-.01em; text-decoration:none}
.logo:hover{text-decoration:none}
.logo-mark svg{filter:drop-shadow(0 4px 12px rgba(37,211,102,.35))}
.logo-mark-img{
  width:28px; height:28px; flex-shrink:0; object-fit:contain;
  filter:drop-shadow(0 2px 6px rgba(37,211,102,.25));
}
.logo-text{font-size:1.05rem; line-height:1; letter-spacing:-.01em}
.logo-light{font-weight:500;color:var(--text-soft)}
.logo-bold{font-weight:800;color:var(--wa-teal)}

.nav-main{display:flex;gap:1.75rem;flex:1;justify-content:center}
.nav-main a{
  color:var(--text); font-weight:700; font-size:1rem; letter-spacing:-.005em;
  padding:.55rem .35rem; position:relative; text-decoration:none;
  transition:color .15s;
}
.nav-main a:hover{color:var(--wa-green-dark)}
.nav-main a::after{
  content:''; position:absolute; left:50%; right:50%; bottom:-6px; height:3px;
  background:var(--grad); border-radius:3px; transition:left .2s ease, right .2s ease;
}
.nav-main a:hover::after{left:0; right:0}
.nav-main a.active{color:var(--wa-green-dark)}
.nav-main a.active::after{left:0; right:0; height:3px; box-shadow:0 2px 6px rgba(37,211,102,.35)}

.nav-cta{display:flex;align-items:center;gap:.5rem}
.nav-toggle{display:none; background:transparent;border:1px solid var(--line); color:var(--text); padding:.4rem .65rem; border-radius:8px; font-size:1.1rem; cursor:pointer; line-height:1}
.nav-mobile-only{display:none}
@media (max-width: 880px){
  .header-inner{gap:.5rem; padding:.7rem 1rem}
  .nav-main{
    display:none; position:absolute; top:100%; left:0; right:0;
    background:#fff; flex-direction:column; gap:0;
    padding:.25rem 1rem 1rem;
    border-bottom:1px solid var(--line); box-shadow:var(--shadow-soft);
    max-height:calc(100vh - 64px); overflow-y:auto;
  }
  .nav-main.open{display:flex}
  .nav-main > a{padding:.85rem .25rem; border-bottom:1px solid var(--line-soft)}
  .nav-main > a.active::after{display:none}
  .nav-main > a.active{color:var(--wa-green-dark); font-weight:600}
  .nav-toggle{display:inline-flex; align-items:center; justify-content:center}
  .nav-cta{margin-left:auto; gap:.35rem}
  /* On mobile, only the cart icon remains in the top-right CTA strip;
     all other auth buttons are surfaced inside the drawer's .nav-mobile-only block. */
  .nav-cta > :not(.cart-btn){display:none}
  .nav-mobile-only{
    display:flex; flex-direction:column;
    margin-top:.5rem; padding-top:.85rem;
    border-top:1px solid var(--line);
  }
  .nav-mobile-only a{
    padding:.85rem .25rem; color:var(--text-soft); font-weight:500;
    border-bottom:1px solid var(--line-soft); text-decoration:none;
  }
  .nav-mobile-only a:last-child{border-bottom:none}
  .nav-mobile-only a.nav-mobile-cta{
    margin-top:.6rem; padding:.75rem 1rem;
    background:var(--grad); color:#fff; text-align:center;
    border-radius:10px; font-weight:700; border:none;
    box-shadow:var(--shadow-green);
  }
}

/* =================== BUTTONS =================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45rem;
  padding:.7rem 1.2rem;border-radius:10px;font-weight:600;font-size:.95rem;
  border:1px solid transparent; cursor:pointer; transition:all .18s ease;
  text-decoration:none; line-height:1; white-space:nowrap;
}
.btn:hover{text-decoration:none}
.btn-sm{padding:.5rem .85rem;font-size:.85rem}
.btn-lg{padding:.9rem 1.6rem;font-size:1rem}
.btn-block{display:flex;width:100%}
.btn-primary{background:var(--grad);color:#fff;box-shadow:var(--shadow-green)}
.btn-primary:hover{transform:translateY(-1px); box-shadow:0 14px 36px -10px rgba(37,211,102,.5); color:#fff}
.btn-outline{background:transparent;border:1px solid var(--line); color:var(--text)}
.btn-outline:hover{border-color:var(--wa-green-dark); color:var(--wa-green-dark); background:rgba(37,211,102,.05)}
.btn-ghost{background:transparent; color:var(--text-soft)}
.btn-ghost:hover{color:var(--text); background:var(--surface-3)}

/* =================== FLASH =================== */
.flash{margin:1rem 0; padding:.85rem 1.1rem; border-radius:10px; border:1px solid; display:flex; align-items:center; gap:.6rem; font-weight:500; animation:slideDown .4s ease}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.flash-success{background:#e7f9ef; border-color:#b7e7c8; color:#0d6e3a}
.flash-error  {background:#fdecec; border-color:#f5b8b8; color:#8a1a1a}
.flash-info   {background:#e6f5fb; border-color:#b9dff0; color:#0c5a83}

/* =================== HERO =================== */
.hero{position:relative; padding:3.5rem 0 4.5rem; overflow:hidden; background:linear-gradient(180deg, #f6fbf8 0%, transparent 100%)}
.hero-inner{display:grid;grid-template-columns:1.3fr 1fr;gap:3rem;align-items:center}
.chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:999px;background:#e7f9ef;border:1px solid #b7e7c8;color:#0d6e3a;font-size:.8rem;font-weight:600;margin-bottom:1.25rem}
.hero-title{font-size:clamp(2.1rem, 4.2vw, 3.4rem); line-height:1.05; margin:0 0 1.1rem; font-weight:800; letter-spacing:-.025em; color:var(--text)}
.grad-text{background:var(--grad-text); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.hero-sub{font-size:1.1rem; color:var(--text-soft); max-width:600px; margin:0 0 1.75rem}
.hero-cta{display:flex;gap:.7rem;flex-wrap:wrap}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-top:2.25rem;padding-top:1.75rem;border-top:1px solid var(--line)}
.hero-stats div{display:flex;flex-direction:column;gap:.25rem}
.hero-stats strong{font-size:1.5rem;font-weight:800;color:var(--wa-green-dark); font-feature-settings:"tnum"}
.hero-stats span{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* Data preview card — replaces WA mockup */
.hero-card-wrap{position:relative}
.data-preview{
  background:#fff;
  border:1px solid var(--line);
  border-radius:14px;
  overflow:hidden;
  box-shadow:var(--shadow);
  max-width:440px; margin-left:auto;
}
.data-preview-head{
  display:flex;align-items:center;gap:.85rem;
  padding:.95rem 1.1rem;
  background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%);
  border-bottom:1px solid var(--line);
}
.dp-icon{font-size:1.5rem}
.dp-meta{flex:1; min-width:0}
.dp-title{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:.95rem; font-weight:700; color:var(--text)}
.dp-sub{font-size:.75rem; color:var(--muted); margin-top:.1rem}
.dp-status{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;background:#e7f9ef;color:#0d6e3a;border-radius:999px;font-size:.72rem;font-weight:700}

.data-preview-body{padding:.5rem .25rem}
.dp-row{
  display:grid;
  grid-template-columns:32px 1fr auto auto;
  align-items:center; gap:.7rem;
  padding:.55rem .85rem;
  border-bottom:1px solid var(--line-soft);
  font-size:.85rem;
}
.dp-row:last-child{border-bottom:none}
.dp-row-head{
  font-size:.65rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; font-weight:700;
  padding:.45rem .85rem;
  background:var(--surface-2);
}
.dp-row-head span{font-family:inherit}
.dp-flag{width:28px; height:20px; object-fit:cover; border-radius:3px; box-shadow:0 1px 2px rgba(0,0,0,.15)}
.dp-phone{font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; color:var(--text); font-weight:600; letter-spacing:.02em}
.dp-name{color:var(--text-soft); font-weight:500; white-space:nowrap}
.dp-tag{display:inline-flex;align-items:center;justify-content:center; min-width:24px; padding:.15rem .4rem; border-radius:5px; font-size:.78rem; font-weight:800}
.dp-tag-ok{background:#e7f9ef; color:#0d6e3a}
.dp-row-more{display:block; padding:.55rem .85rem; color:var(--muted); font-style:italic; font-size:.78rem; text-align:center; background:var(--surface-2)}

.data-preview-foot{
  display:flex; flex-wrap:wrap; gap:.6rem .85rem;
  padding:.85rem 1.1rem;
  background:linear-gradient(180deg, #fff, #f6fbf8);
  border-top:1px solid var(--line);
}
.dp-check{font-size:.74rem; color:var(--wa-green-dark); font-weight:700}

@media (max-width: 880px){
  .hero-inner{grid-template-columns:1fr}
  .hero-stats{grid-template-columns:repeat(2,1fr)}
  .data-preview{margin:0 auto}
}
@media (max-width: 480px){
  .dp-name{display:none}
  .dp-row{grid-template-columns:32px 1fr auto}
}

/* =================== SECTIONS =================== */
.section{padding:3rem 0}
.section-alt{background:var(--surface-2)}
.section-title{font-size:1.85rem;font-weight:800;margin:0 0 .4rem;letter-spacing:-.02em;color:var(--text)}
.section-sub{color:var(--text-soft); margin:0 0 2rem; font-size:1.02rem}
.section-head-row{display:flex;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}
.section-head-row .section-title{margin-bottom:.25rem}
.section-head-row .section-sub{margin-bottom:0}

.grid{display:grid;gap:1.25rem}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* =================== FEATURE CARDS =================== */
.feature-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:1.5rem; transition:all .25s; box-shadow:var(--shadow-soft); position:relative; overflow:hidden;
}
.feature-card::after{content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--grad); opacity:0; transition:opacity .25s}
.feature-card:hover{transform:translateY(-3px); box-shadow:var(--shadow); border-color:#b7e7c8}
.feature-card:hover::after{opacity:1}
.feature-icon{font-size:2rem; margin-bottom:.65rem}
.feature-card h3{margin:0 0 .4rem; font-size:1.08rem; color:var(--text)}
.feature-card p{margin:0; color:var(--text-soft); font-size:.93rem}

/* =================== COUNTRY GRID =================== */
.country-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}
.country-grid-large{grid-template-columns:repeat(3,1fr)}
@media(max-width:980px){.country-grid,.country-grid-large{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.country-grid,.country-grid-large{grid-template-columns:1fr}}
.country-card{
  display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm);
  color:var(--text); transition:all .2s; box-shadow:var(--shadow-soft); text-decoration:none;
}
.country-card:hover{border-color:var(--wa-green-dark); transform:translateY(-2px); box-shadow:var(--shadow); color:var(--text); text-decoration:none}
.country-flag-img{
  width:48px; height:36px; flex-shrink:0;
  border-radius:5px; object-fit:cover;
  box-shadow:0 1px 3px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.06);
}
.country-flag{font-size:2.2rem; line-height:1; flex-shrink:0; width:48px; text-align:center}
.country-info{display:flex;flex-direction:column;flex:1;min-width:0; gap:.15rem}
.country-name{font-weight:700; font-size:.98rem; display:flex;align-items:center;gap:.4rem; flex-wrap:wrap}
.country-region{font-size:.74rem;color:var(--muted); text-transform:uppercase; letter-spacing:.04em; font-weight:600}
.country-stats{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0; line-height:1.1}
.cs-num{font-weight:800;font-size:1.05rem;color:var(--wa-green-dark)}
.cs-lbl{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em; font-weight:700}
.hot-pill{display:inline-block;padding:.08rem .4rem;border-radius:5px;background:#fff3e0;color:#e65100;font-size:.6rem;font-weight:800;letter-spacing:.05em}

/* ===== Region chip filter bar ===== */
.chip-bar{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1rem}
.chip-filter{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.45rem .85rem; background:var(--surface); border:1px solid var(--line);
  border-radius:999px; color:var(--text-soft); font-size:.85rem; font-weight:600;
  text-decoration:none; transition:all .15s;
}
.chip-filter:hover{border-color:var(--wa-green-dark); color:var(--wa-green-dark); background:#f6fbf8; text-decoration:none}
.chip-filter.active{background:var(--grad); color:#fff; border-color:transparent; box-shadow:var(--shadow-green)}
.chip-filter.active:hover{color:#fff}
.chip-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;padding:.05rem .35rem;background:rgba(0,0,0,.08);border-radius:999px;font-size:.7rem;font-weight:700}
.chip-filter.active .chip-count{background:rgba(255,255,255,.2)}

/* ===== Search bar ===== */
.searchbar{
  display:flex; gap:.5rem; padding:.5rem; background:var(--surface); border:1px solid var(--line);
  border-radius:12px; box-shadow:var(--shadow-soft); margin-bottom:1rem; flex-wrap:wrap;
}
.searchbar-input{flex:1; min-width:240px; display:flex;align-items:center;gap:.5rem;padding:0 .9rem;background:var(--surface-2);border-radius:8px}
.searchbar-input svg{color:var(--muted); flex-shrink:0}
.searchbar-input input{
  flex:1; border:none; background:transparent; padding:.65rem 0;
  font-size:.95rem; font-family:inherit; color:var(--text); outline:none;
}
.searchbar-input input::placeholder{color:var(--muted)}
.searchbar-sort{
  padding:.65rem .85rem; border:1px solid var(--line); border-radius:8px;
  background:var(--surface); font-family:inherit; font-size:.9rem; color:var(--text); cursor:pointer;
}
.searchbar-sort:focus{outline:none; border-color:var(--wa-green); box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.searchbar .btn{padding-left:1.4rem; padding-right:1.4rem}
@media(max-width:680px){
  .searchbar-input{width:100%}
  .searchbar .btn, .searchbar-sort{flex:1}
}

/* ===== Result count ===== */
.result-meta{padding:.5rem .25rem 1.25rem; color:var(--text-soft); font-size:.92rem}
.result-meta strong{color:var(--text)}

/* ===== Pagination ===== */
.pagination{
  display:flex; align-items:center; justify-content:center; gap:.35rem;
  padding:2.5rem 0 1rem; flex-wrap:wrap;
}
.page-btn{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:40px; padding:.55rem .85rem;
  background:var(--surface); border:1px solid var(--line); border-radius:8px;
  color:var(--text-soft); font-weight:600; font-size:.9rem;
  text-decoration:none; transition:all .15s;
}
.page-btn:hover{border-color:var(--wa-green-dark); color:var(--wa-green-dark); background:#f6fbf8; text-decoration:none}
.page-btn.active{background:var(--grad); color:#fff; border-color:transparent; box-shadow:var(--shadow-green)}
.page-btn.active:hover{color:#fff}
.page-btn.disabled{color:var(--muted); cursor:not-allowed; opacity:.5}
.page-btn.disabled:hover{border-color:var(--line); color:var(--muted); background:var(--surface)}
.page-ellipsis{padding:.55rem .35rem; color:var(--muted)}

/* =================================================================
   COUNTRY DETAIL — PROFESSIONAL PRODUCT PAGE v2
   Full-width hero + trust strip + 2-col (configurator + sticky summary)
   + 3-col includes + FAQ + related
   ================================================================= */
.product-hero{padding:2rem 0 1.25rem}
.product-hero-grid{
  display:grid; grid-template-columns:auto 1fr; gap:2rem; align-items:center;
  padding:1.75rem 2rem;
  background:linear-gradient(135deg, #f6fbf8 0%, #ffffff 50%, #f6fbf8 100%);
  border:1px solid #b7e7c8; border-radius:18px;
  box-shadow:0 8px 28px -12px rgba(7,94,84,.15);
}
@media(max-width:880px){.product-hero-grid{grid-template-columns:1fr; padding:1.25rem 1.25rem}}
.product-hero-flag img{
  width:180px; max-height:135px; object-fit:cover;
  border-radius:10px;
  box-shadow:0 10px 28px -8px rgba(0,0,0,.25), 0 0 0 1px rgba(0,0,0,.06);
}
.product-hero-eyebrow{
  font-size:.78rem; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em;
  display:inline-flex; align-items:center; gap:.5rem; flex-wrap:wrap;
}
.bc-sep{color:var(--muted)}
.product-hero-title{
  margin:.5rem 0 .5rem; font-size:2rem; font-weight:800;
  color:var(--text); letter-spacing:-.025em; line-height:1.1;
}
.product-hero-sub{margin:0 0 1rem; color:var(--text-soft); font-size:1rem; max-width:640px}
.product-hero-stats{display:flex; gap:2rem; flex-wrap:wrap; padding-top:.5rem; border-top:1px dashed rgba(7,94,84,.15); margin-top:.25rem}
.product-hero-stats div{display:flex; flex-direction:column; gap:.1rem}
.product-hero-stats strong{font-size:1.4rem; font-weight:800; color:var(--wa-green-dark); font-feature-settings:"tnum"; line-height:1}
.product-hero-stats span{font-size:.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:600}
.ml-1{margin-left:.4rem}

/* Trust strip below hero */
.trust-strip{
  display:flex; justify-content:center; gap:.5rem; flex-wrap:wrap;
  margin:1rem 0; padding:.6rem .85rem;
}
.trust-badge{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.35rem .75rem; background:#fff; border:1px solid var(--line); border-radius:999px;
  font-size:.78rem; font-weight:600; color:var(--text-soft);
  box-shadow:0 2px 6px -2px rgba(0,0,0,.05);
}
.trust-badge svg{color:var(--wa-green-dark); flex-shrink:0}

/* Two-column product body */
.product-body{padding:1.25rem 0 2.5rem}
.product-grid{display:grid; grid-template-columns:1fr 360px; gap:2rem; align-items:start}
@media(max-width:980px){.product-grid{grid-template-columns:1fr}}

.product-config{display:flex; flex-direction:column; gap:1.5rem}

/* Step blocks */
.config-step{
  background:#fff; border:1px solid var(--line); border-radius:14px;
  padding:1.5rem 1.5rem;
  box-shadow:0 4px 12px -4px rgba(0,0,0,.05);
}
.config-step-head{display:flex; align-items:center; gap:.7rem; flex-wrap:wrap; margin-bottom:1rem}
.config-step-num{
  display:inline-flex; align-items:center; justify-content:center;
  width:32px; height:32px; border-radius:50%;
  background:var(--grad); color:#fff; font-weight:800; font-size:.95rem;
  box-shadow:var(--shadow-green); flex-shrink:0;
}
.config-step-title{margin:0; font-size:1.15rem; flex:1; min-width:200px}
.config-step-hint{font-size:.82rem; color:var(--muted); flex-basis:100%}
.config-step-hint strong{color:var(--text)}

/* Custom calc — collapsed by default */
.custom-calc-details{
  border:1px dashed #b7e7c8; border-radius:10px; background:#f6fbf8;
}
.custom-calc-details summary{
  cursor:pointer; padding:.7rem 1rem; font-size:.92rem; color:var(--text-soft);
  list-style:none;
}
.custom-calc-details summary::-webkit-details-marker{display:none}
.custom-calc-details summary::before{content:'▸ '; color:var(--wa-green-dark); margin-right:.2rem}
.custom-calc-details[open] summary::before{content:'▾ '}
.custom-calc-details[open] summary{border-bottom:1px solid #b7e7c8; margin-bottom:0}
.custom-calc-details .custom-calc{border:none; background:transparent; padding:.85rem 1rem 1rem}

/* ===== STICKY ORDER SUMMARY ===== */
.product-summary{position:sticky; top:80px}
@media(max-width:980px){.product-summary{position:static}}
.summary-card{
  background:#fff; border:2px solid var(--wa-green); border-radius:16px;
  padding:1.5rem;
  box-shadow:0 12px 32px -10px rgba(37,211,102,.25);
}
.summary-card-head{display:flex; justify-content:space-between; align-items:center; gap:.5rem; margin-bottom:1rem; padding-bottom:.85rem; border-bottom:1px solid var(--line-soft)}
.summary-card-head h3{margin:0; font-size:1.05rem}
.summary-flag{display:inline-flex; align-items:center; gap:.4rem; font-size:.85rem; font-weight:600; color:var(--text-soft)}
.summary-flag img{border-radius:3px; box-shadow:0 1px 2px rgba(0,0,0,.15)}

.summary-row{display:flex; justify-content:space-between; align-items:baseline; padding:.4rem 0; gap:.5rem; font-size:.92rem}
.summary-row strong{color:var(--text); font-weight:700; text-align:right}
.summary-row-sub{padding-top:0; padding-bottom:.6rem}
.summary-label{color:var(--muted); font-size:.82rem; flex-shrink:0}

.summary-hr{border:0; border-top:1px solid var(--line-soft); margin:.5rem 0 .85rem}
.summary-total{display:flex; justify-content:space-between; align-items:baseline; gap:.5rem}
.summary-total > span:first-child{font-size:.95rem; color:var(--text-soft); text-transform:uppercase; letter-spacing:.05em; font-weight:700}
.summary-total-amount{font-size:2rem; font-weight:800; color:var(--wa-green-dark); font-feature-settings:"tnum"; line-height:1}

.summary-meta{margin-top:1.1rem; padding-top:.85rem; border-top:1px solid var(--line-soft); display:flex; flex-direction:column; gap:.45rem}
.summary-meta-row{font-size:.78rem; color:var(--text-soft); line-height:1.45}
.summary-meta-row strong{color:var(--text)}

.summary-help{margin-top:1rem; text-align:center; line-height:1.5}

/* ===== INCLUDES (3-col) ===== */
.product-includes{padding:1.5rem 0}
.include-card{height:100%}
.include-card .include-icon{font-size:1.8rem; margin-bottom:.4rem}
.include-card h3{margin:0 0 .55rem; font-size:1.05rem}

/* ===== FAQ ===== */
.product-faq{padding:1.5rem 0 2.5rem}
.faq-grid{display:grid; grid-template-columns:1fr 1fr; gap:.75rem}
@media(max-width:680px){.faq-grid{grid-template-columns:1fr}}
.faq-item{background:#fff; border:1px solid var(--line); border-radius:10px; padding:.95rem 1.15rem; box-shadow:0 2px 6px -2px rgba(0,0,0,.04)}
.faq-item[open]{border-color:var(--wa-green-dark); background:#f6fbf8}
.faq-item summary{cursor:pointer; font-weight:600; color:var(--text); list-style:none; font-size:.95rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+'; float:right; color:var(--wa-green-dark); font-weight:800; font-size:1.2rem; line-height:1}
.faq-item[open] summary::after{content:'−'}
.faq-item p{margin:.7rem 0 0; color:var(--text-soft); font-size:.9rem; line-height:1.6}
.faq-item a{color:var(--wa-green-dark); font-weight:600}

/* Related grid spacing */
.product-related{padding:1.5rem 0 2.5rem}

/* ===== Sales-psychology starter nudge (above buy form) ===== */
.starter-nudge{
  display:flex; align-items:center; gap:1rem; padding:.95rem 1.2rem;
  background:linear-gradient(135deg, #fffbeb 0%, #fef9d8 100%);
  border:1px solid #fcd34d; border-radius:10px;
  flex-wrap:wrap; justify-content:space-between;
}
.starter-nudge strong{color:#92400e}
.starter-nudge > div{flex:1; min-width:240px; color:#78350f; font-size:.92rem}

/* ===== Custom-volume calculator ===== */
.custom-calc{padding:1rem 1.1rem; background:#f6fbf8; border:1px dashed #b7e7c8; border-radius:10px}
.custom-calc-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;flex-wrap:wrap;margin-bottom:.6rem}
.custom-calc-head h4{margin:0}
.custom-calc-row{display:flex; align-items:center; gap:.5rem; flex-wrap:wrap}
.custom-calc-row #customQty{
  flex:1; min-width:180px; padding:.6rem .9rem;
  border:1px solid var(--line); border-radius:8px;
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:1rem; font-weight:700; color:var(--text);
}
.custom-calc-row #customQty:focus{outline:none;border-color:var(--wa-green);box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.custom-calc-unit{color:var(--muted); font-size:.88rem}
.custom-calc-result{
  margin-top:.7rem; padding:.7rem .85rem; border-radius:8px;
  font-size:.88rem; line-height:1.45;
}
.custom-calc-result.hidden{display:none}
.custom-calc-result.custom-calc-ok    {background:#e7f9ef; border:1px solid #b7e7c8; color:#0d6e3a}
.custom-calc-result.custom-calc-error {background:#fdecec; border:1px solid #f5b8b8; color:#8a1a1a}
.custom-calc-result.custom-calc-info  {background:#e6f5fb; border:1px solid #b9dff0; color:#0c5a83}

/* Delivery note under the buy bar */
.delivery-note{
  margin:.85rem 0 0; padding:.7rem .9rem;
  background:#f6fbf8; border-left:3px solid var(--wa-green);
  border-radius:6px; font-size:.85rem; color:var(--text-soft);
}
.delivery-note strong{color:var(--wa-teal)}

/* ===== Toast notifications ===== */
.toast-container{
  position:fixed; bottom:18px; right:18px; z-index:1000;
  display:flex; flex-direction:column; gap:.5rem; max-width:380px;
  pointer-events:none;
}
.toast{
  background:#fff; border:1px solid var(--line); border-radius:10px;
  padding:.85rem 1.1rem; font-size:.9rem; line-height:1.5;
  box-shadow:0 12px 32px -10px rgba(0,0,0,.25), 0 2px 6px rgba(0,0,0,.08);
  opacity:0; transform:translateY(12px); transition:all .3s cubic-bezier(.2,.8,.2,1);
  pointer-events:auto; cursor:pointer;
  border-left:4px solid var(--muted);
}
.toast.toast-show{opacity:1; transform:translateY(0)}
.toast-success{border-left-color:#10b981; color:#065f46}
.toast-error  {border-left-color:#ef4444; color:#7f1d1d}
.toast-info   {border-left-color:#34B7F1; color:#0c5a83}
.toast-warn   {border-left-color:#f59e0b; color:#78350f}
.toast a{color:inherit; font-weight:700; text-decoration:underline}

/* ===== Country detail — PRO hero (flag + info + price chip) ===== */
.country-hero-pro{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:1.75rem;
  padding:1.75rem 2rem;
  background:linear-gradient(135deg, #f6fbf8 0%, #ffffff 60%, #f6fbf8 100%);
  border:1px solid #b7e7c8;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-soft);
  align-items:center;
}
.country-hero-pro-flag img{
  width:160px; height:auto; max-height:120px; object-fit:cover;
  border-radius:10px;
  box-shadow:0 8px 24px -8px rgba(0,0,0,.25), 0 0 0 1px rgba(0,0,0,.08);
}
.country-hero-pro-info{min-width:0}
.country-hero-pro-eyebrow{
  font-size:.78rem; font-weight:700; color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em;
  display:flex; align-items:center; flex-wrap:wrap;
}
.country-hero-pro-title{
  margin:.25rem 0 .25rem; font-size:1.7rem; font-weight:800;
  color:var(--text); letter-spacing:-.02em; line-height:1.15;
}
.country-hero-pro-note{margin:.25rem 0 .75rem; color:var(--text-soft); font-size:.95rem; max-width:520px}
.country-hero-pro-stats{display:flex;gap:1.5rem;flex-wrap:wrap;margin-top:.75rem}
.country-hero-pro-stats div{display:flex;flex-direction:column;gap:.1rem}
.country-hero-pro-stats strong{font-size:1.3rem;font-weight:800;color:var(--wa-green-dark);font-feature-settings:"tnum";line-height:1}
.country-hero-pro-stats span{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.country-hero-pro-pricing{
  display:flex; flex-direction:column; align-items:center;
  background:#fff; border:2px solid var(--wa-green); border-radius:14px;
  padding:1.1rem 1.4rem; min-width:200px;
  box-shadow:var(--shadow-green);
  text-align:center;
}
.price-from{font-size:.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; font-weight:700}
.price-from-amount{font-size:2.4rem; font-weight:800; color:var(--wa-green-dark); line-height:1; font-feature-settings:"tnum"; margin:.15rem 0}
.price-from-unit{font-size:.78rem; color:var(--muted)}

@media(max-width: 880px){
  .country-hero-pro{grid-template-columns:1fr; padding:1.25rem 1.25rem}
  .country-hero-pro-flag img{width:120px}
  .country-hero-pro-pricing{width:100%}
}

/* Sub-headings inside cards */
.muted-h4{margin:0 0 .65rem; font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:700}

/* Country detail header (legacy class, used elsewhere) */
.country-hero{display:flex;align-items:center;gap:1.75rem;padding:1.75rem;background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--shadow-soft); flex-wrap:wrap}
.country-hero-flag-img{
  width:140px; height:auto; flex-shrink:0;
  border-radius:8px; box-shadow:0 6px 20px -6px rgba(0,0,0,.25), 0 0 0 1px rgba(0,0,0,.08);
}
.country-hero-flag{font-size:5rem; line-height:1; flex-shrink:0}
.country-hero-info{flex:1; min-width:240px}
.country-hero-info h1{margin:0 0 .25rem;font-size:1.9rem; font-weight:800}
.country-hero-info h1 .small{font-size:.7rem;color:var(--muted);font-weight:500}
.country-hero-stats{display:flex;gap:1.5rem;margin-top:.85rem}
.country-hero-stats div{display:flex;flex-direction:column;gap:.15rem}
.country-hero-stats strong{font-size:1.35rem;font-weight:800;color:var(--wa-green-dark);font-feature-settings:"tnum"}
.country-hero-stats span{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}

/* =================== TIER GRID =================== */
.tier-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.tier-grid-pick{grid-template-columns:repeat(4,1fr);gap:.6rem}
@media(max-width:980px){.tier-grid,.tier-grid-pick{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.tier-grid,.tier-grid-pick{grid-template-columns:1fr}}
.tier-card{
  display:flex;flex-direction:column;align-items:center;gap:.35rem;padding:1.5rem 1.25rem;
  background:var(--surface); border:2px solid var(--line); border-radius:var(--r);
  text-align:center; position:relative; box-shadow:var(--shadow-soft); transition:all .2s;
}
.tier-card:hover{transform:translateY(-3px); box-shadow:var(--shadow)}
.tier-popular{border-color:var(--wa-green); box-shadow:var(--shadow-green)}
.tier-free{border-color:#fbbf24; background:linear-gradient(180deg, #fffbeb 0%, #fff 100%)}
.tier-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:.25rem .7rem;background:var(--grad);color:#fff;font-size:.68rem;font-weight:800;border-radius:6px;letter-spacing:.06em; box-shadow:var(--shadow-green); white-space:nowrap}
.tier-badge-free{background:linear-gradient(135deg, #fbbf24 0%, #f59e0b 100%); box-shadow:0 6px 18px -4px rgba(251,191,36,.5)}
.tier-count{font-size:1.6rem;font-weight:800;color:var(--text); font-feature-settings:"tnum"}
.tier-label{font-size:.85rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}
.tier-price{margin-top:.5rem}
.price-big{font-size:2rem;font-weight:800;color:var(--wa-green-dark)}
.price-per{color:var(--muted);font-size:.85rem}
.tier-rate{font-size:.78rem;color:var(--muted)}

/* Tier picker (small radio cards) */
.tier-pick input{position:absolute;opacity:0}
.tier-pick-card{display:flex;flex-direction:column;gap:.2rem;padding:.85rem .8rem;background:var(--surface);border:2px solid var(--line);border-radius:10px;text-align:center;cursor:pointer;transition:all .15s; position:relative}
.tier-pick input:checked + .tier-pick-card{border-color:var(--wa-green); background:#f6fbf8; box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.tier-pick-count{font-size:1.05rem;font-weight:800;color:var(--text)}
.tier-pick-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.tier-pick-price{font-size:1.1rem;font-weight:800;color:var(--wa-green-dark);margin-top:.25rem}
.tier-pick-perk{font-size:.7rem;color:var(--muted)}

/* Type picker */
.type-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.7rem}
@media(max-width:560px){.type-grid{grid-template-columns:1fr}}
.type-opt{cursor:pointer; position:relative}
.type-opt input{position:absolute;opacity:0}
.type-card{display:grid;grid-template-columns:auto 1fr auto;column-gap:.85rem;align-items:center;padding:1rem;background:var(--surface);border:2px solid var(--line);border-radius:10px;transition:all .15s}
.type-opt input:checked + .type-card{border-color:var(--wa-green); background:#f6fbf8; box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.type-icon{font-size:1.6rem;grid-row:1 / span 2}
.type-name{font-weight:700;color:var(--text)}
.type-desc{grid-column:2; font-size:.82rem;color:var(--muted)}
.type-mult{grid-column:3;grid-row:1 / span 2; font-weight:700;color:var(--wa-green-dark);font-size:.85rem; padding:.2rem .5rem;background:rgba(37,211,102,.1);border-radius:6px}

/* Checkout bar */
.checkout-bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#f6fbf8;border:1px solid #b7e7c8;border-radius:10px;margin-top:1.25rem}
.checkout-total{font-size:1.6rem;font-weight:800;color:var(--wa-green-dark)}

/* =================== CTA =================== */
.section-cta{padding:3rem 0 5rem}
.cta-card{
  text-align:center; padding:3rem 2rem;
  background:linear-gradient(135deg, #25D366 0%, #128C7E 100%);
  color:#fff;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow);
}
.cta-card h2{font-size:1.85rem;margin:0 0 .65rem;font-weight:800; color:#fff}
.cta-card p{color:rgba(255,255,255,.9);margin:0 0 1.5rem}
.cta-card .btn-primary{background:#fff;color:var(--wa-teal); box-shadow:0 8px 24px -6px rgba(0,0,0,.2)}
.cta-card .btn-primary:hover{background:#fff;color:var(--wa-teal)}
.cta-card .btn-outline{border-color:rgba(255,255,255,.6); color:#fff}
.cta-card .btn-outline:hover{background:rgba(255,255,255,.12); color:#fff; border-color:#fff}
.cta-buttons{display:flex;justify-content:center;gap:.7rem;flex-wrap:wrap}

/* =================== PAGE HEAD =================== */
.page-head{padding:2.5rem 0 1.25rem; border-bottom:1px solid var(--line); background:linear-gradient(180deg, #f6fbf8, transparent)}
.page-head h1{margin:0 0 .35rem;font-size:2rem;font-weight:800;letter-spacing:-.02em;color:var(--text)}
.page-head p{margin:0}

/* =================== MARKETPLACE =================== */
.market-grid{display:grid;grid-template-columns:260px 1fr;gap:2rem}
@media(max-width:880px){.market-grid{grid-template-columns:1fr}}
.filter-bar{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:1.25rem; position:sticky; top:90px; align-self:start; box-shadow:var(--shadow-soft);
}
.filter-block{margin-bottom:1rem}
.filter-block label{display:block;font-size:.78rem;font-weight:700;color:var(--text-soft);margin-bottom:.35rem;text-transform:uppercase;letter-spacing:.05em}
.input{
  width:100%; padding:.65rem .8rem; background:var(--surface); border:1px solid var(--line);
  border-radius:8px; color:var(--text); font-size:.92rem; font-family:inherit;
  transition:border-color .15s, box-shadow .15s;
}
.input:focus{outline:none; border-color:var(--wa-green); box-shadow:0 0 0 3px rgba(37,211,102,.18)}
.input-sm{padding:.4rem .6rem;font-size:.85rem; max-width:90px}
textarea.input{font-family:inherit; font-size:.92rem}

/* =================== CARDS =================== */
.card{background:var(--surface); border:1px solid var(--line); border-radius:var(--r); padding:1.5rem; box-shadow:var(--shadow-soft)}
.card h3{margin:0 0 .85rem; font-size:1.1rem; color:var(--text)}
.card label{display:block; font-size:.78rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em; margin:.85rem 0 .35rem}
.field-pills{display:flex;flex-wrap:wrap;gap:.4rem}
.field-pill{padding:.3rem .65rem;border-radius:6px;background:#e7f9ef;border:1px solid #b7e7c8;color:#0d6e3a;font-family:'JetBrains Mono',monospace;font-size:.78rem}
.code-block{background:var(--surface-3);border:1px solid var(--line);border-radius:8px;padding:.85rem;overflow-x:auto;font-family:'JetBrains Mono',monospace;font-size:.82rem;color:var(--wa-teal)}
.check-list{list-style:none;padding:0;margin:0}
.check-list li{padding-left:1.5rem;position:relative;margin-bottom:.55rem;color:var(--text-soft)}
.check-list li::before{content:'✓';position:absolute;left:0;color:var(--wa-green);font-weight:800}
.check-list li strong{color:var(--text)}

.buy-box{background:#f6fbf8; border:1px solid #b7e7c8; border-radius:var(--r-lg); padding:1.5rem; position:sticky; top:90px; box-shadow:var(--shadow-soft)}

/* =================== BREADCRUMBS =================== */
.breadcrumbs{padding:1.25rem 1.25rem .25rem; font-size:.85rem; color:var(--muted)}
.breadcrumbs a{color:var(--text-soft); text-decoration:none}

/* =================== CART / CHECKOUT =================== */
.cart-grid{display:grid;grid-template-columns:1fr 360px;gap:2rem}
@media(max-width:880px){.cart-grid{grid-template-columns:1fr}}
.cart-row{display:grid;grid-template-columns:1fr 90px 100px auto;gap:1rem;align-items:center;padding:1rem 0;border-bottom:1px solid var(--line-soft)}
.cart-row:last-child{border-bottom:none}
.cart-info{display:flex;flex-direction:column;gap:.15rem}
.cart-title{color:var(--text);font-weight:600}
.cart-price{font-weight:800; color:var(--wa-green-dark); font-feature-settings:"tnum"}
.sum-row{display:flex;justify-content:space-between;padding:.35rem 0; gap:.5rem}
.sum-total{font-size:1.1rem;font-weight:700;padding-top:.6rem}
.sum-total strong{color:var(--wa-green-dark)}

.pay-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem}
@media(max-width:560px){.pay-grid{grid-template-columns:1fr}}
.pay-opt{cursor:pointer; position:relative}
.pay-opt input{position:absolute;opacity:0}
.pay-card{display:flex;flex-direction:column;gap:.2rem;padding:1rem;background:var(--surface);border:2px solid var(--line);border-radius:10px;transition:all .15s}
.pay-card .pay-icon{font-size:1.4rem; font-weight:800;color:var(--wa-green-dark)}
.pay-opt input:checked + .pay-card{border-color:var(--wa-green);background:#f6fbf8; box-shadow:0 0 0 3px rgba(37,211,102,.18)}

/* =================== CRYPTO PAY =================== */
.crypto-pay-card{border:2px solid var(--wa-green); background:#f6fbf8}
.pay-amount{font-size:2.4rem;font-weight:800;color:var(--wa-green-dark);margin:.5rem 0 1rem}
.wallet-box{display:flex;align-items:center;gap:.5rem;padding:.85rem;background:#fff;border:1px solid var(--line);border-radius:8px}
.wallet-box code{flex:1;background:transparent;border:none;padding:0;font-size:.95rem; color:var(--wa-teal)}
.status-card{border-left:4px solid var(--wa-blue)}
.status-card-paid{border-left-color:var(--wa-green)}

/* =================== AUTH =================== */
.auth-section{padding:2.5rem 0 2rem}
.auth-wrap{display:flex;justify-content:center}
.auth-card{max-width:460px;width:100%}
.auth-card h1{margin:0 0 .35rem; font-size:1.7rem}
.sample-banner{background:var(--grad); color:#fff; padding:.75rem 1rem; border-radius:8px; text-align:center; font-size:.9rem; margin-bottom:1.25rem; box-shadow:var(--shadow-green)}

/* =================== ACCOUNT (sidebar layout) =================== */
.account-shell{display:grid;grid-template-columns:260px 1fr;gap:0; min-height:60vh; max-width:1300px; margin:1.5rem auto; padding:0 1.25rem}
@media(max-width:880px){.account-shell{grid-template-columns:1fr; padding:0 1rem}}
.account-sidebar{
  position:sticky; top:90px; align-self:start;
  padding:1.25rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  box-shadow:var(--shadow-soft); margin-right:1.5rem;
}
@media(max-width:880px){.account-sidebar{position:static; margin-right:0; margin-bottom:1rem}}
.acct-greeting{display:flex;align-items:center;gap:.7rem; padding-bottom:1rem; border-bottom:1px solid var(--line-soft)}
.acct-avatar{width:42px;height:42px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem; flex-shrink:0; box-shadow:var(--shadow-green)}
.acct-name{font-weight:700; font-size:.95rem; color:var(--text)}
.acct-email{font-size:.78rem; color:var(--muted); word-break:break-all}
.acct-bal-pill{display:flex;flex-direction:column;gap:.15rem; padding:.85rem 1rem; background:linear-gradient(135deg,#f6fbf8,#fff); border:1px solid #b7e7c8; border-radius:10px; margin:1rem 0}
.acct-bal-pill strong{font-size:1.5rem; color:var(--wa-green-dark); font-feature-settings:"tnum"; line-height:1}
.account-nav{display:flex;flex-direction:column;gap:.2rem}
.account-nav a{display:flex; align-items:center; gap:.6rem; padding:.6rem .85rem; border-radius:8px; color:var(--text-soft); font-weight:500; font-size:.92rem; text-decoration:none}
.account-nav a:hover{background:var(--surface-3); color:var(--text); text-decoration:none}
.account-nav a.active{background:#e7f9ef; color:var(--wa-green-dark); font-weight:700}
.account-nav a span:first-child{font-size:1.05rem}
.account-main{padding:0 .25rem; min-width:0}
.account-page-head{margin-bottom:1.25rem}
.account-page-head h1{margin:0 0 .25rem; font-size:1.7rem}
.account-page-head p{margin:0}

.stat-card{padding:1.25rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow-soft)}
.stat-card-accent{background:linear-gradient(135deg,#f6fbf8,#fff); border-color:#b7e7c8}
.stat-num{font-size:1.85rem;font-weight:800;color:var(--wa-green-dark); font-feature-settings:"tnum"; line-height:1}
.stat-label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em; font-weight:600}

.activity-list{list-style:none;padding:0;margin:0}
.activity-list li{display:flex;align-items:center;gap:.7rem; padding:.55rem 0; border-bottom:1px solid var(--line-soft); font-size:.9rem}
.activity-list li:last-child{border-bottom:none}
.activity-icon{font-size:1.2rem; flex-shrink:0}
.activity-text{flex:1; min-width:0}

.sample-card{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem;background:var(--grad-soft);border:1px solid #b7e7c8;border-radius:var(--r); box-shadow:var(--shadow-soft); flex-wrap:wrap}
.sample-card h3{margin:0 0 .25rem; color:var(--wa-teal)}
.sample-card p{margin:0; color:var(--text-soft)}

/* =================================================================
   COMPACT MODE — applies inside .admin-shell and .account-shell
   Tighter padding, smaller typography, denser tables, less whitespace.
   ================================================================= */
.admin-shell, .account-shell{
  --r: 10px;
}

/* Sidebar tighter */
.admin-sidebar, .account-sidebar{padding:.95rem .9rem; top:80px}
.admin-greeting, .acct-greeting{padding-bottom:.7rem; gap:.55rem; margin-bottom:.7rem}
.admin-avatar, .acct-avatar{width:34px; height:34px; font-size:.95rem}
.admin-name, .acct-name{font-size:.88rem}
.admin-role, .acct-email{font-size:.7rem}
.admin-nav a, .account-nav a{padding:.42rem .7rem; font-size:.86rem; gap:.5rem}
.admin-nav a span:first-child, .account-nav a span:first-child{font-size:.95rem}
.admin-nav-section{margin:.7rem .35rem .25rem; font-size:.66rem}
.acct-bal-pill{padding:.65rem .8rem; margin:.7rem 0}
.acct-bal-pill strong{font-size:1.2rem}

/* Page head */
.admin-page-head, .account-page-head{margin-bottom:1rem}
.admin-page-head p, .account-page-head p{margin:.15rem 0 0; font-size:.85rem}
.admin-shell h1, .account-shell h1{font-size:1.4rem}
.admin-shell h2, .account-shell h2{font-size:1.15rem}
.admin-shell h3, .account-shell h3{font-size:.98rem; margin:0 0 .55rem}

/* Cards */
.admin-shell .card, .account-shell .card{padding:1rem 1.1rem}
.admin-shell .card label, .account-shell .card label{margin:.6rem 0 .25rem; font-size:.72rem}
.admin-shell .input, .account-shell .input{padding:.5rem .7rem; font-size:.88rem}
.admin-shell textarea.input, .account-shell textarea.input{padding:.55rem .7rem}

/* Stat cards (account overview) */
.account-shell .stat-card{padding:.95rem 1rem; gap:.2rem}
.account-shell .stat-num{font-size:1.55rem}
.account-shell .stat-label{font-size:.7rem}

/* Admin icon stats */
.admin-stats{gap:.65rem}
.admin-stat{padding:.75rem .85rem; gap:.65rem}
.admin-stat-icon{width:36px; height:36px; font-size:1.15rem; border-radius:8px}
.admin-stat-num{font-size:1.2rem}
.admin-stat-lbl{font-size:.66rem}

/* Tables denser */
.admin-shell .tbl th, .account-shell .tbl th{padding:.5rem .45rem; font-size:.7rem}
.admin-shell .tbl td, .account-shell .tbl td{padding:.5rem .45rem; font-size:.85rem}
.admin-shell .tbl, .account-shell .tbl{font-size:.85rem}

/* Compact buttons */
.admin-shell .btn, .account-shell .btn{padding:.55rem .9rem; font-size:.88rem}
.admin-shell .btn-sm, .account-shell .btn-sm{padding:.32rem .6rem; font-size:.76rem}
.admin-shell .btn-lg, .account-shell .btn-lg{padding:.65rem 1.15rem; font-size:.92rem}

/* Margins compress */
.admin-shell .mt-2, .account-shell .mt-2{margin-top:.7rem}
.admin-shell .mt-3, .account-shell .mt-3{margin-top:1rem}
.admin-shell .mt-4, .account-shell .mt-4{margin-top:1.4rem}
.admin-shell .grid, .account-shell .grid{gap:.85rem}

/* Activity list denser */
.account-shell .activity-list li{padding:.4rem 0; font-size:.85rem}
.account-shell .activity-icon{font-size:1rem}

/* Status pills shrink slightly */
.admin-shell .status, .account-shell .status{padding:.13rem .45rem; font-size:.66rem}

/* Wallet hero */
.account-shell .wallet-hero{padding:1.4rem 1.5rem}
.account-shell .wallet-num{font-size:2.2rem}

/* Sample card on account overview */
.account-shell .sample-card{padding:1rem 1.25rem; gap:1rem}
.account-shell .sample-card h3{font-size:1rem}
.account-shell .sample-card p{font-size:.85rem}

/* Download banner */
.account-shell .download-banner{padding:1.1rem 1.4rem; gap:1rem}
.account-shell .download-banner h3{font-size:1.05rem}
.account-shell .download-banner p{font-size:.85rem}

/* Searchbar in admin compact */
.admin-shell .searchbar{padding:.4rem; margin-bottom:.7rem}
.admin-shell .searchbar-input input{padding:.5rem 0; font-size:.88rem}
.admin-shell .searchbar-sort{padding:.5rem .7rem; font-size:.85rem}

/* HR tighter */
.admin-shell hr, .account-shell hr{margin:.7rem 0}

/* Inbox table */
.inbox-tbl tr.inbox-unread td{background:#fffbeb !important; font-weight:600}
.inbox-tbl tr.inbox-unread td:first-child{color:#e65100; font-size:1.2rem; line-height:1}
.mail-frame{width:100%; min-height:480px; border:1px solid var(--line); border-radius:8px; background:#fff}
.mail-text{white-space:pre-wrap; word-break:break-word; padding:1rem; background:var(--surface-2); border-radius:8px; max-height:600px; overflow-y:auto; font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size:.85rem; line-height:1.55}

/* Quick action buttons row */
.admin-quick-actions .btn-sm{padding:.35rem .7rem}

/* Cart-row in account-shell (sample list etc.) */
.account-shell .cart-row{padding:.65rem 0; gap:.7rem; font-size:.85rem}

/* Compact sum-rows */
.admin-shell .sum-row, .account-shell .sum-row{padding:.25rem 0; font-size:.85rem}
.admin-shell .sum-total, .account-shell .sum-total{padding-top:.5rem}

/* Field labels in profile/settings */
.admin-shell .row-actions-pop{padding:.7rem; min-width:220px}

/* Type/pay grids compress */
.account-shell .type-card{padding:.75rem .85rem}
.account-shell .type-name{font-size:.92rem}
.account-shell .type-desc{font-size:.78rem}
.account-shell .pay-card{padding:.75rem .85rem}

/* Tier picker */
.account-shell .tier-pick-card{padding:.65rem .65rem}
.account-shell .tier-pick-count{font-size:.95rem}
.account-shell .tier-pick-price{font-size:1rem}

@media(max-width:880px){
  .admin-sidebar, .account-sidebar{padding:.7rem .85rem}
}

/* Download-ready banner on overview */
.download-banner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1.5rem;background:linear-gradient(135deg, #25D366 0%, #128C7E 100%);color:#fff;border-radius:var(--r); box-shadow:var(--shadow); flex-wrap:wrap; margin-bottom:1rem}
.download-banner h3{margin:0 0 .25rem;color:#fff}
.download-banner p{margin:0;color:rgba(255,255,255,.92)}
.download-banner .btn-primary{background:#fff;color:var(--wa-teal); box-shadow:0 6px 20px -4px rgba(0,0,0,.2)}
.download-banner .btn-primary:hover{background:#fff;color:var(--wa-teal)}

/* Verify-email banner */
.verify-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.verify-banner strong{font-weight:700}

/* Pay-help dropdowns on order detail */
.pay-help{margin-top:.6rem;padding:.7rem .85rem;background:var(--surface-2);border-radius:8px}
.pay-help summary{cursor:pointer;font-weight:600;color:var(--wa-green-dark);list-style:none}
.pay-help summary::-webkit-details-marker{display:none}
.pay-help summary::before{content:'▸ ';color:var(--wa-green-dark);transition:transform .2s}
.pay-help[open] summary::before{content:'▾ '}
.pay-help p{margin:.5rem 0 0;font-size:.88rem;color:var(--text-soft)}

/* Download card on order detail */
.download-card{border-left:4px solid var(--wa-green)}
.download-card .download-link{margin-top:1.25rem; padding-top:1.25rem; border-top:1px solid var(--line)}
.download-card .download-link label{display:block; font-size:.78rem;font-weight:700;color:var(--text-soft);text-transform:uppercase;letter-spacing:.05em; margin-bottom:.4rem}
.status-card-cancelled{border-left-color:#ef4444}

/* ===== Wallet ===== */
.wallet-hero{display:flex;gap:1.5rem;padding:2rem;background:linear-gradient(135deg, var(--wa-teal) 0%, var(--wa-green-dark) 100%); color:#fff; border-radius:var(--r-lg); box-shadow:var(--shadow); flex-wrap:wrap; align-items:center}
.wallet-balance{display:flex;flex-direction:column;gap:.25rem; min-width:160px}
.wallet-balance .muted{color:rgba(255,255,255,.7)}
.wallet-num{font-size:3rem; font-weight:800; font-feature-settings:"tnum"; line-height:1}
.wallet-info{flex:1; min-width:240px}
.wallet-info p{margin:0; color:rgba(255,255,255,.92)}
.wallet-info strong{color:#fff}

.amount-presets{display:flex;flex-wrap:wrap;gap:.4rem; margin:.4rem 0}
.preset-btn{padding:.4rem .85rem;background:var(--surface);border:1px solid var(--line);border-radius:8px;font-weight:700;cursor:pointer;color:var(--text-soft);font-family:inherit;font-size:.85rem;transition:all .15s}
.preset-btn:hover{border-color:var(--wa-green); background:#f6fbf8; color:var(--wa-green-dark)}

/* ===== Coming-soon data type ===== */
.type-opt-disabled{opacity:.65; cursor:not-allowed}
.type-opt-disabled .type-card{background:var(--surface-2)}
.type-mult-contact{background:var(--grad-warm) !important; color:#fff !important; padding:.25rem .55rem; border-radius:6px; font-size:.72rem; font-weight:700; text-decoration:none}
.type-mult-contact:hover{color:#fff !important}

/* ===== Pay-opt disabled ===== */
.pay-opt-disabled{opacity:.55}
.pay-opt-disabled .pay-card{background:var(--surface-2); cursor:not-allowed}
.pay-card-wallet{border-color:#fbbf24; background:linear-gradient(180deg,#fffbeb,#fff) !important}
.pay-opt input:checked + .pay-card-wallet{border-color:var(--wa-green)}

.row-between.mb-2{margin-bottom:.85rem}
.mb-2{margin-bottom:1rem}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){.grid-4{grid-template-columns:repeat(2,1fr)}}

/* =================== TABLE =================== */
.tbl{width:100%;border-collapse:collapse;font-size:.92rem}
.tbl th, .tbl td{padding:.65rem .5rem; text-align:left; border-bottom:1px solid var(--line-soft)}
.tbl th{font-size:.76rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.tbl tr:hover td{background:var(--surface-2)}
.status{display:inline-block;padding:.18rem .55rem;border-radius:5px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em; white-space:nowrap}
.status-awaiting_payment{background:#fff3e0;color:#e65100}
.status-confirming{background:#e6f5fb;color:#0c5a83}
.status-paid{background:#e7f9ef;color:#0d6e3a}
.status-expired,.status-failed,.status-cancelled{background:#fdecec;color:#8a1a1a}
.status-refunded{background:#f3edfa;color:#5b3aa3}
.status-pending{background:#fff3e0;color:#e65100}
.status-processing{background:#e6f5fb;color:#0c5a83}
.status-delivered{background:#e7f9ef;color:#0d6e3a}
.inline-form{display:inline-block;margin:0}

/* =================== ADMIN (full-screen, dedicated layout) =================== */
body.admin-body{
  background:#f4f6f8;
  min-height:100vh;
  display:flex; flex-direction:column;
}

/* Admin top bar */
.admin-topbar{
  background:linear-gradient(180deg, #075E54 0%, #064a42 100%);
  color:#fff;
  border-bottom:3px solid #25D366;
  position:sticky; top:0; z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.admin-topbar-inner{
  max-width:none; padding:.7rem 1.5rem;
  display:flex; align-items:center; gap:1.5rem; justify-content:space-between;
}
.admin-topbar-brand{
  display:flex; align-items:center; gap:.7rem;
  text-decoration:none; color:#fff;
  padding:.15rem .4rem .15rem .15rem; border-radius:8px;
  transition:background .15s;
}
.admin-topbar-brand:hover{text-decoration:none; color:#fff; background:rgba(255,255,255,.06)}
.admin-topbar-img{
  width:26px; height:26px; object-fit:contain; flex-shrink:0;
  filter:drop-shadow(0 2px 6px rgba(37,211,102,.4));
}
.admin-topbar-text{display:flex; flex-direction:column; gap:.05rem; line-height:1.15}
.admin-topbar-text strong{font-weight:700; font-size:.98rem; letter-spacing:-.01em; color:#fff}
.admin-topbar-sub{font-size:.66rem; color:#9bdcc8; text-transform:uppercase; letter-spacing:.12em; font-weight:600}
.admin-topbar-right{display:flex; align-items:center; gap:1rem}
.admin-topbar-link{color:#dcf8c6; font-size:.88rem; text-decoration:none; font-weight:500}
.admin-topbar-link:hover{color:#fff; text-decoration:underline}
.admin-topbar-user{font-size:.85rem; color:#dcf8c6; font-weight:600}
.admin-topbar-logout{background:transparent; color:#fff; border-color:rgba(255,255,255,.4)}
.admin-topbar-logout:hover{background:rgba(255,255,255,.1); color:#fff; border-color:#fff}

/* Admin flash bar (full-width, just below topbar) */
.admin-flash{
  padding:.7rem 1.5rem; font-size:.9rem; font-weight:500;
  border-bottom:1px solid;
}
.admin-flash-success{background:#e7f9ef; border-color:#b7e7c8; color:#0d6e3a}
.admin-flash-error  {background:#fdecec; border-color:#f5b8b8; color:#8a1a1a}
.admin-flash-info   {background:#e6f5fb; border-color:#b9dff0; color:#0c5a83}

/* Full-width shell — sidebar + main */
.admin-shell{
  display:grid; grid-template-columns:240px 1fr; gap:0;
  flex:1; min-height:0;
  align-items:start;
}
@media(max-width:980px){
  .admin-shell{grid-template-columns:1fr}
}
.admin-sidebar{
  position:sticky; top:64px;
  height:calc(100vh - 64px); overflow-y:auto;
  align-self:start;
  padding:1.25rem 1rem;
  background:#fff; border-right:1px solid var(--line);
  margin:0;
}
@media(max-width:980px){
  .admin-sidebar{position:static; height:auto; border-right:none; border-bottom:1px solid var(--line)}
}
.admin-greeting{display:flex;align-items:center;gap:.7rem; padding-bottom:1rem; border-bottom:1px solid var(--line-soft); margin-bottom:1rem}
.admin-avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg, var(--wa-teal), var(--wa-green-dark));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;flex-shrink:0;box-shadow:var(--shadow-green)}
.admin-name{font-weight:700;font-size:.95rem;color:var(--text)}
.admin-role{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.admin-nav{display:flex;flex-direction:column;gap:.15rem}
.admin-nav-section{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700;margin:.85rem .4rem .35rem}
.admin-nav-section:first-child{margin-top:0}
.admin-nav a{display:flex;align-items:center;gap:.55rem;padding:.55rem .8rem;border-radius:8px;color:var(--text-soft);font-weight:500;font-size:.9rem;text-decoration:none}
.admin-nav a:hover{background:var(--surface-3);color:var(--text);text-decoration:none}
.admin-nav a.active{background:#e7f9ef;color:var(--wa-green-dark);font-weight:700}
.admin-nav a span:first-child{width:18px;text-align:center}
.admin-main{padding:1.5rem 1.75rem; min-width:0; max-width:1400px}
@media(max-width:980px){.admin-main{padding:1rem 1rem}}
.admin-main h1{margin:0; font-size:1.7rem}
.admin-page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}
.admin-page-head p{margin:.25rem 0 0}
.admin-quick-actions{display:flex;gap:.4rem;flex-wrap:wrap}

/* Icon stat cards */
.admin-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:.85rem}
@media(max-width:1100px){.admin-stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.admin-stats{grid-template-columns:repeat(2,1fr)}}
.admin-stat{display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-soft)}
.admin-stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;background:var(--surface-2);flex-shrink:0}
.admin-stat-num{font-size:1.4rem;font-weight:800;color:var(--text);font-feature-settings:"tnum";line-height:1}
.admin-stat-lbl{font-size:.74rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:.15rem}
.admin-stat-good{border-color:#b7e7c8; background:linear-gradient(135deg,#f6fbf8,#fff)}
.admin-stat-good .admin-stat-icon{background:#e7f9ef; color:var(--wa-green-dark)}
.admin-stat-good .admin-stat-num{color:var(--wa-green-dark)}
.admin-stat-warn{border-color:#fcd34d; background:linear-gradient(135deg,#fffbeb,#fff)}
.admin-stat-warn .admin-stat-icon{background:#fff3e0; color:#e65100}
.admin-stat-warn .admin-stat-num{color:#e65100}
.admin-stat-info{border-color:#a5d8f0; background:linear-gradient(135deg,#e6f5fb,#fff)}
.admin-stat-info .admin-stat-icon{background:#cfe9f5; color:#0c5a83}
.admin-stat-info .admin-stat-num{color:#0c5a83}

.row-between{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}

/* Row-action popover (e.g. balance adjust) */
.row-actions{position:relative; display:inline-block}
.row-actions summary{list-style:none; cursor:pointer; user-select:none}
.row-actions summary::-webkit-details-marker{display:none}
.row-actions[open] summary{background:var(--wa-green); color:#fff; border-color:transparent}
.row-actions-pop{
  position:absolute; right:0; top:calc(100% + 6px);
  min-width:240px; padding:.85rem;
  background:#fff; border:1px solid var(--line); border-radius:10px;
  box-shadow:var(--shadow); z-index:30;
}
.row-actions-form{display:flex;flex-direction:column;gap:.35rem; margin:0}
.row-actions-form label{margin:0; font-size:.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:700}
.row-actions-form .input-sm{max-width:none}

.inquiry{padding:1rem 0;border-bottom:1px solid var(--line-soft)}
.inquiry:last-child{border-bottom:none}
.cart-btn{position:relative}
.badge-count{position:absolute;top:-4px;right:-4px;background:var(--wa-green);color:#fff;font-size:.65rem;font-weight:800;padding:.05rem .35rem;border-radius:999px;min-width:18px;text-align:center}

/* =================== TOOLS =================== */
.tool-card{display:flex;flex-direction:column;gap:.5rem;padding:1.5rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);text-decoration:none;color:var(--text);transition:all .25s; box-shadow:var(--shadow-soft)}
.tool-card:hover{transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--wa-green-dark); text-decoration:none; color:var(--text)}
.tool-icon{font-size:2.4rem; line-height:1; margin-bottom:.25rem}

/* SVG data-type icon (used on /pricing + country detail) */
.dt-icon-wrap{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:8px;
  background:linear-gradient(135deg,#e7f9ef,#d0f0db);
  color:var(--wa-green-dark);
  flex-shrink:0;
}
.dt-icon-svg{display:inline-flex;line-height:0}
.dt-card{display:flex;flex-direction:column}
.dt-card-head{display:flex;align-items:center;gap:.7rem;margin-bottom:.6rem}
.dt-card-title{margin:0; flex:1}

/* Type-card with SVG icon (country detail step 1) */
.type-icon-pro{
  display:inline-flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:8px;
  background:linear-gradient(135deg,#e7f9ef,#d0f0db);
  color:var(--wa-green-dark); grid-row:1/span 2; flex-shrink:0;
}
.type-card .type-icon{display:none} /* hide legacy emoji icon when SVG is present */

/* SVG icon for tools (replaces unreliable emoji rendering) */
.tool-icon-wrap{
  display:inline-flex; align-items:center; justify-content:center;
  width:54px; height:54px; border-radius:12px;
  background:linear-gradient(135deg,#e7f9ef,#d0f0db);
  color:var(--wa-green-dark);
  margin-bottom:.5rem;
  box-shadow:0 4px 10px -3px rgba(37,211,102,.25);
}
.tool-icon-svg{display:inline-flex; line-height:0}
.tool-icon-big-wrap{
  display:inline-flex; align-items:center; justify-content:center;
  width:80px; height:80px; border-radius:16px;
  background:linear-gradient(135deg,#e7f9ef,#d0f0db);
  color:var(--wa-green-dark);
  flex-shrink:0;
  box-shadow:0 6px 18px -4px rgba(37,211,102,.3);
}
.tool-card h3{margin:0;font-size:1.1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
.tool-card p{margin:0;color:var(--text-soft);font-size:.92rem; flex:1}
.tool-price{display:inline-block;padding:.25rem .6rem;background:#e7f9ef;color:#0d6e3a;border-radius:6px;font-size:.78rem;font-weight:700;align-self:flex-start;margin-top:.5rem}
.beta-pill{display:inline-block;padding:.1rem .4rem;background:var(--wa-blue);color:#fff;border-radius:5px;font-size:.65rem;font-weight:800;letter-spacing:.05em}
.beta-pill-soon{background:#f59e0b}
.tool-header{display:flex;align-items:center;gap:1rem}
.tool-icon-big{font-size:3.5rem; line-height:1}
.tool-header h1{margin:0; font-size:1.7rem; display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}

.tool-price-custom{background:linear-gradient(135deg, #fbbf24, #f59e0b); color:#fff !important}

/* ===== Tool detail page ===== */
.tool-detail-hero{display:flex;align-items:center;gap:1.5rem;padding:2rem;background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%); flex-wrap:wrap}
.tool-detail-info{flex:1; min-width:260px}
.tool-detail-info h1{margin:0 0 .35rem; font-size:1.85rem; display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.tool-detail-tagline{margin:0; color:var(--text-soft); font-size:1.05rem}
.tool-detail-price-pill{display:flex;flex-direction:column;align-items:center;justify-content:center; padding:1rem 1.5rem; background:var(--surface); border:2px solid var(--wa-green); border-radius:14px; box-shadow:var(--shadow-green); min-width:140px}
.tool-detail-price-pill .price-big{font-size:2rem; line-height:1}
.tool-detail-price-pill .price-per{font-size:.78rem; margin-top:.25rem}

/* Quick stats strip */
.tool-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1.25rem}
@media(max-width:680px){.tool-stats{grid-template-columns:repeat(2,1fr)}}
.tool-stat{padding:1rem 1.25rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--r); display:flex; flex-direction:column; gap:.2rem; box-shadow:var(--shadow-soft)}
.tool-stat-num{font-size:1.45rem; font-weight:800; color:var(--wa-green-dark); font-feature-settings:"tnum"; line-height:1}
.tool-stat-lbl{font-size:.74rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:600}

/* Step list (How it works) */
.step-list{list-style:none; padding:0; margin:0; counter-reset:step}
.step-list li{display:flex; gap:.85rem; padding:.65rem 0; align-items:flex-start; border-bottom:1px solid var(--line-soft)}
.step-list li:last-child{border-bottom:none}
.step-num{display:inline-flex; align-items:center; justify-content:center; flex-shrink:0; width:30px; height:30px; border-radius:50%; background:var(--grad); color:#fff; font-weight:800; font-size:.9rem; box-shadow:var(--shadow-green)}

/* =================== EMPTY =================== */
.empty{text-align:center;padding:3rem 1.5rem;background:var(--surface);border:1px dashed var(--line);border-radius:var(--r)}
.empty h3{margin:0 0 .5rem}

/* =================== FOOTER =================== */
.site-footer{padding:2.25rem 0 1rem; background:var(--wa-teal); color:#eef5f3}
.site-footer .logo-light{color:#cfe1dd; font-weight:500}
.site-footer .logo-bold{color:#fff; font-weight:800}
.site-footer p{color:#cfe1dd}
.site-footer a{color:#eef5f3; text-decoration:none}
.site-footer a:hover{color:#fff; text-decoration:underline}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:1.75rem;margin-bottom:1.4rem}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer h5{margin:0 0 .85rem;font-size:.82rem;color:#fff;text-transform:uppercase;letter-spacing:.08em; font-weight:800}
.footer-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.55rem}
.footer-list a{font-size:.92rem; color:#dbe9e5}
.footer-list a:hover{color:#fff}
.site-footer .muted{color:#a3bfb9 !important}
.site-footer .small{color:#cfe1dd}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;margin-top:1rem;border-top:1px solid rgba(255,255,255,.15);font-size:.85rem;flex-wrap:wrap;gap:.5rem; color:#cfe1dd}
.footer-bottom .muted{color:#a3bfb9 !important}

/* Marketplace disclaimer (footer) */
.footer-disclaimer{
  margin-top:.5rem; padding:.75rem 1rem;
  background:rgba(0,0,0,.18); border:1px solid rgba(255,255,255,.1);
  border-radius:8px; font-size:.78rem; line-height:1.5; color:#cfe1dd;
}
.footer-disclaimer strong{color:#fff}
.footer-disclaimer a{color:#dcf8c6; text-decoration:underline}
.footer-disclaimer a:hover{color:#fff}

/* Disclaimer card highlight (compliance + terms pages) */
.disclaimer-card{border-left:4px solid #f59e0b; background:linear-gradient(180deg, #fffbeb 0%, #fff 100%)}

/* ===== Coupon row in cart ===== */
.coupon-form{display:flex; gap:.4rem; margin-top:.5rem}
.coupon-form .input{flex:1; max-width:none}
.sum-row-discount{color:var(--wa-green-dark)}
.sum-row-discount strong{color:var(--wa-green-dark)}

/* ===== Affiliate hero ===== */
.affiliate-hero{
  display:flex; gap:1.5rem; padding:1.5rem;
  background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%);
  border-color:#b7e7c8 !important;
  flex-wrap:wrap; align-items:flex-start;
}
.affiliate-hero > div:first-child{flex:1; min-width:280px}
.affiliate-share{display:flex; flex-direction:column; gap:.5rem; min-width:200px}
.share-btns{display:flex; gap:.4rem; flex-wrap:wrap}

/* email links in footer — full address shown */
.footer-emails{gap:.65rem}
.footer-emails li{display:flex;flex-direction:column;gap:.05rem}
.footer-emails a{
  font-family:ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size:.82rem; color:#fff; word-break:break-all; line-height:1.3;
}
.footer-emails a:hover{color:#dcf8c6; text-decoration:underline}
.email-desc{font-size:.72rem; color:#9bb1ac; line-height:1.3}

/* ===== Crypto strip (footer) ===== */
.crypto-strip{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-top:1rem}
.crypto-strip-label{font-size:.78rem; color:#cfe1dd; font-weight:600; letter-spacing:.02em; margin-right:.25rem; width:100%; margin-bottom:.15rem}
.crypto-chip{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.32rem .7rem .32rem .35rem;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);
  border-radius:999px;font-size:.78rem;font-weight:700;color:#fff;
  transition:all .15s; cursor:default;
}
.crypto-chip:hover{background:rgba(255,255,255,.13); transform:translateY(-1px)}
.crypto-chip-icon{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;color:#fff;font-weight:800;font-size:.85rem;line-height:1;
  flex-shrink:0; box-shadow:0 1px 3px rgba(0,0,0,.3);
}
.crypto-icon-btc{background:#F7931A}
.crypto-icon-usdt{background:#26A17B}
.crypto-icon-eth{background:#627EEA}
.crypto-icon-ltc{background:#345D9D}

/* ===== Contact: department cards ===== */
.dept-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}
@media(max-width:980px){.dept-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.dept-grid{grid-template-columns:1fr}}
.dept-card{
  display:flex;flex-direction:column;gap:.4rem;padding:1.25rem;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  text-decoration:none; color:var(--text); transition:all .2s; box-shadow:var(--shadow-soft);
}
.dept-card:hover{transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--wa-green-dark); text-decoration:none; color:var(--text)}
.dept-icon{font-size:1.8rem; line-height:1; margin-bottom:.15rem}
.dept-card h3{margin:0; font-size:1.08rem}
.dept-card p{margin:0}
.dept-email{display:inline-block; margin-top:.4rem; padding:.25rem .55rem; background:#e7f9ef; color:#0d6e3a; border-radius:6px; font-family:'JetBrains Mono', monospace; font-size:.8rem; font-weight:600; align-self:flex-start}
.dept-card:hover .dept-email{background:var(--grad); color:#fff}

.route-preview{
  margin-top:1rem; padding:.65rem .9rem;
  background:#f6fbf8; border:1px solid #b7e7c8; border-radius:8px;
  display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
}
.route-preview strong{color:var(--wa-green-dark); font-family:'JetBrains Mono', monospace; font-size:.92rem}

/* =================================================================
   BROWSE COUNTRIES — PROFESSIONAL HERO + PRO CARDS
   ================================================================= */

/* ---- Hero ---- */
.browse-hero{
  position:relative; padding:1.5rem 0 2.25rem;
  background:
    radial-gradient(900px 380px at 110% -20%, rgba(37,211,102,.18), transparent 60%),
    radial-gradient(700px 300px at -10% 110%, rgba(52,183,241,.10), transparent 60%),
    linear-gradient(180deg, #f4faf6 0%, #ffffff 100%);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.browse-hero::before{
  content:''; position:absolute; inset:0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(7,94,84,.08) 1px, transparent 0);
  background-size:22px 22px; opacity:.35; pointer-events:none;
}
.browse-hero > .container{position:relative}

.browse-crumbs{font-size:.82rem; color:var(--muted); margin-bottom:1.1rem; display:flex; align-items:center; gap:.4rem; flex-wrap:wrap}
.browse-crumbs a{color:var(--muted); font-weight:600}
.browse-crumbs a:hover{color:var(--wa-green-dark)}
.browse-crumbs-sep{color:var(--line)}
.browse-crumbs-current{color:var(--text); font-weight:700}

.browse-hero-grid{
  display:grid; grid-template-columns:1.4fr 1fr; gap:2.25rem; align-items:center;
}
@media(max-width:920px){.browse-hero-grid{grid-template-columns:1fr; gap:1.5rem}}

.browse-hero-eyebrow{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.32rem .7rem; border-radius:999px;
  background:rgba(37,211,102,.12); color:var(--wa-teal);
  font-size:.78rem; font-weight:700; letter-spacing:.02em;
  border:1px solid rgba(37,211,102,.25);
  margin-bottom:.85rem;
}
.browse-hero-pulse{
  width:8px; height:8px; border-radius:50%; background:var(--wa-green);
  box-shadow:0 0 0 0 rgba(37,211,102,.6); animation:pulse 1.6s ease-out infinite;
}

.browse-hero-title{
  margin:0 0 .75rem; font-size:2.5rem; font-weight:800;
  letter-spacing:-.025em; line-height:1.12; color:var(--text);
}
.browse-hero-accent{
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
@media(max-width:560px){.browse-hero-title{font-size:1.8rem}}

.browse-hero-sub{
  margin:0 0 1.1rem; font-size:1rem; color:var(--text-soft); max-width:60ch; line-height:1.55;
}

.browse-hero-trust{display:flex; flex-wrap:wrap; gap:.45rem}
.browse-hero-trust-pill{
  display:inline-flex; align-items:center; gap:.35rem;
  padding:.32rem .7rem; border-radius:999px;
  background:#fff; border:1px solid #d6ecdb; color:var(--wa-teal);
  font-size:.78rem; font-weight:700;
  box-shadow:0 1px 0 rgba(0,0,0,.02);
}
.browse-hero-trust-pill > span{
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:14px; border-radius:50%;
  background:var(--wa-green); color:#fff; font-size:.6rem; font-weight:900;
}

/* ---- Hero stats card grid ---- */
.browse-hero-stats{
  display:grid; grid-template-columns:repeat(2, 1fr); gap:.7rem;
  background:rgba(255,255,255,.7); backdrop-filter:blur(6px);
  border:1px solid #d6ecdb; border-radius:18px; padding:.9rem;
  box-shadow:var(--shadow-soft);
}
.bh-stat{
  position:relative; padding:.95rem 1rem; border-radius:12px;
  background:linear-gradient(180deg, #ffffff 0%, #f6fbf8 100%);
  border:1px solid #e6efe9;
}
.bh-stat-num{
  font-size:1.6rem; font-weight:800; color:var(--wa-teal);
  letter-spacing:-.02em; line-height:1.05; display:flex; align-items:baseline; gap:.15rem;
}
.bh-stat-plus{font-size:.95rem; color:var(--wa-green); font-weight:800}
.bh-stat-fire{font-size:.95rem; margin-left:.2rem}
.bh-stat-lbl{
  margin-top:.2rem; font-size:.72rem; color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em; font-weight:700;
}
.bh-stat-hot{
  background:linear-gradient(180deg, #fff7ed 0%, #ffe9d5 100%);
  border-color:#ffd8b3;
}
.bh-stat-hot .bh-stat-num{color:#c2410c}

/* ---- Toolbar (sticky region tabs + search) ---- */
.browse-section{padding-top:1.75rem !important}
.browse-toolbar{
  background:#fff; border:1px solid var(--line); border-radius:16px;
  box-shadow:var(--shadow-soft); padding:.85rem; margin-bottom:1rem;
}

/* Region tabs */
.browse-toolbar-tabs{
  display:flex; flex-wrap:wrap; gap:.4rem; padding-bottom:.7rem;
  border-bottom:1px dashed var(--line); margin-bottom:.7rem;
}
.bt-tab{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.5rem .85rem; border-radius:10px;
  background:var(--surface-2); border:1px solid transparent;
  color:var(--text-soft); font-size:.86rem; font-weight:700;
  text-decoration:none; transition:all .15s;
  white-space:nowrap;
}
.bt-tab:hover{background:#eaf6ee; color:var(--wa-teal); text-decoration:none}
.bt-tab.active{
  background:var(--grad); color:#fff;
  box-shadow:0 6px 16px -6px rgba(37,211,102,.45);
}
.bt-tab.active:hover{color:#fff}
.bt-tab-emoji{font-size:1rem; line-height:1}
.bt-tab-count{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:22px; height:18px; padding:0 .35rem;
  background:rgba(0,0,0,.07); border-radius:999px;
  font-size:.7rem; font-weight:800; color:inherit;
}
.bt-tab.active .bt-tab-count{background:rgba(255,255,255,.22); color:#fff}

/* Search row */
.browse-toolbar-search{
  display:flex; gap:.5rem; flex-wrap:wrap; align-items:stretch;
}
.bts-input{
  flex:1; min-width:240px; display:flex; align-items:center; gap:.55rem;
  padding:0 .9rem; background:var(--surface-2);
  border:1px solid transparent; border-radius:10px; transition:all .15s;
}
.bts-input:focus-within{
  background:#fff; border-color:var(--wa-green);
  box-shadow:0 0 0 3px rgba(37,211,102,.15);
}
.bts-input svg{color:var(--muted); flex-shrink:0}
.bts-input input{
  flex:1; border:none; background:transparent; outline:none;
  font-size:.95rem; font-family:inherit; color:var(--text); padding:.7rem 0;
}
.bts-input input::placeholder{color:var(--muted)}
.bts-clear{
  width:22px; height:22px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:50%; background:rgba(0,0,0,.08); color:var(--muted);
  text-decoration:none; font-size:.75rem; font-weight:700; flex-shrink:0;
}
.bts-clear:hover{background:#ef4444; color:#fff; text-decoration:none}
.bts-sort{
  padding:.7rem .9rem; border:1px solid var(--line); border-radius:10px;
  background:#fff; font-family:inherit; font-size:.9rem; color:var(--text);
  cursor:pointer; min-width:200px;
}
.bts-sort:focus{outline:none; border-color:var(--wa-green); box-shadow:0 0 0 3px rgba(37,211,102,.15)}
.bts-go{padding-left:1.4rem; padding-right:1.4rem}
@media(max-width:680px){
  .browse-toolbar-search{flex-direction:column}
  .bts-input, .bts-sort, .bts-go{width:100%}
}

/* ---- Result meta + active filter pills ---- */
.browse-meta{
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:.5rem; margin-bottom:1rem;
  padding:.25rem .15rem;
}
.browse-meta-text{color:var(--text-soft); font-size:.92rem}
.browse-meta-text strong{color:var(--text)}
.browse-meta-pills{display:flex; flex-wrap:wrap; gap:.35rem; align-items:center}
.bm-pill{
  display:inline-flex; align-items:center; gap:.3rem;
  padding:.3rem .65rem; border-radius:999px;
  background:#eaf6ee; color:var(--wa-teal);
  font-size:.78rem; font-weight:600;
  text-decoration:none; border:1px solid #cfe9d6; transition:all .15s;
}
.bm-pill:hover{background:#fff; color:var(--wa-teal); text-decoration:none}
.bm-pill strong{font-weight:800; color:var(--wa-teal)}
.bm-pill-clear{background:transparent; color:#dc2626; border-color:#fecaca}
.bm-pill-clear:hover{background:#fee2e2; color:#dc2626}

/* ---- Pro country card grid ---- */
.cc-pro-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:1rem;
}
@media(max-width:1080px){.cc-pro-grid{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:620px){.cc-pro-grid{grid-template-columns:1fr}}

.cc-pro{
  position:relative;
  display:flex; flex-direction:column; gap:.85rem;
  padding:1rem 1rem .85rem; background:#fff;
  border:1px solid var(--line); border-radius:14px;
  text-decoration:none; color:var(--text);
  transition:all .2s;
  box-shadow:var(--shadow-soft);
  overflow:hidden;
}
.cc-pro::after{
  /* subtle green accent line at the top */
  content:''; position:absolute; left:0; right:0; top:0; height:3px;
  background:var(--grad); opacity:0; transition:opacity .2s;
}
.cc-pro:hover{
  border-color:#b7e7c8; transform:translateY(-3px);
  box-shadow:0 16px 36px -16px rgba(7,94,84,.22), 0 4px 12px rgba(7,94,84,.06);
  text-decoration:none; color:var(--text);
}
.cc-pro:hover::after{opacity:1}
.cc-pro:hover .cc-pro-cta{background:var(--grad); color:#fff; border-color:transparent}
.cc-pro:hover .cc-pro-cta svg{transform:translateX(3px)}

/* Hot variant */
.cc-pro.is-hot{border-color:#ffd9b8}
.cc-pro.is-hot:hover{border-color:#ffb685}

/* Ranking pill (top 3 only) */
.cc-pro-rank{
  position:absolute; top:.6rem; right:.6rem; z-index:2;
  display:inline-flex; align-items:center; justify-content:center;
  width:28px; height:28px; border-radius:50%;
  background:linear-gradient(135deg, #d4d4d4, #a3a3a3); color:#fff;
  font-size:.72rem; font-weight:900; letter-spacing:.02em;
  box-shadow:0 4px 10px rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.4);
}
.cc-pro-rank.rank-1{background:linear-gradient(135deg, #fbbf24, #d97706)}
.cc-pro-rank.rank-2{background:linear-gradient(135deg, #d1d5db, #6b7280)}
.cc-pro-rank.rank-3{background:linear-gradient(135deg, #fdba74, #c2410c)}

/* Card head: flag + title */
.cc-pro-head{display:flex; align-items:center; gap:.85rem; padding-right:2.2rem}
.cc-pro-flag{
  width:56px; height:42px; flex-shrink:0;
  border-radius:6px; object-fit:cover;
  box-shadow:0 2px 6px rgba(0,0,0,.15), 0 0 0 1px rgba(0,0,0,.06);
}
.cc-pro-flag-fallback{
  width:56px; height:42px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--surface-2); border-radius:6px; font-size:1.8rem;
}
.cc-pro-title{flex:1; min-width:0}
.cc-pro-name{
  display:flex; align-items:center; gap:.4rem; flex-wrap:wrap;
  font-size:1.05rem; font-weight:800; color:var(--text);
  letter-spacing:-.01em; line-height:1.2;
}
.cc-pro-hot{
  display:inline-block; padding:.1rem .42rem; border-radius:5px;
  background:linear-gradient(135deg, #fff3e0, #ffe0b3);
  color:#c2410c; font-size:.62rem; font-weight:900; letter-spacing:.06em;
}
.cc-pro-region{
  margin-top:.2rem; display:flex; align-items:center; gap:.5rem;
  font-size:.72rem; color:var(--muted); font-weight:600;
}
.cc-pro-region-tag{text-transform:uppercase; letter-spacing:.05em}
.cc-pro-iso{
  font-family:'JetBrains Mono', ui-monospace, monospace;
  background:#eef5f1; color:var(--wa-teal);
  padding:.05rem .35rem; border-radius:4px;
  font-size:.7rem; font-weight:700; letter-spacing:.04em;
}

/* Stat strip: 3 mini stats side by side */
.cc-pro-stats{
  display:grid; grid-template-columns:1.1fr 1fr 1fr; gap:.4rem;
  padding:.65rem; background:linear-gradient(180deg, #f6fbf8 0%, #f0f7f3 100%);
  border-radius:10px; border:1px solid #e3eee7;
}
.cc-pro-stat{
  display:flex; flex-direction:column; gap:.1rem;
  padding:.15rem .25rem; min-width:0;
}
.cc-pro-stat + .cc-pro-stat{border-left:1px solid #d8e8de}
.cc-pro-stat-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:18px; height:18px; border-radius:5px;
  background:#fff; color:var(--muted); margin-bottom:.15rem;
}
.cc-pro-stat-primary .cc-pro-stat-icon{background:var(--grad); color:#fff}
.cc-pro-stat-num{
  font-size:1.05rem; font-weight:800; color:var(--text); line-height:1.1;
  letter-spacing:-.01em; white-space:nowrap;
}
.cc-pro-stat-primary .cc-pro-stat-num{color:var(--wa-green-dark)}
.cc-pro-stat-lbl{
  font-size:.62rem; color:var(--muted);
  text-transform:uppercase; letter-spacing:.06em; font-weight:700;
}

/* Footer: trust + CTA */
.cc-pro-foot{
  display:flex; justify-content:space-between; align-items:center;
  gap:.5rem; padding-top:.15rem; border-top:1px dashed var(--line); padding-top:.7rem;
}
.cc-pro-trust{
  display:inline-flex; align-items:center; gap:.3rem;
  font-size:.72rem; color:var(--muted); font-weight:600;
}
.cc-pro-check{
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:14px; border-radius:50%;
  background:var(--wa-green); color:#fff; font-size:.6rem; font-weight:900;
}
.cc-pro-dot{color:var(--line); font-weight:700}
.cc-pro-cta{
  display:inline-flex; align-items:center; gap:.3rem;
  padding:.35rem .7rem; border-radius:8px;
  background:#fff; border:1px solid var(--line); color:var(--wa-teal);
  font-size:.78rem; font-weight:700; transition:all .2s;
}
.cc-pro-cta svg{transition:transform .2s}

/* ---- Empty state ---- */
.browse-empty{
  text-align:center; padding:3.5rem 1.5rem;
  background:linear-gradient(180deg, #f6fbf8 0%, #fff 100%);
  border:1px dashed #b7e7c8; border-radius:18px;
}
.browse-empty-icon{font-size:2.4rem; margin-bottom:.6rem}
.browse-empty h3{margin:0 0 .35rem; font-size:1.2rem}
.browse-empty p{margin:0 0 1rem}

/* ---- Help strip below grid ---- */
.browse-help{
  display:flex; align-items:center; gap:1rem; flex-wrap:wrap;
  margin-top:2rem; padding:1rem 1.25rem;
  background:linear-gradient(135deg, #f6fbf8 0%, #ffffff 60%);
  border:1px solid #d6ecdb; border-radius:14px;
}
.browse-help-icon{
  width:42px; height:42px; flex-shrink:0;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--grad); color:#fff; border-radius:10px;
  font-size:1.3rem; box-shadow:var(--shadow-green);
}
.browse-help-text{flex:1; min-width:240px; line-height:1.4}
.browse-help-text strong{display:block; color:var(--text); font-size:.98rem; margin-bottom:.1rem}

/* =================================================================
   HOME PAGE — SALES-FOCUSED REDESIGN
   ================================================================= */

/* ---- Btn XL ---- */
.btn-xl{padding:1.05rem 2rem; font-size:1.05rem; font-weight:800; border-radius:12px}

/* ---- Hero pro ---- */
.hero-pro{padding:2.5rem 0 1.5rem !important; position:relative}
.hero-eyebrow-pro{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.4rem .85rem; border-radius:999px;
  background:rgba(37,211,102,.12); color:var(--wa-teal);
  font-size:.85rem; font-weight:700;
  border:1px solid rgba(37,211,102,.28); margin-bottom:1rem;
}
.hero-eyebrow-pulse{
  width:9px;height:9px;border-radius:50%;background:var(--wa-green);
  box-shadow:0 0 0 0 rgba(37,211,102,.6); animation:pulse 1.6s ease-out infinite;
}
.hero-title-pro{
  margin:0 0 1rem; font-size:3rem; font-weight:900;
  letter-spacing:-.03em; line-height:1.08; color:var(--text);
}
.hero-strike{
  position:relative; color:#94a3a3; font-weight:800;
}
.hero-strike::after{
  content:''; position:absolute; left:-2%; right:-2%; top:55%; height:5px;
  background:#ef4444; transform:rotate(-3deg); border-radius:3px;
}
@media(max-width:680px){.hero-title-pro{font-size:2rem}}

.hero-sub-pro{
  margin:0 0 1.5rem; font-size:1.1rem; color:var(--text-soft);
  max-width:60ch; line-height:1.55;
}

.hero-cta-pro{display:flex; gap:.75rem; flex-wrap:wrap; align-items:stretch; margin-bottom:1.25rem}
.hero-cta-main{
  flex-direction:column; align-items:center; padding:.95rem 1.75rem !important;
  text-align:center; line-height:1.15;
}
.hero-cta-sub{
  display:block; font-size:.7rem; font-weight:600; opacity:.85;
  margin-top:.25rem; letter-spacing:.02em;
}

.hero-trust-strip{
  display:flex; flex-wrap:wrap; gap:1.25rem;
  font-size:.85rem; color:var(--text-soft); font-weight:600;
}
.hts-item{display:inline-flex; align-items:center; gap:.3rem}

/* Floating savings badge over data preview */
.hero-card-wrap{position:relative}
.hero-floating-badge{
  position:absolute; top:-18px; right:-12px; z-index:3;
  width:110px; height:110px; padding:.6rem;
  background:var(--grad); color:#fff; border-radius:50%;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; box-shadow:0 14px 32px -10px rgba(37,211,102,.55), inset 0 1px 0 rgba(255,255,255,.3);
  transform:rotate(-8deg);
  animation:hfb-bob 3s ease-in-out infinite;
}
@keyframes hfb-bob{0%,100%{transform:rotate(-8deg) translateY(0)}50%{transform:rotate(-8deg) translateY(-4px)}}
.hfb-num{font-size:1.7rem; font-weight:900; letter-spacing:-.02em; line-height:1}
.hfb-lbl{font-size:.62rem; font-weight:700; line-height:1.15; margin-top:.15rem; opacity:.95}
@media(max-width:880px){.hero-floating-badge{display:none}}

/* Hero counter strip */
.hero-counter-strip{
  display:grid; grid-template-columns:repeat(5, 1fr); gap:.75rem;
  margin-top:2rem; padding:1rem 1.25rem;
  background:linear-gradient(135deg, #f6fbf8, #ffffff);
  border:1px solid #d6ecdb; border-radius:16px;
  box-shadow:var(--shadow-soft);
}
.hcs-item{text-align:center; border-right:1px dashed #cfe5d6; padding:.25rem 0}
.hcs-item:last-child{border-right:none}
.hcs-num{font-size:1.6rem; font-weight:900; color:var(--wa-teal); letter-spacing:-.02em}
.hcs-lbl{font-size:.72rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em; margin-top:.15rem}
@media(max-width:760px){
  .hero-counter-strip{grid-template-columns:repeat(2, 1fr); gap:.5rem}
  .hcs-item{border-right:none; border-bottom:1px dashed #cfe5d6; padding-bottom:.5rem}
  .hcs-item:last-child{border-bottom:none}
}

/* ---- Live activity ticker ---- */
.ticker-section{padding:1.25rem 0 .5rem}
.ticker-card{
  background:#fff; border:1px solid var(--line); border-radius:14px;
  padding:.85rem 1rem; box-shadow:var(--shadow-soft); overflow:hidden;
}
.ticker-label{
  display:flex; align-items:center; gap:.5rem;
  padding-bottom:.6rem; border-bottom:1px dashed var(--line);
  font-size:.85rem; color:var(--text-soft);
}
.ticker-track{
  display:flex; gap:1.5rem; overflow:hidden; padding:.6rem 0 .25rem;
  mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
@keyframes ticker-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-track{animation:ticker-scroll 35s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ticker-item{
  display:inline-flex; align-items:center; gap:.5rem; flex-shrink:0;
  padding:.4rem .85rem; background:var(--surface-2); border-radius:999px;
  font-size:.85rem; color:var(--text-soft);
}
.ticker-flag{font-size:1.1rem}
.ticker-amount{color:var(--wa-green-dark); font-weight:800}
.ticker-time{color:var(--muted); font-size:.75rem}

/* ---- Problem / Solution split ---- */
.problem-section{padding:3.5rem 0}
.problem-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:1.25rem;
}
@media(max-width:780px){.problem-grid{grid-template-columns:1fr}}
.problem-bad, .problem-good{
  padding:1.5rem 1.5rem 1.25rem; border-radius:16px;
  border:1px solid var(--line); position:relative; overflow:hidden;
}
.problem-bad{background:linear-gradient(135deg, #fff7f7 0%, #fff 80%); border-color:#fecaca}
.problem-good{background:linear-gradient(135deg, #f6fbf8 0%, #fff 80%); border-color:#b7e7c8}
.problem-bad-tag, .problem-good-tag{
  display:inline-block; padding:.35rem .85rem; border-radius:999px;
  font-size:.8rem; font-weight:800; margin-bottom:.85rem;
}
.problem-bad-tag{background:#fee2e2; color:#dc2626}
.problem-good-tag{background:#d1fae5; color:#047857}
.problem-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.55rem}
.problem-list li{font-size:.95rem; color:var(--text); line-height:1.45}
.problem-list-bad li{color:#7f1d1d}
.problem-list-good li{color:#064e3b}
.problem-list-good strong{color:var(--wa-green-dark)}

/* ---- ROI calculator ---- */
.roi-section{padding:3.5rem 0}
.roi-card{
  display:grid; grid-template-columns:1fr 1fr; gap:1.5rem;
  padding:1.75rem; background:#fff; border:1px solid var(--line); border-radius:18px;
  box-shadow:var(--shadow);
}
@media(max-width:760px){.roi-card{grid-template-columns:1fr; padding:1.25rem}}
.roi-controls{display:flex; flex-direction:column; gap:1.25rem}
.roi-field{display:flex; flex-direction:column; gap:.45rem}
.roi-lbl{font-weight:700; color:var(--text); font-size:.92rem}
.roi-field input[type=range]{
  -webkit-appearance:none; appearance:none; width:100%; height:6px;
  background:#e5e9eb; border-radius:6px; outline:none;
}
.roi-field input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none; appearance:none;
  width:22px; height:22px; border-radius:50%;
  background:var(--grad); cursor:pointer;
  box-shadow:0 4px 10px -2px rgba(37,211,102,.45);
  border:3px solid #fff;
}
.roi-field input[type=range]::-moz-range-thumb{
  width:22px; height:22px; border-radius:50%; background:#25D366; cursor:pointer; border:3px solid #fff;
}
.roi-val{font-weight:800; color:var(--wa-teal); font-size:1.1rem; align-self:flex-start}

.roi-results{
  display:flex; flex-direction:column; gap:.65rem;
  padding:1.25rem; background:linear-gradient(135deg, #f6fbf8, #fff);
  border:1px solid #d6ecdb; border-radius:14px;
}
.roi-row{display:flex; justify-content:space-between; align-items:center; font-size:.95rem; padding:.35rem 0}
.roi-row-lbl{color:var(--text-soft); font-weight:600}
.roi-row-val{font-weight:800; color:var(--text); font-size:1rem}
.roi-row-bad .roi-row-val{color:#dc2626; text-decoration:line-through}
.roi-row-save .roi-row-val{color:var(--wa-green-dark); font-size:1.4rem}
.roi-row-roi .roi-row-val{
  font-size:1.6rem;
  background:var(--grad-text); -webkit-background-clip:text; background-clip:text; color:transparent;
}
.roi-results hr{border:0; border-top:1px dashed #cfe5d6; margin:.4rem 0}

/* ---- Testimonials ---- */
.testimonials-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.25rem}
@media(max-width:920px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial-card{
  padding:1.5rem; background:#fff; border:1px solid var(--line); border-radius:16px;
  box-shadow:var(--shadow-soft); display:flex; flex-direction:column; gap:1rem;
}
.testimonial-stars{font-size:1.05rem; letter-spacing:.05em}
.testimonial-card p{margin:0; color:var(--text); font-size:1rem; line-height:1.5; font-style:italic}
.testimonial-author{display:flex; align-items:center; gap:.75rem; padding-top:.5rem; border-top:1px dashed var(--line)}
.ta-avatar{
  width:44px; height:44px; border-radius:50%; background:var(--grad); color:#fff;
  display:inline-flex; align-items:center; justify-content:center; font-weight:800; font-size:1.1rem;
}
.ta-name{font-weight:700; color:var(--text); line-height:1.2}
.ta-role{font-size:.78rem; color:var(--muted); font-weight:600}

/* ---- FAQ ---- */
.container-narrow-faq{max-width:820px; margin:0 auto; padding:0 1.25rem}
.section-title.center{text-align:center}
.section-sub.center{text-align:center}
.faq-list{display:flex; flex-direction:column; gap:.6rem; margin-top:1.5rem}
.faq-item{
  background:#fff; border:1px solid var(--line); border-radius:12px;
  padding:.1rem; transition:border-color .15s;
}
.faq-item[open]{border-color:#b7e7c8; box-shadow:var(--shadow-soft)}
.faq-item summary{
  cursor:pointer; padding:1rem 1.25rem; font-weight:700; color:var(--text);
  display:flex; justify-content:space-between; align-items:center;
  list-style:none; font-size:1rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+'; font-size:1.4rem; font-weight:400; color:var(--wa-green-dark);
  transition:transform .2s; line-height:1; flex-shrink:0; margin-left:1rem;
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:var(--wa-green-dark)}
.faq-body{
  padding:0 1.25rem 1rem; color:var(--text-soft); line-height:1.55; font-size:.94rem;
}

/* ---- CTA pro ---- */
.cta-card-pro{position:relative; padding:2.75rem 2rem 2.5rem !important; overflow:hidden}
.cta-card-pro::before{
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(600px 250px at 110% -20%, rgba(255,255,255,.18), transparent 60%),
    radial-gradient(500px 200px at -10% 110%, rgba(0,0,0,.05), transparent 60%);
  pointer-events:none;
}
.cta-urgency{
  display:inline-block; padding:.45rem 1rem; border-radius:999px;
  background:rgba(255,255,255,.18); color:#fff; font-size:.85rem; font-weight:700;
  margin-bottom:1rem; border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(4px);
}
.cta-highlight{
  display:inline-block; padding:.05em .35em; background:#fff;
  color:var(--wa-teal); border-radius:6px; box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.cta-trust-row{
  display:flex; justify-content:center; flex-wrap:wrap; gap:1.25rem;
  margin-top:1.5rem; font-size:.85rem; opacity:.95;
}
.cta-trust-row span{font-weight:600}

/* =================================================================
   ADMIN ANALYTICS DASHBOARD
   ================================================================= */
.an-range{display:flex; align-items:center; gap:.35rem}
.an-range-lbl{font-size:.85rem; color:var(--muted); font-weight:600; margin-right:.4rem}
.an-range-btn{
  display:inline-flex; align-items:center; padding:.45rem .8rem;
  border-radius:8px; background:var(--surface-2); color:var(--text-soft);
  font-size:.85rem; font-weight:700; text-decoration:none; transition:all .15s;
  border:1px solid transparent;
}
.an-range-btn:hover{background:#eaf6ee; color:var(--wa-teal); text-decoration:none}
.an-range-btn.active{background:var(--grad); color:#fff; box-shadow:var(--shadow-green)}
.an-range-btn.active:hover{color:#fff}

/* KPI cards */
.an-kpis{display:grid; grid-template-columns:repeat(5, 1fr); gap:.85rem; margin-bottom:.5rem}
@media(max-width:1100px){.an-kpis{grid-template-columns:repeat(3, 1fr)}}
@media(max-width:680px){.an-kpis{grid-template-columns:repeat(2, 1fr)}}
.an-kpi{
  padding:1.1rem 1.15rem; background:#fff; border:1px solid var(--line);
  border-radius:14px; box-shadow:var(--shadow-soft); display:flex; flex-direction:column; gap:.3rem;
  position:relative; overflow:hidden;
}
.an-kpi-primary{
  background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%);
  border-color:#b7e7c8;
}
.an-kpi-bot{opacity:.85}
.an-kpi-lbl{font-size:.76rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em}
.an-kpi-num{font-size:2rem; font-weight:900; color:var(--text); letter-spacing:-.02em; line-height:1.05}
.an-kpi-primary .an-kpi-num{color:var(--wa-teal)}
.an-kpi-meta{font-size:.78rem; color:var(--muted); display:flex; align-items:center; gap:.4rem}
.an-delta{font-weight:800; padding:.1rem .4rem; border-radius:5px}
.an-delta.up{background:#d1fae5; color:#047857}
.an-delta.down{background:#fee2e2; color:#dc2626}
.an-delta.flat{background:var(--surface-2); color:var(--muted)}

/* Chart */
.an-chart-wrap{padding:.5rem 0; overflow:hidden}
.an-chart{width:100%; height:auto; display:block; max-height:240px}

/* Funnel */
.an-funnel{display:flex; flex-direction:column; gap:.75rem; margin-top:.5rem}
.an-funnel-row{display:flex; align-items:center; gap:1rem}
.an-funnel-bar{
  display:flex; align-items:center; gap:.65rem;
  padding:.85rem 1.15rem; border-radius:10px;
  background:var(--grad); color:#fff;
  box-shadow:0 6px 16px -8px rgba(37,211,102,.45);
  min-width:180px;
}
.an-funnel-icon{font-size:1.3rem}
.an-funnel-lbl{font-weight:700; flex:1}
.an-funnel-num{font-weight:900; font-size:1.15rem}
.an-funnel-conv{font-size:.85rem; color:var(--muted); font-weight:700}

/* Tables */
.an-tbl th{font-weight:700; color:var(--text-soft); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em}
.an-tbl td{font-size:.9rem; padding:.5rem .65rem; border-bottom:1px solid var(--line-soft)}
.an-tbl th.r, .an-tbl td.r{text-align:right}
.an-tbl th.bar, .an-tbl td.bar{width:160px}
.an-path{font-family:ui-monospace, monospace; color:var(--wa-teal); font-size:.86rem}
.an-ref{font-family:ui-monospace, monospace; color:var(--text); font-size:.86rem}

/* Bar / sparkbar */
.an-bar{display:inline-block; width:100%; height:8px; background:var(--surface-2); border-radius:4px; overflow:hidden}
.an-bar-fill{display:block; height:100%; background:var(--grad); border-radius:4px}
.an-bar-fill.an-bar-blue{background:linear-gradient(90deg, #34B7F1, #0284c7)}

/* Devices */
.an-devices{display:flex; flex-direction:column; gap:.5rem}
.an-device{display:flex; flex-direction:column; gap:.25rem}
.an-device-lbl{display:flex; justify-content:space-between; font-size:.85rem; color:var(--text)}
.an-device-name{font-weight:700; text-transform:capitalize}
.an-device-num{color:var(--muted); font-weight:600}

/* SEO submit card */
.an-seo-card{background:linear-gradient(135deg, #f6fbf8 0%, #fff 100%); border-color:#b7e7c8}
.an-seo-list{padding-left:1.1rem; margin:.5rem 0 0; display:flex; flex-direction:column; gap:.5rem}
.an-seo-list li{font-size:.92rem; line-height:1.55}

/* =================================================================
   PHASE-2 FEATURES — bundles, blog, reviews, scarcity, guarantee, vs, etc
   ================================================================= */

/* ---- Cookie banner ---- */
.cookie-banner{
  position:fixed; left:1rem; right:1rem; bottom:1rem; z-index:200;
  max-width:780px; margin:0 auto;
  background:#0d1117; color:#e6edf3; border-radius:14px;
  box-shadow:0 16px 40px -12px rgba(0,0,0,.35);
  border:1px solid #30363d;
  animation:cookie-in .3s ease-out;
}
@keyframes cookie-in{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.cookie-banner-inner{display:flex;align-items:center;gap:1rem;padding:.85rem 1rem;flex-wrap:wrap}
.cookie-banner-text{flex:1;min-width:240px;font-size:.88rem;line-height:1.45}
.cookie-banner-text a{color:var(--wa-green); text-decoration:underline}
.cookie-banner-actions{display:flex;gap:.4rem;flex-shrink:0}
.cookie-banner .btn{font-size:.85rem;padding:.5rem 1rem}
.cookie-banner .btn-outline{border-color:#30363d; color:#e6edf3}
.cookie-banner .btn-outline:hover{background:#1c2329; color:#fff; border-color:#56606b}

/* ---- Money-back guarantee page ---- */
.guarantee-hero{padding:3rem 0 2rem; background:radial-gradient(700px 350px at 50% -20%, rgba(37,211,102,.12), transparent 60%)}
.guarantee-hero-inner{max-width:780px; margin:0 auto; padding:0 1.25rem; text-align:center}
.guarantee-badge{display:inline-block; margin:0 0 1.5rem}
.gb-ring{
  width:170px; height:170px; border-radius:50%;
  background:var(--grad); color:#fff;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  box-shadow:0 18px 40px -12px rgba(37,211,102,.45), inset 0 2px 0 rgba(255,255,255,.25);
  border:5px solid #fff;
}
.gb-num{font-size:2.6rem; font-weight:900; letter-spacing:-.02em; line-height:1}
.gb-lbl{font-size:.7rem; font-weight:800; letter-spacing:.1em; opacity:.9; margin-top:.2rem}
.guarantee-title{font-size:2.4rem; font-weight:900; letter-spacing:-.025em; margin:0 0 .85rem; line-height:1.15}
.guarantee-sub{font-size:1.1rem; color:var(--text-soft); margin:0 0 1.5rem; line-height:1.6}
.guarantee-cta{display:flex; gap:.65rem; justify-content:center; flex-wrap:wrap}
.g-step{
  display:grid; grid-template-columns:auto 1fr; gap:1.25rem; align-items:flex-start;
  padding:1.25rem 1.5rem; background:#fff; border:1px solid var(--line); border-radius:14px;
  margin-bottom:1rem; box-shadow:var(--shadow-soft);
}
.g-step-num{
  width:48px; height:48px; border-radius:50%; background:var(--grad); color:#fff;
  display:inline-flex; align-items:center; justify-content:center; font-size:1.4rem; font-weight:900;
  flex-shrink:0;
}
.g-step-body h3{margin:0 0 .35rem; font-size:1.1rem}
.g-step-body p{margin:0; color:var(--text-soft); line-height:1.55}
.g-fine-list{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.65rem}
.g-fine-list li{padding:.85rem 1.1rem; background:var(--surface-2); border-radius:8px; font-size:.94rem; line-height:1.5}
.g-fine-list strong{color:var(--wa-teal)}
.g-trust-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1rem}
@media(max-width:760px){.g-trust-grid{grid-template-columns:1fr}}
.g-trust-card{
  text-align:center; padding:1.5rem 1.25rem; background:#fff;
  border:1px solid var(--line); border-radius:14px; box-shadow:var(--shadow-soft);
}
.g-trust-icon{font-size:2.2rem; margin-bottom:.5rem}
.g-trust-card h3{margin:0 0 .35rem}
.g-trust-card p{margin:0; color:var(--text-soft); font-size:.92rem}

/* ---- Comparison page (vs) ---- */
.vs-hero{padding:3rem 0 1.5rem; background:linear-gradient(180deg, #f6fbf8, transparent)}
.vs-hero-inner{max-width:880px; margin:0 auto; padding:0 1.25rem; text-align:center}
.vs-versus{display:flex; justify-content:center; align-items:center; gap:1.5rem; margin-bottom:1.5rem; flex-wrap:wrap}
.vs-side{display:flex; flex-direction:column; align-items:center; gap:.5rem; min-width:120px}
.vs-logo{width:64px; height:64px; border-radius:14px; display:inline-flex; align-items:center; justify-content:center; background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-soft); font-size:2rem}
.vs-logo-other{background:#f3f4f6}
.vs-name{font-weight:800; color:var(--text); font-size:.95rem}
.vs-side-us .vs-name{color:var(--wa-green-dark)}
.vs-vs{font-size:1.4rem; font-weight:900; color:var(--muted); padding:0 1rem}
.vs-title{font-size:2.1rem; font-weight:900; letter-spacing:-.02em; margin:0 0 .75rem; line-height:1.18}
@media(max-width:560px){.vs-title{font-size:1.5rem}}
.vs-sub{font-size:1rem; color:var(--text-soft); margin:0; line-height:1.55}

.vs-table-wrap{overflow-x:auto; margin-top:1.25rem}
.vs-table{width:100%; min-width:680px; border-collapse:collapse; background:#fff; border:1px solid var(--line); border-radius:14px; overflow:hidden; box-shadow:var(--shadow-soft)}
.vs-table th, .vs-table td{padding:.95rem 1.1rem; text-align:left; vertical-align:top; border-bottom:1px solid var(--line-soft)}
.vs-table th{background:var(--surface-2); font-weight:800; font-size:.92rem}
.vs-col-us{color:var(--wa-green-dark); width:34%}
.vs-col-them{color:var(--text-soft); width:34%}
.vs-feature{font-weight:700; color:var(--text); width:32%}
.vs-cell{display:flex; align-items:flex-start; gap:.55rem; font-size:.92rem}
.vs-mark{display:inline-flex; align-items:center; justify-content:center; width:20px; height:20px; border-radius:50%; font-weight:900; font-size:.8rem; flex-shrink:0}
.vs-mark-good{background:#d1fae5; color:#047857}
.vs-mark-bad{background:#fee2e2; color:#dc2626}
.vs-cell-us{font-weight:600}
.vs-wins, .vs-fairness{padding-left:1.25rem; display:flex; flex-direction:column; gap:.6rem}
.vs-wins li, .vs-fairness li{font-size:.95rem; line-height:1.55}
.vs-fairness li{color:var(--text-soft)}

/* ---- Scarcity strip on country detail ---- */
.scarcity-strip{
  display:flex; flex-wrap:wrap; gap:.75rem 1.25rem; align-items:center;
  padding:.75rem 1rem; margin-top:1rem;
  background:linear-gradient(135deg, #f6fbf8, #fff);
  border:1px solid #b7e7c8; border-radius:12px;
  font-size:.88rem;
}
.scarcity-cell{display:inline-flex; align-items:center; gap:.4rem}
.scarcity-cell strong{color:var(--text)}
.scarcity-stock strong{color:var(--wa-green-dark)}
.scarcity-pulse{
  width:9px; height:9px; border-radius:50%; background:var(--wa-green);
  box-shadow:0 0 0 0 rgba(37,211,102,.6); animation:pulse 1.6s ease-out infinite;
  margin-right:.15rem;
}
.scarcity-recent strong{color:#c2410c}
.scarcity-fresh strong{color:var(--wa-blue)}

/* ---- Per-country content / SEO copy ---- */
.country-content{padding:2rem 1.25rem}
.country-content .section-title{margin-bottom:.85rem}
.country-content .cc-h3{margin:1.5rem 0 .65rem; font-size:1.15rem; color:var(--wa-teal); font-weight:800}
.cc-prose{color:var(--text-soft); line-height:1.7; font-size:1rem}
.cc-prose p{margin:0 0 1rem}
.cc-prose ul, .cc-prose ol{padding-left:1.5rem; margin:0 0 1rem}
.cc-prose li{margin-bottom:.35rem}
.cc-prose a{color:var(--wa-green-dark); text-decoration:underline}
.cc-prose strong{color:var(--text)}

/* ---- Reviews ---- */
.reviews-section{padding:2rem 1.25rem}
.reviews-head{display:flex; justify-content:space-between; align-items:flex-end; gap:1rem; flex-wrap:wrap; margin-bottom:1.25rem}
.rv-stars{display:inline-flex; gap:1px; vertical-align:middle}
.rv-star{font-size:1rem; color:#d6dde0; line-height:1}
.rv-star.on{color:#f59e0b}
.rv-form{
  background:#fff; border:1px solid #b7e7c8; border-radius:14px; padding:1.25rem; margin-bottom:1.25rem;
  display:flex; flex-direction:column; gap:.85rem;
}
.rv-form label{display:flex; flex-direction:column; gap:.3rem; font-weight:700; font-size:.88rem; color:var(--text)}
.rv-form input, .rv-form textarea, .rv-form select{
  font:inherit; font-size:.95rem; padding:.65rem .85rem;
  border:1px solid var(--line); border-radius:8px; background:#fff; color:var(--text);
}
.rv-form input:focus, .rv-form textarea:focus, .rv-form select:focus{outline:none; border-color:var(--wa-green); box-shadow:0 0 0 3px rgba(37,211,102,.15)}
.rv-form-row{display:grid; grid-template-columns:1fr 2fr; gap:.75rem}
@media(max-width:560px){.rv-form-row{grid-template-columns:1fr}}
.rv-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:1rem}
@media(max-width:760px){.rv-grid{grid-template-columns:1fr}}
.rv-card{
  padding:1.25rem; background:#fff; border:1px solid var(--line); border-radius:12px;
  display:flex; flex-direction:column; gap:.65rem; box-shadow:var(--shadow-soft);
}
.rv-card-head{display:flex; justify-content:space-between; align-items:center; gap:.5rem}
.rv-verified{font-size:.72rem; color:var(--wa-green-dark); font-weight:800; padding:.18rem .55rem; background:#d1fae5; border-radius:999px}
.rv-title{font-weight:800; color:var(--text); font-size:1rem; margin:.2rem 0}
.rv-body{margin:0; color:var(--text-soft); line-height:1.55; font-size:.94rem; font-style:italic}
.rv-foot{font-size:.82rem; color:var(--text-soft); padding-top:.4rem; border-top:1px dashed var(--line)}

/* Admin reviews */
.rv-admin-card{padding:1rem 1.25rem}
.rv-admin-head{display:flex; justify-content:space-between; align-items:center; gap:.5rem}
.rv-admin-foot{display:flex; justify-content:space-between; align-items:center; gap:.75rem; padding-top:.75rem; border-top:1px dashed var(--line); flex-wrap:wrap}
.rv-admin-actions{display:flex; gap:.35rem}

/* ---- Bundles list ---- */
.bundle-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.25rem}
@media(max-width:980px){.bundle-grid{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:620px){.bundle-grid{grid-template-columns:1fr}}
.bundle-card{
  position:relative; display:flex; flex-direction:column; gap:.7rem;
  padding:1.5rem 1.25rem 1.25rem; background:#fff; border:1px solid var(--line); border-radius:16px;
  text-decoration:none; color:var(--text); transition:all .2s; box-shadow:var(--shadow-soft);
}
.bundle-card:hover{transform:translateY(-3px); border-color:#b7e7c8; box-shadow:var(--shadow); text-decoration:none; color:var(--text)}
.bundle-card.is-popular{border-color:var(--wa-green); box-shadow:var(--shadow-green)}
.bundle-badge{
  position:absolute; top:-12px; left:50%; transform:translateX(-50%);
  padding:.25rem .75rem; background:var(--grad); color:#fff;
  font-size:.68rem; font-weight:800; border-radius:6px; letter-spacing:.06em;
  box-shadow:var(--shadow-green); white-space:nowrap;
}
.bundle-badge-inline{position:static; transform:none; display:inline-block; margin-bottom:.5rem}
.bundle-emoji{font-size:2.2rem}
.bundle-name{margin:0; font-size:1.15rem; font-weight:800; color:var(--text); line-height:1.25}
.bundle-tagline{margin:0; color:var(--text-soft); font-size:.9rem; line-height:1.45}
.bundle-meta{display:flex; flex-wrap:wrap; gap:.35rem}
.bundle-pill{font-size:.7rem; font-weight:700; padding:.18rem .55rem; background:var(--surface-2); color:var(--text-soft); border-radius:999px}
.bundle-price-row{display:flex; justify-content:space-between; align-items:flex-end; padding-top:.6rem; margin-top:auto; border-top:1px dashed var(--line)}
.bundle-price{display:flex; align-items:baseline; gap:.4rem}
.bundle-orig{color:var(--muted); text-decoration:line-through; font-size:.95rem}
.bundle-final{font-size:1.5rem; font-weight:900; color:var(--wa-green-dark)}
.bundle-save{padding:.2rem .55rem; background:#fef3c7; color:#92400e; font-size:.78rem; font-weight:800; border-radius:5px}

/* Bundle detail */
.bundle-hero{padding:2rem 1.25rem 1rem}
.bundle-hero-grid{
  display:grid; grid-template-columns:auto 1fr 280px; gap:1.5rem; align-items:start;
  background:linear-gradient(135deg, #f6fbf8, #fff);
  border:1px solid #b7e7c8; border-radius:18px; padding:1.5rem;
}
@media(max-width:880px){.bundle-hero-grid{grid-template-columns:1fr}}
.bundle-hero-icon{font-size:4rem; line-height:1}
.bundle-hero-title{margin:.25rem 0; font-size:2rem; font-weight:900; letter-spacing:-.02em; line-height:1.18}
.bundle-hero-tagline{margin:0 0 .5rem; color:var(--text-soft); font-size:1.05rem}
.bundle-hero-desc{color:var(--text-soft); margin:.5rem 0 0; line-height:1.55}
.bundle-hero-stats{display:flex; gap:1.5rem; margin-top:1rem; flex-wrap:wrap}
.bundle-hero-stats > div{display:flex; flex-direction:column; line-height:1.1}
.bundle-hero-stats strong{font-size:1.5rem; color:var(--wa-teal); font-weight:900; letter-spacing:-.02em}
.bundle-hero-stats span{font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.05em; font-weight:700; margin-top:.2rem}
.bundle-hero-buy{
  padding:1.25rem; background:#fff; border:1px solid var(--line); border-radius:14px;
  text-align:center; box-shadow:var(--shadow-soft);
}
.bundle-hero-orig{color:var(--muted); text-decoration:line-through; font-size:1.05rem}
.bundle-hero-final{font-size:2.4rem; font-weight:900; color:var(--wa-green-dark); letter-spacing:-.02em; line-height:1}
.bundle-hero-save{font-size:.85rem; color:#92400e; background:#fef3c7; display:inline-block; padding:.2rem .65rem; border-radius:5px; font-weight:800; margin:.4rem 0 .85rem}

.bundle-items{padding:2rem 1.25rem}
.bundle-items-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:.75rem}
@media(max-width:760px){.bundle-items-grid{grid-template-columns:1fr}}
.bundle-item{display:grid; grid-template-columns:auto 1fr auto; gap:.75rem; align-items:center; padding:.85rem 1rem; background:#fff; border:1px solid var(--line); border-radius:10px}
.bundle-item-flag{border-radius:4px; box-shadow:0 1px 3px rgba(0,0,0,.15)}
.bundle-item-name{font-size:.95rem; line-height:1.3}
.bundle-item-detail{margin-top:.15rem}
.bundle-item-price{text-align:right; line-height:1.1}
.bundle-item-price strong{display:block; font-size:1rem; color:var(--text)}

/* ---- Blog ---- */
.blog-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:1.5rem}
@media(max-width:980px){.blog-grid{grid-template-columns:repeat(2, 1fr)}}
@media(max-width:620px){.blog-grid{grid-template-columns:1fr}}
.blog-card{
  display:flex; flex-direction:column;
  background:#fff; border:1px solid var(--line); border-radius:14px;
  text-decoration:none; color:var(--text); overflow:hidden; transition:all .2s;
  box-shadow:var(--shadow-soft);
}
.blog-card:hover{transform:translateY(-3px); border-color:#b7e7c8; box-shadow:var(--shadow); text-decoration:none; color:var(--text)}
.blog-card-cover{
  height:180px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg, #f6fbf8, #ffffff);
  border-bottom:1px solid var(--line);
}
.blog-card-cover img{width:100%; height:100%; object-fit:cover}
.blog-card-emoji{font-size:3.5rem; line-height:1}
.blog-card-body{padding:1.25rem; display:flex; flex-direction:column; gap:.6rem; flex:1}
.blog-card-tags{display:flex; flex-wrap:wrap; gap:.3rem}
.blog-tag{font-size:.7rem; font-weight:700; padding:.15rem .55rem; background:var(--surface-2); color:var(--wa-teal); border-radius:999px; text-transform:uppercase; letter-spacing:.04em}
.blog-card-title{margin:0; font-size:1.15rem; font-weight:800; color:var(--text); line-height:1.3}
.blog-card-excerpt{margin:0; color:var(--text-soft); font-size:.9rem; line-height:1.5; flex:1}
.blog-card-meta{font-size:.78rem; color:var(--muted); padding-top:.5rem; border-top:1px dashed var(--line)}

/* Blog post */
.blog-post{padding-bottom:3rem}
.blog-post-head{padding:2rem 1.25rem 1rem; max-width:820px; margin:0 auto; text-align:center}
.blog-post-tags{display:flex; gap:.4rem; justify-content:center; margin-bottom:.85rem}
.blog-post-title{font-size:2.4rem; font-weight:900; letter-spacing:-.025em; margin:0 0 .65rem; line-height:1.18}
@media(max-width:560px){.blog-post-title{font-size:1.7rem}}
.blog-post-excerpt{font-size:1.1rem; color:var(--text-soft); margin:0 0 1rem; line-height:1.55}
.blog-post-meta{font-size:.9rem; color:var(--muted)}
.blog-post-cover{margin:1.5rem auto; max-width:1000px; padding:0 1.25rem}
.blog-post-cover img{width:100%; height:auto; border-radius:14px; box-shadow:var(--shadow)}
.blog-post-cover-emoji{
  text-align:center; font-size:6rem;
  background:linear-gradient(135deg, #f6fbf8, #fff);
  padding:3rem; border-radius:14px; max-width:600px; margin:1.5rem auto;
}
.blog-post-body{padding:1rem 1.25rem; font-size:1.05rem; line-height:1.75; color:var(--text)}
.blog-post-body h2{font-size:1.6rem; margin:2.2rem 0 1rem; font-weight:800; color:var(--text)}
.blog-post-body h3{font-size:1.25rem; margin:1.8rem 0 .85rem; font-weight:800; color:var(--wa-teal)}
.blog-post-body p{margin:0 0 1.2rem}
.blog-post-body ul, .blog-post-body ol{padding-left:1.5rem; margin:0 0 1.2rem}
.blog-post-body li{margin-bottom:.45rem}
.blog-post-body a{color:var(--wa-green-dark); text-decoration:underline}
.blog-post-body blockquote{margin:1.5rem 0; padding:1rem 1.25rem; background:var(--surface-2); border-left:4px solid var(--wa-green); border-radius:0 8px 8px 0; color:var(--text-soft); font-style:italic}
.blog-post-body code{background:#f0f5f7; padding:.1em .35em; border-radius:5px; font-size:.92em; color:var(--wa-teal)}
.blog-post-body pre{background:#0d1117; color:#e6edf3; padding:1rem; border-radius:8px; overflow-x:auto; margin:0 0 1.2rem}
.blog-post-body pre code{background:transparent; color:inherit; padding:0}
.blog-post-body img{max-width:100%; border-radius:8px; margin:1rem 0}

.blog-post-cta{margin-top:2.5rem; padding:2rem 1.5rem; background:linear-gradient(135deg, #f6fbf8, #fff); border:1px solid #b7e7c8; border-radius:14px; text-align:center}
.blog-post-cta h3{margin:0 0 .5rem}
.blog-post-cta p{margin:0 0 1rem; color:var(--text-soft)}
.blog-post-cta .btn{margin:.25rem}

.blog-related{padding:2rem 1.25rem}

/* ---- Quality report (rendered inside .card on order detail) ---- */
.qr{font-size:.95rem; line-height:1.55}
.qr-head{display:flex; justify-content:space-between; align-items:flex-start; gap:1rem; padding-bottom:1rem; border-bottom:1px solid var(--line); margin-bottom:1rem}
.qr-eyebrow{font-size:.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; font-weight:700}
.qr-title{margin:.25rem 0 .15rem; font-size:1.5rem; font-weight:900; color:var(--text)}
.qr-sub{margin:0; color:var(--text-soft); font-size:.92rem}
.qr-stamp{
  padding:.45rem .85rem; background:#d1fae5; color:#047857;
  font-weight:900; font-size:.85rem; letter-spacing:.06em;
  border-radius:8px; flex-shrink:0; box-shadow:inset 0 0 0 1px #34d399;
}
.qr-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:.75rem; margin:1rem 0}
@media(max-width:680px){.qr-grid{grid-template-columns:repeat(2, 1fr)}}
.qr-stat{padding:.85rem 1rem; background:var(--surface-2); border-radius:10px; border:1px solid var(--line)}
.qr-stat-good{background:linear-gradient(135deg, #f0fdf4, #fff); border-color:#bbf7d0}
.qr-stat-num{font-size:1.6rem; font-weight:900; color:var(--text); letter-spacing:-.02em; line-height:1.05}
.qr-stat-good .qr-stat-num{color:var(--wa-green-dark)}
.qr-stat-lbl{font-size:.78rem; color:var(--text-soft); font-weight:700; margin:.25rem 0 .15rem}
.qr-stat-detail{font-size:.78rem; color:var(--muted)}
.qr-breakdown{margin:1.5rem 0}
.qr-breakdown h3{margin:0 0 .65rem; font-size:1rem; color:var(--text-soft)}
.qr-tbl{width:100%; border-collapse:collapse; font-size:.88rem}
.qr-tbl th{padding:.5rem .65rem; background:var(--surface-2); font-weight:700; text-align:left; color:var(--text-soft); font-size:.78rem; text-transform:uppercase; letter-spacing:.04em}
.qr-tbl td{padding:.55rem .65rem; border-bottom:1px solid var(--line-soft)}
.qr-tbl .r{text-align:right}
.qr-note{padding:1rem 1.25rem; background:#fefce8; border:1px solid #fde68a; border-radius:8px; font-size:.85rem; line-height:1.6; color:#713f12}
.qr-note strong{color:#854d0e}
.qr-note a{color:#854d0e; text-decoration:underline}

/* ---- GDPR / Privacy portal ---- */
.priv-pending{background:linear-gradient(135deg, #fef3c7, #fff); border:1px solid #fde68a; padding:1.25rem}
.priv-counts{list-style:none; padding:0; margin:.85rem 0; display:grid; grid-template-columns:repeat(2, 1fr); gap:.4rem}
.priv-counts li{padding:.5rem .75rem; background:var(--surface-2); border-radius:6px; font-size:.92rem}
.priv-counts strong{color:var(--wa-teal); font-weight:800}
.priv-warn{background:#fef3c7; color:#854d0e; padding:.65rem .85rem; border-radius:8px; font-size:.88rem; margin:.65rem 0}
.priv-info{background:#d1fae5; color:#047857; padding:.65rem .85rem; border-radius:8px; font-size:.88rem; margin:.65rem 0}
.btn-danger{color:#dc2626; border-color:#fecaca}
.btn-danger:hover{background:#fee2e2; color:#dc2626; border-color:#dc2626}
.priv-tbl{width:100%; border-collapse:collapse; font-size:.92rem}
.priv-tbl td{padding:.6rem .75rem; border-bottom:1px solid var(--line-soft); vertical-align:top}
.priv-tbl td:first-child{width:30%; color:var(--text)}

/* ---- Admin form helpers used in new admin pages ---- */
.cc-form{display:flex; flex-direction:column; gap:.85rem; padding:1.5rem}
.cc-form label{display:flex; flex-direction:column; gap:.3rem; font-weight:700; color:var(--text); font-size:.88rem}
.cc-form input, .cc-form textarea, .cc-form select{
  font:inherit; font-size:.95rem; padding:.65rem .85rem;
  border:1px solid var(--line); border-radius:8px; background:#fff; color:var(--text);
}
.cc-form .cc-mono{font-family:ui-monospace, 'JetBrains Mono', monospace; font-size:.85rem}
.cc-form .grid label{margin-bottom:0}
.cc-form .cb-row{flex-direction:row; align-items:center; gap:.5rem; padding:.65rem .85rem; background:var(--surface-2); border-radius:8px}
.cc-form .cb-row input{width:auto}
.grid-4{display:grid; grid-template-columns:repeat(4, 1fr); gap:.85rem}
@media(max-width:760px){.grid-4{grid-template-columns:1fr 1fr}}

/* =================================================================
   ADMIN OVERHAUL — search, badges, dashboard, filter pills, activity
   ================================================================= */

/* ---- Top-bar global search ---- */
.admin-topbar-search{
  flex:1; max-width:520px; min-width:0;
  display:flex; align-items:center; gap:.5rem;
  padding:.45rem .9rem;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12);
  border-radius:10px; color:#dcf8c6; transition:all .15s;
}
.admin-topbar-search:focus-within{
  background:rgba(255,255,255,.14); border-color:rgba(37,211,102,.6);
  box-shadow:0 0 0 3px rgba(37,211,102,.18);
}
.admin-topbar-search svg{color:#9bdcc8; flex-shrink:0}
.admin-topbar-search input{
  flex:1; background:transparent; border:none; outline:none;
  color:#fff; font-family:inherit; font-size:.92rem;
}
.admin-topbar-search input::placeholder{color:#9bdcc8; opacity:.7}
.admin-topbar-kbd{
  font-family:inherit; font-size:.85rem; color:#9bdcc8; opacity:.8;
  flex-shrink:0;
}
@media(max-width:980px){.admin-topbar-search{display:none}}

/* ---- Sidebar notification badges ---- */
.admin-nav-badge{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:20px; height:18px; padding:0 .4rem; margin-left:auto;
  background:#ef4444; color:#fff; font-size:.68rem; font-weight:800;
  border-radius:999px; line-height:1;
  box-shadow:0 2px 4px rgba(239,68,68,.3);
}
.admin-nav a.active .admin-nav-badge{background:#fff; color:#dc2626; box-shadow:none}

/* ---- Dashboard "Needs Attention" ---- */
.d-attn{
  display:flex; gap:1rem; align-items:flex-start;
  padding:1rem 1.25rem; margin-bottom:1.25rem;
  background:linear-gradient(135deg, #fef3c7, #fff7ed);
  border:1px solid #fde68a; border-radius:14px;
  box-shadow:var(--shadow-soft);
}
.d-attn-clear{background:linear-gradient(135deg, #d1fae5, #f0fdf4); border-color:#bbf7d0}
.d-attn-icon{
  width:44px; height:44px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  background:#fff; border-radius:10px; font-size:1.5rem;
  box-shadow:var(--shadow-soft);
}
.d-attn-body{flex:1; min-width:0}
.d-attn-title{font-weight:800; color:#854d0e; font-size:1.02rem; margin-bottom:.5rem}
.d-attn-clear .d-attn-title{color:#047857}
.d-attn-list{display:flex; flex-wrap:wrap; gap:.5rem}
.d-attn-item{
  display:inline-flex; align-items:center; gap:.5rem;
  padding:.5rem .85rem; background:#fff; border:1px solid #fde68a;
  border-radius:999px; color:#854d0e; font-weight:600; font-size:.88rem;
  text-decoration:none; transition:all .15s;
}
.d-attn-item:hover{transform:translateY(-1px); box-shadow:var(--shadow-soft); color:#854d0e; text-decoration:none}
.d-attn-num{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:24px; height:24px; padding:0 .45rem; background:#dc2626; color:#fff;
  font-weight:800; font-size:.78rem; border-radius:999px;
}
.d-attn-emoji{font-size:1.05rem; line-height:1}
.d-attn-lbl{color:#7c2d12}

/* ---- Dashboard KPI cards ---- */
.d-kpis{display:grid; grid-template-columns:repeat(6, 1fr); gap:.85rem; margin-bottom:.5rem}
@media(max-width:1200px){.d-kpis{grid-template-columns:repeat(3, 1fr)}}
@media(max-width:680px){.d-kpis{grid-template-columns:repeat(2, 1fr)}}
.d-kpi{
  padding:1rem 1.1rem; background:#fff; border:1px solid var(--line);
  border-radius:12px; box-shadow:var(--shadow-soft);
  display:flex; flex-direction:column; gap:.3rem;
}
.d-kpi-primary{background:linear-gradient(135deg, #f6fbf8, #fff); border-color:#b7e7c8}
.d-kpi-lbl{font-size:.72rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em}
.d-kpi-num{font-size:1.7rem; font-weight:900; color:var(--text); letter-spacing:-.02em; line-height:1.05}
.d-kpi-primary .d-kpi-num{color:var(--wa-teal)}
.d-kpi-meta{font-size:.78rem; color:var(--muted); display:flex; align-items:center; gap:.4rem}
.d-delta{font-weight:800; padding:.1rem .4rem; border-radius:5px}
.d-delta.up{background:#d1fae5; color:#047857}
.d-delta.down{background:#fee2e2; color:#dc2626}
.d-delta.flat{background:var(--surface-2); color:var(--muted)}

/* ---- Dashboard charts row ---- */
.d-charts{display:grid; grid-template-columns:repeat(3, 1fr); gap:.85rem; margin-top:1rem}
@media(max-width:980px){.d-charts{grid-template-columns:1fr}}
.d-chart-card{
  padding:1rem 1.1rem .55rem; background:#fff;
  border:1px solid var(--line); border-radius:12px;
  box-shadow:var(--shadow-soft);
}
.d-chart-head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:.4rem; gap:.5rem}
.d-chart-lbl{font-size:.78rem; color:var(--muted); font-weight:700; text-transform:uppercase; letter-spacing:.05em}
.d-chart-total{font-size:1.15rem; font-weight:800; color:var(--text)}
.d-chart-svg{width:100%; height:80px; display:block}

/* ---- Dashboard activity list ---- */
.d-activity{list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:.4rem}
.d-activity li{
  display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
  padding:.5rem .65rem; background:var(--surface-2); border-radius:8px;
  font-size:.85rem;
}
.d-activity-when{flex-shrink:0; min-width:64px}
.d-activity-action{color:var(--text-soft)}
.d-activity li code{font-size:.78rem; color:var(--wa-teal); background:#fff; padding:.05em .35em; border-radius:4px; border:1px solid var(--line-soft)}

/* ---- Filter pillbar (admin lists) ---- */
.al-pillbar{
  display:flex; flex-wrap:wrap; gap:.4rem; margin:0 0 1rem;
  padding:.5rem; background:#fff; border:1px solid var(--line);
  border-radius:10px; box-shadow:var(--shadow-soft);
}
.al-pill{
  display:inline-flex; align-items:center; gap:.4rem;
  padding:.4rem .85rem; border-radius:8px;
  background:var(--surface-2); color:var(--text-soft);
  font-size:.85rem; font-weight:700; text-decoration:none;
  border:1px solid transparent; transition:all .15s;
  white-space:nowrap;
}
.al-pill:hover{background:#eaf6ee; color:var(--wa-teal); text-decoration:none}
.al-pill.active{background:var(--grad); color:#fff; box-shadow:0 4px 10px -4px rgba(37,211,102,.45)}
.al-pill.active:hover{color:#fff}
.al-pill > span:first-child{font-size:.95rem; line-height:1}

/* ---- Admin range buttons (analytics + activity log) ---- */
.admin-quick-actions .btn.active{background:var(--grad); color:#fff; border-color:transparent}

/* ---- Activity log table ---- */
.al-icon{font-size:1.15rem; line-height:1; width:30px; text-align:center}

/* ---- Admin search results card spacing ---- */
.admin-shell .card + .card{margin-top:.85rem}

/* ---- Tweak admin nav active state to leave room for badge ---- */
.admin-nav a{justify-content:flex-start}
.admin-nav a.active{background:var(--grad); color:#fff; font-weight:700; box-shadow:var(--shadow-green)}
.admin-nav a.active:hover{background:var(--grad); color:#fff}
