@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=Fraunces:ital,wght@0,700;0,900;1,700&display=swap');

/* ═══════════════════════ DESIGN TOKENS ═══════════════════════ */
:root {
  --g900:#0d2b1e;--g800:#1a4731;--g700:#21623f;--g600:#2d7a52;--g500:#3a9068;
  --g400:#52b082;--g300:#7ecba1;--g200:#b7e4c7;--g100:#dff2e9;--g50:#f2faf5;
  --white:#ffffff;
  --s50:#f8fafc;--s100:#f1f5f9;--s200:#e2e8f0;--s300:#cbd5e1;
  --s400:#94a3b8;--s500:#64748b;--s700:#334155;--s900:#0f172a;

  /* layout */
  --panel-w: 380px;
  --hdr-h:   56px;
  --mob-hdr: 52px;      /* mobile top bar height */
  --drawer-peek: 64px;  /* how much of drawer peeks on mobile */

  /* decoration */
  --r-lg:20px;--r-md:12px;--r-sm:8px;--r-xs:6px;
  --sh-panel:8px 0 48px rgba(0,0,0,.22);
  --sh-float:0 12px 48px rgba(0,0,0,.18),0 2px 8px rgba(0,0,0,.08);
  --sh-card:0 4px 20px rgba(13,43,30,.12);
  --tr:.2s cubic-bezier(.4,0,.2,1);

  --font-ui:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-d:'Fraunces',Georgia,serif;
}

/* ═══════════════════════ RESET ═══════════════════════ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;overflow:hidden;}
body{font-family:var(--font-ui);color:var(--s900);background:var(--g100);
     -webkit-tap-highlight-color:transparent;}

/* ═══════════════════════ MAP ═══════════════════════ */
#map-root{position:fixed;inset:0;z-index:0;}

/* ═══════════════════════ LEAFLET OVERRIDES ═══════════════════════ */
.leaflet-control-zoom{
  border:none!important;
  box-shadow:var(--sh-card)!important;
  border-radius:var(--r-md)!important;
  overflow:hidden;
  margin-left:calc(var(--panel-w) + 16px)!important;
  margin-top:calc(var(--hdr-h) + 14px)!important;
}
.leaflet-control-zoom a{
  background:white!important;color:var(--g800)!important;border:none!important;
  border-bottom:1px solid var(--s100)!important;
  font-size:16px!important;line-height:30px!important;
  width:34px!important;height:34px!important;transition:background var(--tr)!important;
}
.leaflet-control-zoom a:last-child{border-bottom:none!important;}
.leaflet-control-zoom a:hover{background:var(--g50)!important;color:var(--g600)!important;}
.leaflet-control-attribution{
  background:rgba(255,255,255,.82)!important;backdrop-filter:blur(6px);
  border-radius:6px 0 0 0!important;font-size:.65rem!important;color:var(--s500)!important;
}
.leaflet-popup-content-wrapper{
  border-radius:var(--r-lg)!important;box-shadow:var(--sh-float)!important;
  border:none!important;padding:0!important;overflow:hidden;
}
.leaflet-popup-content{margin:0!important;}
.leaflet-popup-tip{background:white!important;}

/* ═══════════════════════ POPUP ═══════════════════════ */
.popup-inner{padding:14px 16px;}
.popup-num{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;
  background:var(--g600);color:white;border-radius:50%;font-size:.68rem;font-weight:700;margin-bottom:6px;}
.popup-title{font-family:var(--font-d);font-size:1rem;color:var(--g800);font-weight:700;line-height:1.25;}
.popup-desc{font-size:.77rem;color:var(--s500);margin-top:5px;line-height:1.55;}
.popup-coords{font-size:.68rem;color:var(--g500);margin-top:8px;font-family:'Courier New',monospace;
  display:flex;align-items:center;gap:4px;}

