  :root{
    --ink:#0c1411; --panel:#101c17; --panel-2:#16261f; --line:#27392f;
    --paper:#f3ede1; --muted:#9bb0a4; --amber:#e8a04c; --trail:#7fb069;
    --sky:#6fb3c9; --rust:#cf6b4a; --violet:#b08bd6;
  }
  *{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
  html,body{margin:0;height:100%;font-family:"Archivo",system-ui,sans-serif;background:var(--ink);color:var(--paper)}
  #map{position:fixed;inset:0;background:#0a100d}

  .topbar{position:fixed;top:0;left:0;right:0;z-index:1200;display:flex;align-items:center;gap:.7rem;
    padding:.55rem .8rem;background:linear-gradient(180deg,rgba(8,14,11,.94),rgba(8,14,11,.78) 70%,transparent);pointer-events:none}
  .brand{pointer-events:auto;display:flex;align-items:baseline;gap:.55rem;line-height:1}
  .brand .mark{font-family:"Fraunces",serif;font-weight:700;font-size:1.32rem;letter-spacing:.2px;color:var(--paper);text-shadow:0 1px 8px rgba(0,0,0,.6)}
  .brand .mark em{color:var(--amber);font-style:normal}
  .brand .sub{font-family:"DM Mono",monospace;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-shadow:0 1px 6px rgba(0,0,0,.7)}
  @media (max-width:560px){.brand .sub{display:none}}

  .searchwrap{margin-left:auto;pointer-events:auto;position:relative;width:min(38vw,320px)}
  @media (max-width:560px){.searchwrap{width:46vw}}
  .searchwrap input{width:100%;padding:.5rem 2rem .5rem .75rem;border-radius:9px;border:1px solid var(--line);
    background:rgba(16,28,23,.92);color:var(--paper);font-family:"Archivo";font-size:.85rem;outline:none;box-shadow:0 4px 18px rgba(0,0,0,.4)}
  .searchwrap input::placeholder{color:#728578}
  .searchwrap input:focus{border-color:var(--amber)}
  .searchclear{position:absolute;right:7px;top:50%;transform:translateY(-50%);width:22px;height:22px;border:0;
    border-radius:50%;background:rgba(255,255,255,.08);color:var(--muted);cursor:pointer;font-size:1.05rem;line-height:1;
    display:none;align-items:center;justify-content:center;padding:0}
  .searchclear.show{display:flex}
  .searchclear:hover{color:var(--paper);background:rgba(255,255,255,.16)}
  .results{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--panel);border:1px solid var(--line);
    border-radius:10px;overflow:hidden;box-shadow:0 16px 40px rgba(0,0,0,.5);display:none}
  .results.open{display:block}
  .results button{display:block;width:100%;text-align:left;padding:.55rem .7rem;border:0;border-bottom:1px solid var(--line);
    background:transparent;color:var(--paper);font-family:"Archivo";font-size:.8rem;cursor:pointer}
  .results button:last-child{border-bottom:0}
  .results button:hover{background:var(--panel-2);color:var(--amber)}

  .panel{position:fixed;z-index:1100;top:.8rem;left:.8rem;width:320px;max-width:calc(100vw - 1.6rem);
    background:linear-gradient(180deg,var(--panel),var(--ink));border:1px solid var(--line);border-radius:16px;
    box-shadow:0 22px 60px rgba(0,0,0,.55),inset 0 1px 0 rgba(255,255,255,.03);overflow:hidden;transition:transform .35s cubic-bezier(.4,0,.1,1)}
  .panel.collapsed{transform:translateX(calc(-100% - 1.2rem))}
  .panel-scroll{max-height:calc(100vh - 1.6rem);overflow-y:auto;padding:.1rem 0 .3rem}
  .panel-brand{padding:.5rem 1rem .1rem 1rem;font-family:"Archivo";font-weight:700;font-size:.92rem;
    letter-spacing:.01em;color:var(--paper);display:flex;align-items:center;gap:.5rem}
  .panel-brand .mark{flex:1;min-width:0}
  .brand-actions{flex:none;display:flex;align-items:center;gap:.4rem}
  .panel-brand em{color:var(--amber);font-style:normal}
  .brand-search-btn{flex:none;width:30px;height:30px;border-radius:8px;border:1px solid var(--line);
    background:var(--panel-2);color:var(--paper);cursor:pointer;font-size:.85rem;display:flex;
    align-items:center;justify-content:center;transition:.13s}
  .brand-search-btn:hover{border-color:var(--amber);color:var(--amber)}
  .brand-search-btn.act{background:var(--amber);color:#0c1411;border-color:var(--amber)}
  #panelclose{font-size:1.3rem}
  .panel-scroll::-webkit-scrollbar{width:8px}
  .panel-scroll::-webkit-scrollbar-thumb{background:#2c4338;border-radius:8px}

  .sec{padding:.28rem 1rem .08rem}
  .sec h3{margin:0 0 .4rem;font-family:"DM Mono",monospace;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
    color:var(--amber);display:flex;align-items:center;gap:.5rem}
  .sec h3::after{content:"";flex:1;height:1px;background:var(--line)}

  .seg{display:grid;grid-template-columns:repeat(2,1fr);gap:.35rem}
  .seg button{padding:.42rem .4rem;border:1px solid var(--line);border-radius:9px;background:var(--panel-2);
    color:var(--muted);font-family:"Archivo";font-size:.72rem;font-weight:600;cursor:pointer;transition:.15s}
  .seg button .t{display:block;font-size:.6rem;font-weight:400;color:#6d8073;margin-top:1px}
  .seg button.active{border-color:var(--amber);color:var(--ink);background:var(--amber)}
  .seg button.active .t{color:#5c3d12}

  .layer{display:flex;align-items:flex-start;gap:.45rem;padding:.32rem .3rem;border-radius:10px;cursor:pointer;transition:.12s}
  .layer:hover{background:rgba(255,255,255,.025)}
  .chev{flex:none;width:14px;margin-top:.15rem;color:#6d8073;font-size:.7rem;transition:transform .18s;text-align:center}
  .layeritem.open .chev{transform:rotate(90deg);color:var(--amber)}
  .swatch{width:13px;height:13px;border-radius:4px;margin-top:.22rem;flex:none;border:1px solid rgba(255,255,255,.25)}
  .layer .body{flex:1;min-width:0}
  .layer .name{font-size:.78rem;font-weight:600;display:flex;align-items:center;gap:.4rem}
  .layer .desc{font-size:.64rem;color:var(--muted);line-height:1.3;margin-top:1px}
  .layer .warn{display:none;font-size:.62rem;color:var(--rust);margin-top:2px}
  .layer.failed .warn{display:block}
  .toggle{position:relative;width:38px;height:21px;border-radius:20px;background:#2a3c32;flex:none;border:1px solid var(--line);transition:.18s;margin-top:.05rem}
  .toggle::after{content:"";position:absolute;top:2px;left:2px;width:15px;height:15px;border-radius:50%;background:#7f9286;transition:.18s}
  .layer.on .toggle{background:var(--trail);border-color:var(--trail)}
  .layer.on .toggle::after{transform:translateX(17px);background:#0c1411}
  /* Light-mode toggles: light track + white knob (off), green track + white knob (on) */
  body.light .toggle{background:#ccc4b2;border-color:#bcb39f}
  body.light .toggle::after{background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.25)}
  body.light .layer.on .toggle{background:var(--trail);border-color:var(--trail)}
  body.light .layer.on .toggle::after{background:#fff}

  .sublist{display:none;padding:.1rem .35rem .5rem 1.5rem}
  .layeritem.open .sublist{display:block}
  .linfo{font-size:.7rem;color:var(--muted);line-height:1.4;margin:.1rem 0 .5rem}
  .isearch{width:100%;padding:.35rem .55rem;border-radius:7px;border:1px solid var(--line);background:var(--ink);
    color:var(--paper);font-family:"Archivo";font-size:.74rem;outline:none;margin-bottom:.4rem}
  .isearch:focus{border-color:var(--amber)}
  .items{max-height:240px;overflow-y:auto}
  .items::-webkit-scrollbar{width:7px}
  .items::-webkit-scrollbar-thumb{background:#2c4338;border-radius:8px}
  .iload{font-size:.68rem;color:#6d8073;padding:.3rem .2rem}
  .item{display:flex;align-items:flex-start;gap:.5rem;padding:.3rem .2rem;border-radius:6px;cursor:pointer;transition:.12s}
  .item:hover{background:rgba(232,160,76,.06)}
  .item:hover .iname{color:var(--amber)}
  .item input{margin-top:.18rem;width:16px;height:16px;accent-color:var(--trail);flex:none;cursor:pointer}
  .ibody{flex:1;min-width:0;cursor:pointer}
  .iname{font-size:.8rem;color:var(--paper);line-height:1.3}
  .idesc{display:none;font-size:.68rem;color:var(--muted);margin-top:1px}
  .idesc.show{display:block}
  .isearch{width:100%;padding:.4rem .6rem;border-radius:8px;border:1px solid var(--line);background:var(--ink);
    color:var(--paper);font-family:"Archivo";font-size:.78rem;outline:none;margin-bottom:.5rem}
  .isearch:focus{border-color:var(--amber)}
  .vtoolbar{display:flex;align-items:stretch;gap:.4rem;margin-bottom:.5rem}
  .vtoolbar .isearch{flex:1;margin-bottom:0}
  .sortbtn{flex:none;padding:.4rem .65rem;border-radius:8px;border:1px solid var(--line);
    background:var(--ink);color:var(--muted);font-family:"DM Mono",monospace;font-size:.7rem;cursor:pointer;
    letter-spacing:.02em;white-space:nowrap}
  .sortbtn:hover{color:var(--amber);border-color:var(--amber)}
  .sortbtn[data-mode="visited"]{color:var(--trail);border-color:var(--trail)}

  /* My Visits launcher button */
  .visitsrow{display:flex;flex-wrap:wrap;gap:.4rem;margin:.55rem 1rem .15rem;align-items:center}
  .visitsbtn{flex:1;min-width:115px;padding:.5rem .7rem;border-radius:11px;
    border:1px solid var(--trail);background:linear-gradient(180deg,rgba(127,176,105,.16),rgba(127,176,105,.06));
    color:var(--paper);font-family:"Archivo";font-weight:600;font-size:.76rem;cursor:pointer;text-align:center;
    display:inline-flex;align-items:center;justify-content:center;gap:.4rem}
  .visitsbtn:hover{border-color:var(--amber);color:var(--amber)}
  .visitsbtn.heat{border-color:#7f9286;
    background:linear-gradient(180deg,rgba(127,176,105,.10),rgba(127,176,105,.03));color:var(--paper)}
  .visitsbtn.heat:hover{border-color:var(--amber);color:var(--amber)}
  .visitsbtn.heat.on{border-color:#e8a04c;
    background:linear-gradient(180deg,rgba(232,160,76,.26),rgba(232,160,76,.08));color:var(--amber)}
  /* star toggle: dim when off, gold when on */
  .hbstar{font-size:1rem;line-height:1;color:#6f8478;transition:.18s}
  .visitsbtn.heat.on .hbstar{color:var(--amber);text-shadow:0 0 8px rgba(232,160,76,.6)}
  .tipjar{text-align:center;padding:.55rem .8rem .2rem;margin-top:.3rem;border-top:1px solid var(--line)}
  .tipjar a{font-size:.72rem;color:var(--muted);text-decoration:none;letter-spacing:.02em}
  .tipjar a:hover{color:var(--amber)}
  .tipjar .dot{font-size:.72rem;color:#3a4f43;margin:0 .35rem}

  /* My Visits / Places / Settings — modal-over-map (shared) */
  #visits, #settings{position:fixed;inset:0;z-index:1400;background:rgba(6,12,10,.55);
    backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
    display:none;align-items:flex-start;justify-content:center;cursor:pointer}
  #visits.open, #settings.open{display:flex}
  /* source icons row, sits left of the Upload button */
  .src-row{display:inline-flex;gap:.3rem;align-items:center}
  .src-row:empty{display:none}
  .src-row .src-i{width:30px;height:30px;border-radius:8px;
    border:1px solid var(--trail);background:rgba(127,176,105,.18);
    font-size:.95rem;line-height:1;padding:0;display:inline-flex;align-items:center;justify-content:center;
    color:var(--paper);cursor:default;position:relative}
  /* footer of modal for the delete button */
  .vfoot{padding:.55rem 1rem .8rem;border-top:1px solid var(--line);text-align:right}
  .vfoot-spread{display:flex;justify-content:space-between;align-items:center;gap:.5rem}
  .bottomdel{padding:.45rem .8rem;border:1px solid var(--line);background:transparent;
    color:var(--muted);border-radius:8px;font-family:"Archivo";font-weight:600;font-size:.75rem;
    cursor:pointer;letter-spacing:.02em}
  .bottomdel:hover{border-color:var(--rust);color:var(--rust)}
  .bottomdel-danger{color:#e08577;border-color:#7a3a31}
  .bottomdel-danger:hover{color:#f4a496;border-color:#c44d3a;background:rgba(196,77,58,.12)}
  /* info-popover links footer */
  /* settings modal — minimal */
  #settings .vmodal{width:min(520px, 100% - 24px)}
  .settings-row{display:flex;flex-wrap:nowrap;gap:.3rem;align-items:center;margin-top:.55rem;overflow-x:auto}
  .settings-row .sbtn{white-space:nowrap;padding:.35rem .5rem;font-size:.7rem}
  .settings-row .sbtn{padding:.35rem .65rem;border:1px solid var(--line);background:var(--panel-2);
    color:var(--paper);border-radius:6px;cursor:pointer;font-family:"Archivo";font-size:.74rem;
    font-weight:600;line-height:1;transition:.12s}
  .settings-row .sbtn:hover{border-color:var(--amber);color:var(--amber);background:rgba(232,160,76,.08)}
  .settings-row .sbtn-danger{color:#e08577;border-color:#7a3a31}
  .settings-row .sbtn-danger:hover{color:#f4a496;border-color:#c44d3a;background:rgba(196,77,58,.12)}
  .settings-row .src-row{display:flex;gap:.25rem;margin-left:auto;align-items:center}
  .settings-row .src-row:empty{margin-left:0}
  .settings-section-label{padding:.85rem 1rem .15rem;font-family:"DM Mono",monospace;
    font-size:.58rem;color:var(--muted);letter-spacing:.2em;text-transform:uppercase}
  .user-section{padding:0 1rem .35rem}
  .snapshot{display:grid;grid-template-columns:1fr 1fr;gap:.3rem .9rem;margin-bottom:.55rem}
  .snap-row{display:flex;align-items:center;gap:.45rem;font-size:.78rem;color:var(--paper)}
  .snap-dot{width:9px;height:9px;border-radius:3px;flex:none}
  .snap-name{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted)}
  .snap-num{font-family:"DM Mono",monospace;font-weight:600;color:var(--paper)}
  .sharebtn{flex:0 0 auto;width:auto;font-size:.72rem;padding:.32rem .7rem}
  @media (max-width:560px){ .snapshot{grid-template-columns:1fr} }
  .user-row{display:flex;gap:.4rem;margin-bottom:.4rem;align-items:center}
  .user-row input{flex:1;padding:.4rem .55rem;border:1px solid var(--line);background:var(--panel-2);
    color:var(--paper);border-radius:6px;font-family:"Archivo";font-size:.74rem}
  .user-row input::placeholder{color:var(--muted)}
  .user-row input:focus{outline:none;border-color:var(--amber)}
  .user-row .sbtn{flex:1;padding:.45rem .65rem;border:1px solid var(--line);background:var(--panel-2);
    color:var(--paper);border-radius:6px;cursor:pointer;font-family:"Archivo";font-size:.74rem;
    font-weight:600;line-height:1.1;transition:.12s}
  .user-row .sbtn:hover{border-color:var(--amber);color:var(--amber);background:rgba(232,160,76,.08)}
  .user-pill{flex:1;padding:.4rem .65rem;border:1px solid var(--trail);border-radius:6px;
    background:rgba(127,176,105,.15);color:var(--paper);font-size:.74rem;font-weight:600;
    display:flex;align-items:center;gap:.35rem}
  .user-pill b{color:var(--amber);font-weight:600}
  .user-pill-dim{border-color:var(--line);background:transparent;color:var(--muted);font-weight:500}
  .authbtn{gap:.4rem;padding:.4rem .7rem}
  .authbtn.connected{border-color:var(--trail);color:var(--trail)}
  .authbtn .jsonbadge{font-family:"DM Mono",monospace;font-size:.6rem;border:1px solid currentColor;
    border-radius:4px;padding:0 .25rem;line-height:1.5;opacity:.9}
  .gdot{width:8px;height:8px;border-radius:50%;background:#3fae5f;display:inline-block;box-shadow:0 0 6px rgba(63,174,95,.7)}
  .gbtn{display:inline-flex;align-items:center;gap:.45rem}
  .glogo{display:inline-flex;align-items:center;justify-content:center;width:17px;height:17px;border-radius:50%;
    background:#fff;color:#4285F4;font-weight:800;font-family:"Archivo",sans-serif;font-size:.72rem;line-height:1;flex:none}
  .gbtn-lg{width:100%;justify-content:center;padding:.6rem;font-size:.86rem}
  /* ===== Landing (full-screen) ===== */
  #welcome{position:fixed;inset:0;z-index:2200;display:none;overflow-y:auto;
    background:radial-gradient(1100px 480px at 82% -8%, rgba(232,160,76,.10), transparent 60%),
               linear-gradient(180deg,#0c1411 0%,#0e1a14 55%,#0c1411 100%)}
  #welcome.open{display:block}
  .land{min-height:100%;display:flex;flex-direction:column}
  .land-nav{display:flex;align-items:center;gap:1rem;padding:1rem 1.4rem;flex-wrap:wrap}
  .land-brand{display:flex;align-items:center;gap:.6rem;margin-right:auto}
  .land-mark{width:40px;height:40px;border-radius:10px;display:block}
  .land-word{font-family:"Archivo";font-weight:800;font-size:1.25rem;color:var(--paper);letter-spacing:-.01em}
  .land-word em{color:var(--amber);font-style:normal}
  .land-links{display:flex;gap:.2rem}
  .land-links button{background:none;border:none;color:var(--muted);font-family:"Archivo";
    font-size:.88rem;font-weight:600;padding:.4rem .7rem;border-radius:7px;cursor:pointer;transition:.12s}
  .land-links button:hover{color:var(--paper);background:rgba(255,255,255,.05)}
  .land-navbtns{display:flex;gap:.5rem}
  .land-btn{font-family:"Archivo";font-weight:700;font-size:.88rem;padding:.5rem 1rem;border-radius:9px;
    cursor:pointer;border:1px solid var(--line);background:transparent;color:var(--paper);transition:.12s}
  .land-btn.ghost:hover{border-color:var(--amber);color:var(--amber)}
  .land-btn.amber{background:var(--amber);border-color:var(--amber);color:#241606}
  .land-btn.amber:hover{filter:brightness(1.06)}
  .land-btn.outline:hover{border-color:var(--amber);color:var(--amber)}
  .land-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:2.2rem;align-items:center;
    padding:1.2rem 1.4rem;max-width:1240px;margin:0 auto;width:100%;box-sizing:border-box}
  .land-h1{font-family:"Fraunces",serif;font-weight:600;color:var(--paper);
    font-size:clamp(2rem,4.8vw,3.4rem);line-height:1.03;margin:.5rem 0 1rem;letter-spacing:-.015em}
  .land-h1 em{color:var(--amber);font-style:normal}
  .land-lead{color:var(--muted);font-size:1rem;line-height:1.5;margin:0 0 1.5rem;max-width:38ch}
  .land-feats{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:0 0 1.6rem}
  .land-feat{display:flex;flex-direction:column;gap:.28rem}
  .lf-ic{color:var(--trail);font-size:1.15rem;line-height:1}
  .land-feat b{color:var(--trail);font-family:"Archivo";font-size:.82rem;font-weight:700}
  .land-feat small{color:var(--muted);font-size:.7rem;line-height:1.35}
  .land-cta{display:flex;gap:.6rem;flex-wrap:wrap;margin:0 0 .9rem}
  .land-cta .gbtn{width:auto;flex:0 0 auto;padding:.7rem 1.15rem;font-size:.92rem}
  .land-cta .land-btn{padding:.7rem 1.2rem;font-size:.92rem}
  .land-priv{color:var(--muted);font-size:.74rem;display:flex;align-items:center;gap:.4rem}
  .land-preview{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel);
    box-shadow:0 24px 70px rgba(0,0,0,.55)}
  .lp-bar{display:flex;align-items:center;gap:.4rem;padding:.5rem .55rem;background:var(--panel-2);
    border-bottom:1px solid var(--line)}
  .lp-pill{display:inline-flex;align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;color:var(--paper);
    background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:7px;padding:.32rem .5rem}
  .lp-seg{display:flex;gap:.1rem}
  .lp-seg span{font-size:.68rem;color:var(--muted);padding:.32rem .5rem;border-radius:6px;white-space:nowrap}
  .lp-seg span.on{background:var(--trail);color:#10271a;font-weight:700}
  .lp-tools{margin-left:auto;display:flex;gap:.45rem;color:var(--muted);font-size:.8rem;padding-right:.2rem}
  .lp-map{position:relative;height:312px;background:linear-gradient(160deg,#37463a,#283730)}
  .lp-map > svg{position:absolute;inset:0;width:100%;height:100%}
  .lp-badge{position:absolute;left:.7rem;bottom:.7rem;display:flex;align-items:center;gap:.5rem;
    background:rgba(12,20,17,.86);border:1px solid var(--line);border-radius:11px;padding:.5rem .7rem}
  .lp-badge .chk{width:22px;height:22px;border-radius:50%;background:var(--trail);color:#10271a;
    display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.78rem}
  .lp-badge b{color:var(--paper);font-size:.82rem;font-family:"Archivo";display:block;line-height:1.1}
  .lp-badge small{color:var(--muted);font-size:.66rem}
  .lp-legend{position:absolute;right:.7rem;bottom:.7rem;background:rgba(12,20,17,.86);
    border:1px solid var(--line);border-radius:11px;padding:.5rem .6rem;display:grid;gap:.22rem}
  .lp-legend div{display:flex;align-items:center;gap:.4rem;font-size:.65rem;color:var(--paper)}
  .lp-legend i{width:10px;height:10px;border-radius:3px;display:inline-block;flex:0 0 auto}
  .lp-legend .ck{margin-left:auto;color:var(--trail);font-weight:800}
  .land-stats{display:grid;grid-template-columns:repeat(6,1fr);gap:1rem;max-width:1240px;margin:.5rem auto 0;
    width:100%;padding:1.3rem 1.4rem;border-top:1px solid var(--line);box-sizing:border-box}
  .ls{display:flex;flex-direction:column;gap:.05rem}
  .ls-top{display:flex;align-items:center;gap:.45rem}
  .ls-ic{color:var(--trail);font-size:1rem}
  .ls b{font-family:"Fraunces",serif;font-size:1.7rem;color:var(--paper);font-weight:600;line-height:1}
  .ls strong{font-family:"Archivo";font-size:.82rem;color:var(--paper);font-weight:700;margin-top:.2rem}
  .ls small{color:var(--muted);font-size:.68rem}
  .land-foot{text-align:center;color:var(--muted);font-size:.72rem;padding:1.1rem;display:flex;
    align-items:center;justify-content:center;gap:.4rem}
  @media (max-width:900px){
    .land-links{display:none}
    .land-hero{grid-template-columns:1fr;gap:1.3rem;padding-top:.5rem}
    .land-preview{order:2}
    .land-feats{grid-template-columns:repeat(2,1fr)}
    .land-stats{grid-template-columns:repeat(3,1fr)}
  }
  @media (max-width:520px){
    .land-stats{grid-template-columns:repeat(2,1fr)}
    .land-navbtns .land-btn.ghost{display:none}
    .lp-seg span:nth-child(n+3){display:none}
  }
  /* dark mode toggle with sun/moon icons */
  .dmtoggle{display:inline-flex;align-items:center;cursor:pointer;user-select:none}
  .dmtoggle input{position:absolute;opacity:0;pointer-events:none}
  .dmtrack{width:46px;height:22px;background:#33453c;border-radius:22px;border:1px solid var(--line);
    position:relative;transition:.2s;display:flex;align-items:center;padding:0 5px;justify-content:space-between}
  .dmicon{font-size:.7rem;line-height:1;z-index:1;transition:.2s}
  .dmicon-sun{color:#f0c060}
  .dmicon-moon{color:#9fc9f0}
  .dmthumb{position:absolute;top:1px;left:1px;width:18px;height:18px;background:var(--paper);
    border-radius:50%;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.4)}
  .dmtoggle input:checked + .dmtrack{background:#1c2520}
  .dmtoggle input:checked + .dmtrack .dmthumb{left:24px;background:#e8a04c}
  .dmtoggle input:not(:checked) + .dmtrack .dmthumb{background:#f0c060}
  #settingsBody{flex:1 1 auto;overflow-y:auto;padding:0 1rem .65rem;
    display:grid;grid-template-columns:1fr 1fr;gap:.1rem .8rem}
  .srow{display:flex;align-items:center;gap:.45rem;padding:.22rem 0;border-bottom:1px solid rgba(255,255,255,.04)}
  .srow .desc{display:none}
  .srow:last-child{border-bottom:0}
  .srow .sw{width:22px;height:22px;border-radius:5px;border:1px solid rgba(255,255,255,.15);flex:none;
    cursor:pointer;position:relative;overflow:hidden}
  .srow .sw input{position:absolute;inset:0;opacity:0;cursor:pointer;border:0;padding:0;background:none}
  .srow .nm{flex:1;font-size:.78rem;font-weight:500}
  .srow .desc{flex:none;font-size:.6rem;color:var(--muted);font-family:"DM Mono",monospace;letter-spacing:.02em}
  .srow .rb{padding:.15rem .35rem;border:1px solid transparent;background:transparent;color:var(--muted);
    border-radius:4px;cursor:pointer;font-size:.65rem;line-height:1}
  .srow .rb:hover{border-color:var(--amber);color:var(--amber)}
  /* searchwrap inside panel */
  .panel-scroll .searchwrap{width:auto;margin:0 .25rem .5rem;pointer-events:auto}
  /* floating map controls — bottom-right of the viewport */
  .mapfab{position:fixed;z-index:1100;right:.8rem;bottom:1.1rem;display:flex;flex-direction:column;gap:.4rem}
  .mapfab .fab{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);
    background:rgba(12,20,17,.92);color:var(--amber);cursor:pointer;font-size:1.15rem;line-height:1;
    font-family:"Archivo";font-weight:600;display:flex;align-items:center;justify-content:center;
    box-shadow:0 6px 18px rgba(0,0,0,.5);transition:.12s;backdrop-filter:blur(3px)}
  .mapfab .fab:hover{border-color:var(--amber);background:rgba(232,160,76,.18)}
  .mapfab .fab.locating{animation:pulse 1.4s ease-in-out infinite}
  @keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
  body.light .mapfab .fab{background:rgba(255,255,255,.95)}
  /* light theme */
  body.light{
    --bg:#f5f1e8; --paper:#1c2520; --muted:#5d6b62; --amber:#a86420; --ink:#ffffff;
    --line:#d6cfbf; --panel:#fbf7ec; --panel-2:#f0eadb; --trail:#3d6f3f;
    background:var(--bg);color:var(--paper)
  }
  /* Light-mode legibility fixes for the Track sheet, panel and popovers */
  body.light .layer:hover{background:rgba(0,0,0,.045)}
  body.light .iload, body.light .vhead .chev, body.light .note{color:#6b7a70}
  body.light .items::-webkit-scrollbar-thumb,
  body.light #vbody::-webkit-scrollbar-thumb,
  body.light #placesBody::-webkit-scrollbar-thumb,
  body.light .panel-scroll::-webkit-scrollbar-thumb{background:#cfc8b8}
  body.light .ipop{box-shadow:0 16px 40px rgba(0,0,0,.18)}
  body.light .leaflet-control-attribution{background:rgba(255,255,255,.85);color:#444}
  /* tab bar */
  .vtabs{display:flex;gap:0;margin:.6rem -.1rem -.3rem;border-bottom:1px solid var(--line)}
  .vtab{flex:none;padding:.55rem 1rem;background:transparent;border:0;color:var(--muted);
    font-family:"Archivo";font-weight:600;font-size:.78rem;cursor:pointer;
    border-bottom:2px solid transparent;margin-bottom:-1px;letter-spacing:.01em}
  .vtab:hover{color:var(--paper)}
  .vtab.active{color:var(--amber);border-bottom-color:var(--amber)}
  /* place-add input row at top of each Places section */
  .padd{display:flex;gap:.35rem;padding:.35rem .3rem .55rem 1.6rem}
  .padd input{flex:1;padding:.4rem .6rem;border:1px dashed var(--line);background:var(--panel-2);
    color:var(--paper);border-radius:7px;font-family:"Archivo";font-size:.78rem}
  .padd input:focus{outline:none;border-color:var(--amber);border-style:solid}
  .padd button{padding:.4rem .8rem;border:1px solid var(--trail);background:rgba(127,176,105,.18);
    color:var(--trail);border-radius:7px;font-family:"Archivo";font-weight:600;font-size:.74rem;cursor:pointer}
  .padd button:hover{background:rgba(127,176,105,.3)}
  /* place item row inside a vsec */
  .prow{display:flex;align-items:center;gap:.5rem;padding:.32rem .4rem;border-radius:6px;font-size:.84rem}
  .prow:hover{background:rgba(232,160,76,.06)}
  .prow .pn{flex:1;color:var(--paper)}
  .prow .src{font-size:.62rem;color:var(--muted);font-family:"DM Mono",monospace;letter-spacing:.04em;
    padding:.08rem .4rem;border-radius:10px;border:1px solid var(--line)}
  .prow .rm{flex:none;width:22px;height:22px;border:1px solid var(--line);background:transparent;
    color:var(--muted);border-radius:6px;cursor:pointer;font-size:.85rem;line-height:1;padding:0;
    display:inline-flex;align-items:center;justify-content:center}
  .prow .rm:hover{border-color:var(--rust);color:var(--rust)}
  .pempty{padding:.4rem 1.6rem .8rem;font-size:.72rem;color:var(--muted);font-style:italic}
  .vmodal{margin:12px 12px 12px 360px;background:var(--panel);border:1px solid var(--line);
    border-radius:14px;width:calc(100% - 372px);max-width:900px;max-height:calc(100vh - 24px);
    display:flex;flex-direction:column;overflow:hidden;cursor:default;
    box-shadow:0 30px 80px rgba(0,0,0,.6)}
  .vtop{padding:.9rem 1.1rem .8rem;border-bottom:1px solid var(--line);position:relative}
  .vtoprow{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
  .vtoprow{display:flex;gap:.55rem;align-items:center;flex-wrap:wrap}
  .vtitle{font-family:"Fraunces",serif;font-weight:700;font-size:1.35rem;color:var(--amber);line-height:1.1;flex:1;min-width:0}
  .vactions{display:flex;gap:.4rem;align-items:center;flex-wrap:wrap}
  /* unified header buttons: same border/font/size for Upload, ✕, ⓘ */
  .vhbtn{padding:.45rem .8rem;border:1px solid var(--amber);background:transparent;color:var(--amber);
    border-radius:8px;font-family:"Archivo";font-weight:600;font-size:.78rem;cursor:pointer;line-height:1;
    display:inline-flex;align-items:center;justify-content:center;height:34px}
  .vhbtn:hover{background:rgba(232,160,76,.12)}
  .vhbtn:disabled{opacity:.5;cursor:default}
  .vhbtn.vhicon{padding:0;width:34px;font-size:.95rem}
  .vhbtn.on{background:rgba(232,160,76,.18)}
  #tlclear{border-color:var(--line);color:var(--muted)}
  #tlclear:hover{border-color:var(--rust);color:var(--rust)}
  .vactions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}
  #tlbtn:disabled{opacity:.5;cursor:default}
  .tlstatus{font-size:.7rem;color:var(--muted);min-height:1em;margin-top:.5rem}
  .tlstatus.success{color:var(--trail)}
  .tlstatus.error{color:var(--rust)}

  .iwrap{position:relative;display:inline-flex}
  .iicon{width:28px;height:28px;border-radius:50%;border:1px solid var(--line);background:transparent;
    color:var(--muted);font-size:.95rem;line-height:1;cursor:pointer;flex:none;padding:0;
    display:inline-flex;align-items:center;justify-content:center}
  .iicon:hover{color:var(--amber);border-color:var(--amber)}
  .ipop{display:none;position:fixed;width:280px;max-width:calc(100vw - 24px);
    background:var(--ink);border:1px solid var(--line);border-radius:9px;padding:.6rem .8rem;
    font-size:.74rem;color:var(--paper);line-height:1.5;z-index:1500;
    box-shadow:0 16px 40px rgba(0,0,0,.6)}
  .ipop.show{display:block}
  .ipop ul{list-style:none;margin:0;padding:0}
  .ipop li{padding:.2rem 0 .2rem .9rem;position:relative}
  .ipop li::before{content:"·";color:var(--amber);position:absolute;left:.15rem;font-weight:bold;font-size:1.1rem;line-height:.9}
  .ipop code{font-family:"DM Mono",monospace;font-size:.66rem;background:rgba(232,160,76,.12);
    padding:0 .25rem;border-radius:3px;color:var(--amber)}

  #vbody, #placesBody{flex:1;overflow-y:auto;padding:.3rem 1rem .8rem;
    scrollbar-width:none;-ms-overflow-style:none}
  #vbody::-webkit-scrollbar, #placesBody::-webkit-scrollbar{width:0;height:0;display:none}
  #vbody::-webkit-scrollbar-thumb, #placesBody::-webkit-scrollbar-thumb{background:transparent}
  .vsec{border-bottom:1px solid var(--line)}
  .vhead{display:flex;align-items:center;gap:.55rem;padding:.5rem .3rem;cursor:pointer;
    position:sticky;top:0;background:var(--ink);z-index:5;border-bottom:1px solid var(--line)}
  .vhead:hover{background:var(--panel-2)}
  .vhead .chev{flex:none;width:14px;color:#6d8073;font-size:.75rem;transition:transform .18s}
  .vsec.open .vhead .chev{transform:rotate(90deg);color:var(--amber)}
  .vbodytxt{flex:1;min-width:0}
  .vname{font-size:.95rem;font-weight:600;color:var(--paper)}
  .vinfo{font-size:.68rem;color:var(--muted);margin-top:1px}
  .vcount{flex:none;font-family:"DM Mono",monospace;font-size:.66rem;color:var(--trail);
    border:1px solid var(--line);border-radius:20px;padding:.2rem .6rem}
  .vitems{display:none;padding:.1rem .3rem 1rem 1.6rem}
  .vsec.open .vitems{display:block}

  .legend{padding:.2rem 1rem .4rem}
  .legend .row{display:flex;align-items:center;gap:.55rem;font-size:.7rem;color:var(--muted);padding:.16rem 0}
  .legend .row span.k{width:14px;height:10px;border-radius:3px;flex:none}

  .note{padding:.4rem 1rem 0;font-size:.66rem;color:#7d9387;line-height:1.45}
  .note b{color:var(--paper);font-weight:600}

  .tab{position:fixed;z-index:1150;top:64px;left:.8rem;width:42px;height:42px;border-radius:12px;background:var(--panel);
    border:1px solid var(--line);color:var(--amber);cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(0,0,0,.5)}
  .panel.collapsed ~ .tab{display:flex}
  .panelclose{position:absolute;top:.6rem;right:.6rem;width:28px;height:28px;border-radius:8px;border:1px solid var(--line);
    background:var(--panel-2);color:var(--muted);cursor:pointer;font-size:1rem;line-height:1;z-index:2}
  .panelclose:hover{color:var(--amber);border-color:var(--amber)}

  .readout{position:fixed;z-index:1100;bottom:.7rem;left:50%;transform:translateX(-50%);background:rgba(12,20,17,.86);
    border:1px solid var(--line);border-radius:9px;padding:.32rem .7rem;font-family:"DM Mono",monospace;font-size:.66rem;
    color:var(--muted);white-space:nowrap;box-shadow:0 6px 18px rgba(0,0,0,.4);backdrop-filter:blur(4px)}
  .readout b{color:var(--amber);font-weight:500}

  .leaflet-popup-content-wrapper{background:var(--panel);color:var(--paper);border-radius:12px;border:1px solid var(--line)}
  .leaflet-popup-tip{background:var(--panel);border:1px solid var(--line)}
  .leaflet-popup-content{margin:.45rem .55rem;font-family:"Archivo";font-size:.8rem;line-height:1.25;min-width:0}
  .leaflet-popup-content .poprow{display:flex;align-items:center;gap:.6rem}
  .leaflet-popup-content .poptext{flex:1;min-width:0}
  .leaflet-popup-content .popname{font-family:"Fraunces";font-size:.95rem;font-weight:600;color:var(--amber);
    line-height:1.15;word-break:break-word}
  .leaflet-popup-content .popsub{font-size:.68rem;color:var(--muted);line-height:1.35;margin-top:.3rem}
  .leaflet-popup-content .popicons{display:flex;flex-direction:column;gap:.3rem;flex:none}
  .popicon{width:23px;height:23px;border-radius:50%;border:1px solid var(--line);background:transparent;color:var(--muted);
    cursor:pointer;font-size:.76rem;line-height:1;padding:0;flex:none;
    display:inline-flex;align-items:center;justify-content:center;text-decoration:none;transition:.12s}
  .popicon:hover{color:var(--amber);border-color:var(--amber)}
  .popcheck.on{background:rgba(127,176,105,.22);border-color:var(--trail);color:var(--trail)}
  .popcheck.on:hover{color:var(--paper)}
  .leaflet-popup-close-button{display:none !important}
  .leaflet-bar a{background:var(--panel);color:var(--paper);border-bottom:1px solid var(--line)}
  .leaflet-bar a:hover{background:var(--panel-2)}
  .leaflet-control-attribution{background:rgba(12,20,17,.7)!important;color:#7d9387!important}
  .leaflet-control-attribution a{color:var(--muted)!important}
  .spin{display:inline-block;width:10px;height:10px;border:2px solid var(--line);border-top-color:var(--amber);border-radius:50%;animation:s .7s linear infinite;vertical-align:-1px}
  @keyframes s{to{transform:rotate(360deg)}}
  .map-busy{position:fixed;top:64px;right:.8rem;z-index:1100;background:var(--panel);border:1px solid var(--line);
    border-radius:11px;padding:.55rem .95rem;font-family:"DM Mono";font-size:.84rem;color:var(--paper);display:none;align-items:center;gap:.55rem;
    box-shadow:0 8px 24px rgba(0,0,0,.4)}
  .map-busy .spin{width:14px;height:14px}
  .map-busy.show{display:flex}
  /* Feedback / coffee popups */
  #feedback,#coffee{position:fixed;inset:0;z-index:2400;background:rgba(0,0,0,.55);display:none;
    align-items:center;justify-content:center;padding:1rem}
  #feedback.open,#coffee.open{display:flex}
  .fbcard{width:min(380px,100%);background:var(--panel);border:1px solid var(--line);border-radius:16px;
    padding:1.3rem 1.2rem 1.1rem;box-shadow:0 20px 60px rgba(0,0,0,.55)}
  .fbtitle{font-family:"Archivo";font-weight:800;font-size:1.05rem;color:var(--paper)}
  .fbsub{margin:.25rem 0 .9rem;color:var(--muted);font-size:.78rem;line-height:1.4}
  .fbfrom{font-size:.76rem;color:var(--muted);margin-bottom:.55rem}
  .fbfrom b{color:var(--paper)}
  #feedback input,#feedback textarea{width:100%;box-sizing:border-box;padding:.55rem .65rem;border:1px solid var(--line);
    background:var(--panel-2);color:var(--paper);border-radius:9px;font-family:"Archivo";font-size:.84rem;margin-bottom:.55rem}
  #feedback textarea{resize:vertical;line-height:1.4}
  #feedback input::placeholder,#feedback textarea::placeholder{color:var(--muted)}
  #feedback input:focus,#feedback textarea:focus{outline:none;border-color:var(--amber)}
  .fbstatus{font-size:.74rem;min-height:1em;margin-bottom:.4rem}
  .fbstatus.ok{color:var(--trail)} .fbstatus.err{color:var(--rust)}
  .fbbtns{display:flex;justify-content:flex-end;gap:.5rem}
  #diag{position:fixed;inset:0;z-index:2000;display:none;align-items:center;justify-content:center;padding:1.5rem;
    background:rgba(8,14,11,.92);backdrop-filter:blur(3px);cursor:pointer}
  #diag.show{display:flex}
  #diag::before{content:"";position:absolute}
  #diag>span,#diag{}
  #diag .card{max-width:460px;background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:1.4rem 1.5rem;
    box-shadow:0 24px 70px rgba(0,0,0,.6);font-size:.9rem;line-height:1.5;color:var(--paper);text-align:left}
  #diag .card h4{margin:0 0 .6rem;font-family:"Fraunces";color:var(--amber);font-size:1.15rem}
  #diag .card b{color:var(--amber)}
  #diag .card .x{display:block;margin-top:.9rem;font-size:.72rem;color:var(--muted)}
  /* ---------- Phone / portrait layout ---------- */
  @media (max-width: 600px), (orientation: portrait) and (max-width: 820px){
    .panel{top:.5rem;left:.5rem;right:.5rem;width:auto;max-width:none;border-radius:14px}
    .panel-scroll{max-height:calc(100vh - .8rem)}
    .panel-brand{font-size:1rem;padding:.65rem .85rem .1rem}
    /* full-screen modals */
    .vmodal{margin:0;width:100%;height:100%;max-height:100vh;border-radius:0;border:0}
    #visits .vmodal, #settings .vmodal{width:100%}
    #settings .vmodal{width:100%}
    #settingsBody{grid-template-columns:1fr}
    .vtitle{font-size:1.15rem}
    /* layer rows a touch taller for finger taps */
    .layer{padding:.3rem .35rem}
    /* keep the settings button row swipeable */
    .settings-row{gap:.35rem}
    /* bottom-anchored controls clear of the panel */
    .fabs{bottom:1rem}
  }
  /* very short viewports: let settings color grid stay 2-up but scroll gracefully */
  @media (max-height: 560px){
    .vmodal{margin:8px;max-height:calc(100vh - 16px)}
  }