/* ═══════════════════════ DESKTOP HEADER BAR ═══════════════════════ */
.map-header{
  position:fixed;top:0;left:var(--panel-w);right:0;height:var(--hdr-h);z-index:500;
  background:rgba(255,255,255,.92);backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(255,255,255,.7);
  display:flex;align-items:center;justify-content:space-between;padding:0 20px;
  box-shadow:0 1px 0 rgba(0,0,0,.06),0 4px 20px rgba(0,0,0,.05);
}
.hdr-left{display:flex;align-items:center;gap:12px;}
.hdr-dot{width:10px;height:10px;background:var(--g500);border-radius:50%;
  box-shadow:0 0 0 3px var(--g100);animation:pulse 2.5s ease-in-out infinite;}
@keyframes pulse{
  0%,100%{box-shadow:0 0 0 3px var(--g100);}
  50%{box-shadow:0 0 0 7px rgba(58,144,104,.12);}
}
.hdr-title{font-family:var(--font-d);font-size:1rem;font-weight:700;color:var(--g800);letter-spacing:-.02em;}
.hdr-sub{font-size:.69rem;color:var(--s400);margin-top:1px;letter-spacing:.01em;}
.hdr-right{display:flex;align-items:center;gap:8px;}
.hdr-chip{display:flex;align-items:center;gap:6px;padding:5px 12px;background:var(--g50);
  border:1px solid var(--g200);border-radius:20px;font-size:.71rem;font-weight:600;color:var(--g700);}

/* ═══════════════════════ MOBILE TOP BAR ═══════════════════════ */
.mob-bar{
  display:none;
  position:fixed;top:0;left:0;right:0;height:var(--mob-hdr);z-index:700;
  background:var(--g800);
  padding:0 14px;
  align-items:center;justify-content:space-between;
  box-shadow:0 2px 16px rgba(0,0,0,.25);
}
.mob-brand{display:flex;align-items:center;gap:9px;}
.mob-brand-icon{width:34px;height:34px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  border-radius:9px;display:flex;align-items:center;justify-content:center;}
.mob-brand-text h1{font-family:var(--font-d);font-size:.9rem;color:white;font-weight:700;line-height:1.2;}
.mob-brand-text p{font-size:.6rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.04em;}
.mob-actions{display:flex;align-items:center;gap:8px;}
/* Drawer toggle button */
.mob-drawer-btn{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:white;cursor:pointer;transition:background var(--tr);
  -webkit-tap-highlight-color:transparent;
}
.mob-drawer-btn:active{background:rgba(255,255,255,.22);}
/* Locate button in mobile bar */
.mob-loc-btn{
  display:flex;align-items:center;justify-content:center;
  width:38px;height:38px;border-radius:var(--r-sm);
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);
  color:white;cursor:pointer;transition:background var(--tr);
}
.mob-loc-btn.located{background:rgba(37,99,235,.3);border-color:rgba(37,99,235,.5);}

/* ═══════════════════════ SIDE PANEL (desktop) ═══════════════════════ */
.side-panel{
  position:fixed;top:0;left:0;bottom:0;width:var(--panel-w);z-index:600;
  background:var(--white);box-shadow:var(--sh-panel);
  display:flex;flex-direction:column;overflow:hidden;
  transition:transform var(--tr);
}

/* Panel header */
.panel-hdr{
  background:linear-gradient(160deg,var(--g900) 0%,var(--g700) 60%,var(--g600) 100%);
  padding:20px 20px 18px;flex-shrink:0;position:relative;overflow:hidden;
}
.panel-hdr::after{content:'';position:absolute;bottom:-30px;right:-30px;width:120px;height:120px;
  border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none;}
.panel-logo-row{display:flex;align-items:center;gap:12px;margin-bottom:14px;}
.panel-logo-icon{width:44px;height:44px;flex-shrink:0;background:rgba(255,255,255,.12);
  border:1.5px solid rgba(255,255,255,.2);border-radius:12px;
  display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);}
.panel-logo-text h2{font-family:var(--font-d);font-size:1.05rem;font-weight:700;color:white;line-height:1.25;letter-spacing:-.01em;}
.panel-logo-text p{font-size:.67rem;color:rgba(255,255,255,.55);margin-top:2px;letter-spacing:.04em;text-transform:uppercase;}
.panel-desc{font-size:.75rem;color:rgba(255,255,255,.72);line-height:1.6;}
.panel-desc strong{color:rgba(255,255,255,.95);font-weight:600;}

/* GPS locate bar */
.loc-bar{padding:10px 14px;background:var(--s50);border-bottom:1px solid var(--s100);flex-shrink:0;display:flex;align-items:center;gap:10px;}
.loc-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:9px 12px;
  background:white;border:1.5px solid var(--s200);border-radius:var(--r-md);
  font-family:var(--font-ui);font-size:.8rem;font-weight:600;color:var(--s700);
  cursor:pointer;transition:all var(--tr);-webkit-tap-highlight-color:transparent;}
.loc-btn:hover{border-color:var(--g400);color:var(--g700);background:var(--g50);}
.loc-btn.located{background:var(--g50);border-color:var(--g400);color:var(--g700);}
.loc-btn.locating{opacity:.7;cursor:wait;}
.loc-status{font-size:.7rem;color:var(--s500);line-height:1.4;flex:1;}
.loc-status.ok{color:var(--g600);font-weight:600;}
.loc-status.err{color:#dc2626;}

/* Search */
.panel-search{padding:14px 14px 10px;background:var(--s50);border-bottom:1px solid var(--s100);flex-shrink:0;}
.search-field{position:relative;}
.search-field svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);pointer-events:none;}
.search-field input{width:100%;padding:9px 12px 9px 36px;background:white;border:1.5px solid var(--s200);
  border-radius:var(--r-md);font-family:var(--font-ui);font-size:.83rem;color:var(--s900);
  outline:none;transition:border-color var(--tr),box-shadow var(--tr);}
.search-field input::placeholder{color:var(--s400);}
.search-field input:focus{border-color:var(--g400);box-shadow:0 0 0 3px rgba(58,144,104,.1);}
.meta-row{display:flex;align-items:center;justify-content:space-between;margin-top:9px;padding:0 2px;}
.meta-count{font-size:.73rem;color:var(--s500);}
.meta-count strong{color:var(--g700);font-weight:700;}
.btn-sel-all{background:none;border:none;font-family:var(--font-ui);font-size:.73rem;font-weight:600;
  color:var(--g600);cursor:pointer;padding:0;transition:color var(--tr);}
.btn-sel-all:hover{color:var(--g800);}

/* Spots list */
.spots-list{flex:1;overflow-y:auto;padding:12px;scrollbar-width:thin;scrollbar-color:var(--s200) transparent;}
.spots-list::-webkit-scrollbar{width:3px;}
.spots-list::-webkit-scrollbar-thumb{background:var(--s200);border-radius:2px;}

.spot-card{display:flex;align-items:flex-start;gap:11px;padding:11px 12px;border-radius:var(--r-md);
  border:1.5px solid transparent;cursor:pointer;transition:all var(--tr);margin-bottom:6px;
  background:var(--s50);user-select:none;position:relative;-webkit-tap-highlight-color:transparent;}
.spot-card:hover{background:var(--g50);border-color:var(--g200);}
.spot-card.selected{background:var(--g50);border-color:var(--g400);box-shadow:0 0 0 1px var(--g300) inset,var(--sh-card);}
.spot-check{width:20px;height:20px;min-width:20px;border-radius:var(--r-xs);border:2px solid var(--s300);
  background:white;display:flex;align-items:center;justify-content:center;
  transition:all var(--tr);margin-top:1px;flex-shrink:0;}
.spot-card.selected .spot-check{background:var(--g600);border-color:var(--g600);}
.spot-check svg{opacity:0;transform:scale(.5);transition:all var(--tr);}
.spot-card.selected .spot-check svg{opacity:1;transform:scale(1);}
.spot-idx{position:absolute;right:10px;top:10px;width:18px;height:18px;background:var(--g700);
  color:white;border-radius:50%;font-size:.6rem;font-weight:800;display:none;align-items:center;justify-content:center;}
.spot-card.selected .spot-idx{display:flex;}
.spot-body{flex:1;min-width:0;}
.spot-name{font-size:.86rem;font-weight:700;color:var(--g800);line-height:1.3;}
.spot-desc{font-size:.72rem;color:var(--s500);margin-top:3px;line-height:1.45;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.spot-coord{font-size:.65rem;color:var(--g500);margin-top:5px;font-family:'Courier New',monospace;display:flex;align-items:center;gap:3px;}
.empty-state{text-align:center;padding:48px 20px;color:var(--s400);}
.empty-state svg{margin-bottom:12px;opacity:.5;}
.empty-state p{font-size:.85rem;line-height:1.6;}

/* Panel footer */
.panel-foot{padding:14px 16px;background:white;border-top:1px solid var(--s100);flex-shrink:0;}
.sel-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.sel-label{font-size:.75rem;color:var(--s500);}
.sel-label strong{color:var(--g800);font-weight:700;}
.sel-clear{background:none;border:none;font-family:var(--font-ui);font-size:.72rem;
  color:var(--s400);cursor:pointer;padding:0;transition:color var(--tr);}
.sel-clear:hover{color:#e53e3e;}

.btn-optimize{width:100%;padding:13px 16px;
  background:linear-gradient(135deg,var(--g900) 0%,var(--g600) 100%);color:white;border:none;
  border-radius:var(--r-md);font-family:var(--font-ui);font-size:.86rem;font-weight:700;
  cursor:pointer;transition:all var(--tr);
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 4px 20px rgba(13,43,30,.35);letter-spacing:.01em;
  position:relative;overflow:hidden;-webkit-tap-highlight-color:transparent;}
.btn-optimize::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.08),transparent);}
.btn-optimize:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 32px rgba(13,43,30,.45);}
.btn-optimize:active:not(:disabled){transform:translateY(0);}
.btn-optimize:disabled{opacity:.38;cursor:not-allowed;transform:none;box-shadow:none;}

/* GA progress */
.ga-box{display:none;margin-top:12px;background:var(--g50);border:1px solid var(--g200);border-radius:var(--r-md);padding:10px 12px;}
.ga-box.show{display:block;}
.ga-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:7px;}
.ga-top span{font-size:.71rem;font-weight:600;color:var(--g700);}
.ga-gen{font-size:.68rem;color:var(--g500);font-family:monospace;}
.ga-track{height:5px;background:var(--g200);border-radius:3px;overflow:hidden;}
.ga-fill{height:100%;width:0%;background:linear-gradient(90deg,var(--g600),var(--g300));border-radius:3px;transition:width .08s linear;}
.ga-status{font-size:.69rem;color:var(--g600);margin-top:6px;font-weight:500;}
.ga-step{font-size:.67rem;color:var(--g500);margin-top:3px;font-family:'Courier New',monospace;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ═══════════════════════ RESULT RIBBON ═══════════════════════ */
.result-ribbon{
  position:fixed;bottom:0;left:var(--panel-w);right:0;
  height:0;z-index:480;
  transition:height .35s cubic-bezier(.4,0,.2,1);overflow:hidden;
}
.result-ribbon.show{height:96px;}
.ribbon-inner{
  position:absolute;inset:0;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);
  border-top:1px solid rgba(255,255,255,.9);
  box-shadow:0 -8px 32px rgba(0,0,0,.1);
  display:flex;align-items:center;padding:0 20px;gap:14px;
}
.ribbon-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;
  flex-shrink:0;background:var(--g800);border-radius:var(--r-md);
  padding:10px 16px;color:white;min-width:108px;gap:2px;}
.ribbon-stat-val{font-family:var(--font-d);font-size:1.3rem;font-weight:700;line-height:1;}
.ribbon-stat-lbl{font-size:.6rem;opacity:.65;text-transform:uppercase;letter-spacing:.08em;}
.ribbon-div{width:1px;height:52px;background:var(--s200);flex-shrink:0;}
.ribbon-label{font-family:var(--font-d);font-size:.78rem;font-weight:700;color:var(--g800);
  display:flex;align-items:center;gap:6px;flex-shrink:0;white-space:nowrap;}
.ribbon-stops{flex:1;display:flex;align-items:center;overflow-x:auto;overflow-y:hidden;
  list-style:none;scrollbar-width:none;padding:4px 0;gap:0;}
.ribbon-stops::-webkit-scrollbar{display:none;}
.ribbon-stop{display:flex;align-items:center;flex-shrink:0;}
.stop-pill{display:flex;align-items:center;gap:6px;background:var(--g50);border:1px solid var(--g200);
  border-radius:20px;padding:5px 10px;white-space:nowrap;}
.stop-n{width:18px;height:18px;background:var(--g600);color:white;border-radius:50%;
  font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.stop-lbl{font-size:.75rem;font-weight:600;color:var(--g800);}
.stop-arrow{width:20px;text-align:center;color:var(--g300);font-size:10px;flex-shrink:0;}
.ribbon-road-note{font-size:.68rem;color:var(--s500);padding:0 4px;white-space:nowrap;
  flex-shrink:0;display:flex;align-items:center;gap:4px;}

/* ═══════════════════════ LOCATION / GPS ═══════════════════════ */
@keyframes spin{to{transform:rotate(360deg);}}
.spin{animation:spin .9s linear infinite;transform-origin:center;}

.user-loc-pulse{
  width:20px;height:20px;background:#2563eb;border-radius:50%;border:3px solid white;
  box-shadow:0 0 0 4px rgba(37,99,235,.25),0 4px 12px rgba(0,0,0,.2);
  animation:locPulse 2s ease-in-out infinite;
}
@keyframes locPulse{
  0%,100%{box-shadow:0 0 0 4px rgba(37,99,235,.25),0 4px 12px rgba(0,0,0,.2);}
  50%{box-shadow:0 0 0 10px rgba(37,99,235,.08),0 4px 12px rgba(0,0,0,.2);}
}

/* ═══════════════════════ TOAST ═══════════════════════ */
.map-toast{
  position:fixed;top:calc(var(--hdr-h) + 12px);right:16px;z-index:900;
  background:white;border-radius:var(--r-md);padding:10px 14px;
  box-shadow:var(--sh-float);border-left:3px solid var(--g500);
  font-size:.8rem;font-weight:500;color:var(--s700);max-width:280px;
  display:flex;align-items:center;gap:8px;
  animation:toastIn .25s ease;pointer-events:none;
}
.map-toast.warn{border-color:#d97706;}
.map-toast.err{border-color:#dc2626;}
@keyframes toastIn{from{opacity:0;transform:translateX(12px);}to{opacity:1;transform:none;}}

/* ═══════════════════════ DRAWER HANDLE (mobile) ═══════════════════════ */
.drawer-handle{
  display:none;width:100%;padding:10px 0 6px;background:white;
  flex-shrink:0;cursor:grab;touch-action:none;
  border-bottom:1px solid var(--s100);
  align-items:center;justify-content:center;flex-direction:column;gap:4px;
}
.drawer-pill{width:36px;height:4px;background:var(--s300);border-radius:2px;}
.drawer-label{font-size:.65rem;color:var(--s400);font-weight:600;letter-spacing:.06em;text-transform:uppercase;}

/* ═══════════════════════ MOBILE OVERLAY SCRIM ═══════════════════════ */
.mob-scrim{
  display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:599;
  backdrop-filter:blur(2px);opacity:0;transition:opacity .3s;pointer-events:none;
}
.mob-scrim.show{opacity:1;pointer-events:auto;}

/* ═══════════════════════ MOBILE RESULT SHEET ═══════════════════════ */
/* On mobile, result ribbon becomes a bottom sheet */
@media(max-width:767px){
  .result-ribbon{left:0;bottom:0;}
  .result-ribbon.show{height:auto;max-height:45vh;}
  .ribbon-inner{
    flex-direction:column;align-items:stretch;padding:14px 16px;gap:10px;
    height:auto;position:relative;
  }
  .ribbon-top-row{display:flex;align-items:center;gap:12px;}
  .ribbon-div{display:none;}
  .ribbon-label{font-size:.82rem;}
  .ribbon-stops{padding:0;overflow-x:auto;}
  .stop-pill{padding:5px 10px;}
  .stop-lbl{font-size:.78rem;}
  .ribbon-road-note{font-size:.72rem;}
}

/* ═══════════════════════ RESPONSIVE BREAKPOINTS ═══════════════════════ */

/* ── TABLET (768–1023px): narrower panel ── */
@media(min-width:768px) and (max-width:1023px){
  :root{ --panel-w:320px; }
  .panel-desc{display:none;}
  .panel-logo-text h2{font-size:.95rem;}
  .hdr-sub{display:none;}
  .hdr-chip:last-child{display:none;}
}

/* ── MOBILE (<768px): bottom-drawer layout ── */
@media(max-width:767px){
  :root{ --mob-hdr:52px; }

  /* Hide desktop header bar and show mobile top bar */
  .map-header{display:none;}
  .mob-bar{display:flex;}

  /* Move zoom control for mobile */
  .leaflet-control-zoom{
    margin-left:12px!important;
    margin-top:calc(var(--mob-hdr) + 12px)!important;
  }

  /* Panel becomes a bottom drawer */
  .side-panel{
    top:auto;
    left:0;right:0;bottom:0;
    width:100%;
    height:calc(100vh - var(--mob-hdr));
    border-radius:var(--r-lg) var(--r-lg) 0 0;
    box-shadow:0 -8px 40px rgba(0,0,0,.25);
    /* Start collapsed — only drawer handle visible */
    transform:translateY(calc(100% - var(--drawer-peek)));
    transition:transform .35s cubic-bezier(.4,0,.2,1);
    z-index:650;
  }

  /* Drawer expanded state */
  .side-panel.drawer-open{transform:translateY(0);}

  /* Show drawer handle */
  .drawer-handle{display:flex;}

  /* Compact panel header on mobile */
  .panel-hdr{padding:14px 16px 12px;}
  .panel-logo-row{margin-bottom:8px;}
  .panel-desc{font-size:.73rem;line-height:1.5;}
  .panel-logo-icon{width:38px;height:38px;}
  .panel-logo-text h2{font-size:.95rem;}

  /* Toast: full width on mobile, above drawer */
  .map-toast{
    top:auto;
    bottom:calc(var(--drawer-peek) + 12px);
    right:12px;left:12px;
    max-width:none;
  }

  /* Result ribbon stacks above drawer peek */
  .result-ribbon{z-index:640;}

  /* Scrim shows when drawer is open */
  .mob-scrim{display:block;}

  /* Hide loc-bar in panel on mobile (loc button is in mob-bar instead) */
  .loc-bar{display:none;}
  #locStatusWrap{display:none!important;}

  /* Bigger touch targets on mobile */
  .spot-card{padding:13px 12px;margin-bottom:8px;}
  .spot-check{width:24px;height:24px;min-width:24px;}
  .spot-name{font-size:.9rem;}
  .btn-optimize{padding:15px;}
  .panel-foot{padding:12px 14px 20px;}
  .btn-sel-all{font-size:.8rem;padding:4px 0;}

  /* Spot desc on mobile */
  .spot-desc{display:none;}
  .spot-coord{font-size:.68rem;}
}

/* ── SMALL MOBILE (<400px) ── */
@media(max-width:399px){
  .mob-brand-text p{display:none;}
  .hdr-chip{display:none;}
  .ribbon-stat{min-width:90px;padding:8px 12px;}
  .ribbon-stat-val{font-size:1.1rem;}
}
