/* ============================================================
   TribeTrak · Constellation (refined)
   Straight star-map links · pan & zoom · quick-view modal
   Light + Deep-space, Cosmic Bloom tokens.
   ============================================================ */
:root{
  --jakarta:'Plus Jakarta Sans',-apple-system,system-ui,sans-serif;
  --inter:'Inter',-apple-system,system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;}
body{
  font-family:var(--inter);color:#EDE7FB;background:#0E0824;
  background-image:
    radial-gradient(1100px 720px at 16% -10%, #1d1346 0%, rgba(29,19,70,0) 60%),
    radial-gradient(1000px 760px at 98% 8%, #241149 0%, rgba(36,17,73,0) 55%),
    radial-gradient(900px 800px at 90% 108%, #2a0f3a 0%, rgba(42,15,58,0) 58%);
  min-height:100%;padding:54px 30px 90px;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:1060px;margin:0 auto;}

/* ---------- intro ---------- */
.head{display:flex;align-items:flex-start;gap:20px;margin-bottom:14px;}
.head .badge{width:54px;height:54px;border-radius:16px;flex:none;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,#6C4BD6,#8E6BEA);box-shadow:0 14px 30px -10px rgba(108,75,214,.7);}
.kicker{font-family:var(--jakarta);font-weight:700;font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:#FFC85C;margin-bottom:7px;}
.head h1{font-family:var(--jakarta);font-weight:800;font-size:29px;letter-spacing:-.02em;line-height:1.04;}
.head h1 span{color:#B49AF6;}
.head p{font-size:14px;color:#BBAEE4;max-width:640px;margin-top:9px;line-height:1.6;}
.head p b{color:#E6DCFF;font-weight:700;}

.hint{display:flex;flex-wrap:wrap;gap:9px;margin:20px 0 36px;}
.hint .chip{display:flex;align-items:center;gap:8px;background:rgba(40,26,82,.55);border:1px solid #3a2a66;
  border-radius:999px;padding:8px 14px 8px 11px;font-size:12px;color:#C9BCF2;font-weight:500;}
.hint .chip b{color:#F4F1FF;font-family:var(--jakarta);font-weight:700;}
.hint .chip svg{width:14px;height:14px;color:#B49AF6;}

/* ---------- device columns ---------- */
.stage{display:flex;gap:56px;justify-content:center;align-items:flex-start;flex-wrap:wrap;}
.device-col{display:flex;flex-direction:column;align-items:center;gap:15px;}
.device-label{display:flex;align-items:center;gap:9px;font-family:var(--jakarta);font-weight:700;font-size:14px;color:#E6DCFF;}
.device-label .dot{width:10px;height:10px;border-radius:50%;}
.device-label .sub{font-family:var(--inter);font-weight:500;font-size:12px;color:#9385BC;}

/* ---------- phone frame ---------- */
.phone{
  width:390px;height:844px;border-radius:54px;position:relative;flex:none;padding:13px;
  background:linear-gradient(160deg,#2A2150,#171033);
  box-shadow:0 2px 4px rgba(20,11,46,.5) inset,0 40px 80px -24px rgba(8,4,24,.7),0 12px 28px -14px rgba(8,4,24,.6);
}
.phone::after{content:"";position:absolute;left:-3px;top:168px;width:3px;height:62px;border-radius:3px;
  background:#241A4D;box-shadow:0 86px 0 #241A4D,0 -90px 0 #241A4D;}
.screen{width:100%;height:100%;border-radius:42px;overflow:hidden;position:relative;background:var(--bg);
  font-family:var(--inter);color:var(--text);}

/* theme tokens */
.screen[data-theme="light"]{
  --bg:#FFFFFF;--surface:#FFFFFF;--surface-2:#FAF7FF;--surface-3:#F1ECFB;--violet:#6C4BD6;--violet-soft:#8E6BEA;--violet-deep:#5838BE;
  --node:#F2A93B;--node-glow:rgba(242,169,59,.5);--node-hi:#FFE6B0;--coral:#FF6F91;
  --text:#241A4D;--muted:#6B5E96;--faint:#9A8DC4;--border:#ECE6FA;--border-2:#E3DAF6;--chip:#F4EFFD;--chip-text:#6C4BD6;
  --glass-strong:rgba(255,255,255,.9);--shadow-card:0 18px 40px -18px rgba(108,75,214,.34);--shadow-sheet:0 -16px 44px -18px rgba(108,75,214,.26);
  --user-glow:rgba(108,75,214,.45);--statusbar:#241A4D;}
.screen[data-theme="dark"]{
  --bg:#140B2E;--surface:#241646;--surface-2:#2A1A52;--surface-3:#321F60;--violet:#9B7BF0;--violet-soft:#B49AF6;--violet-deep:#7C5BD0;
  --node:#FFC85C;--node-glow:rgba(255,200,92,.6);--node-hi:#FFF0CC;--coral:#FF6F91;
  --text:#F4F1FF;--muted:#C9BCF2;--faint:#8E7FC0;--border:#332159;--border-2:#3C2A66;--chip:#2C1C57;--chip-text:#C9BCF2;
  --glass-strong:rgba(20,11,46,.7);--shadow-card:0 20px 46px -18px rgba(0,0,0,.6);--shadow-sheet:0 -18px 50px -16px rgba(0,0,0,.5);
  --user-glow:rgba(155,123,240,.6);--statusbar:#F4F1FF;}
.screen[data-theme="dark"]{background:
  radial-gradient(440px 360px at 80% 4%, rgba(155,123,240,.18), transparent 70%),
  radial-gradient(380px 340px at 6% 98%, rgba(255,111,145,.10), transparent 72%),var(--bg);}
.screen[data-theme="light"]{background:
  radial-gradient(520px 360px at 86% 4%, rgba(142,107,234,.06), transparent 70%),
  radial-gradient(420px 340px at 4% 98%, rgba(255,111,145,.05), transparent 72%),var(--bg);}

/* status bar */
.island{position:absolute;top:11px;left:50%;transform:translateX(-50%);width:108px;height:30px;background:#0A0620;border-radius:18px;z-index:60;}
.statusbar{position:absolute;top:0;left:0;right:0;height:50px;z-index:59;display:flex;align-items:center;justify-content:space-between;
  padding:16px 30px 0;font-family:var(--jakarta);font-weight:700;font-size:14px;color:var(--statusbar);}
.statusbar .ic{display:flex;gap:6px;align-items:center;}

/* app shell */
.app{position:absolute;inset:0;display:flex;flex-direction:column;padding-top:50px;}
.app-head{flex:none;padding:8px 18px 12px;position:relative;z-index:20;}
.head-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;}
.head-title h1{font-family:var(--jakarta);font-weight:800;font-size:25px;letter-spacing:-.025em;line-height:1.05;color:var(--text);}
.head-count{font-size:13px;color:var(--muted);font-weight:600;margin-top:4px;display:flex;align-items:center;gap:7px;}
.head-count .sep{width:3px;height:3px;border-radius:50%;background:var(--faint);}
.head-count b{font-family:var(--jakarta);color:var(--text);font-weight:700;}
.viewtoggle{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:13px;padding:3px;gap:2px;flex:none;}
.viewtoggle button{border:none;background:transparent;cursor:pointer;width:38px;height:34px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;color:var(--faint);}
.viewtoggle button svg{width:18px;height:18px;}
.viewtoggle button.on{background:var(--surface);color:var(--violet);box-shadow:0 4px 10px -4px rgba(108,75,214,.4);}
.screen[data-theme="dark"] .viewtoggle button.on{box-shadow:0 4px 12px -4px rgba(0,0,0,.6);}
.avatar{width:40px;height:40px;border-radius:50%;flex:none;background:radial-gradient(circle at 35% 30%,var(--violet-soft),var(--violet) 72%);
  border:2px solid var(--surface);box-shadow:0 0 0 1px var(--border),0 6px 14px -6px rgba(108,75,214,.6);
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--jakarta);font-weight:800;font-size:15px;cursor:pointer;}
.searchrow{display:flex;gap:8px;align-items:center;margin-top:14px;}
.search{flex:1;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:15px;
  padding:11px 13px;box-shadow:var(--shadow-card);min-width:0;}
.search svg{width:17px;height:17px;color:var(--violet);flex:none;}
.search .ph{font-size:13.5px;color:var(--faint);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.iconbtn{width:46px;height:46px;border-radius:14px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-card);
  display:flex;align-items:center;justify-content:center;flex:none;position:relative;cursor:pointer;}
.iconbtn svg{width:19px;height:19px;color:var(--violet);}
.iconbtn .badge{position:absolute;top:-5px;right:-5px;min-width:19px;height:19px;border-radius:999px;
  background:linear-gradient(150deg,#FF8AA6,#FF6F91);color:#fff;font-family:var(--jakarta);font-weight:800;font-size:10.5px;
  display:flex;align-items:center;justify-content:center;padding:0 5px;border:2px solid var(--bg);}

.app-body{flex:1;position:relative;overflow:hidden;}

/* ===================== GEO CONSTELLATION ===================== */
.cmap{position:absolute;inset:0;overflow:hidden;touch-action:none;cursor:grab;}
.cmap.grabbing{cursor:grabbing;}
.earth-canvas{position:absolute;top:0;left:0;transform-origin:0 0;will-change:transform;}
.geo-arcs{position:absolute;inset:0;width:100%;height:100%;overflow:visible;pointer-events:none;}
/* straight star-map links */
.geo-link{fill:none;stroke:var(--violet);stroke-width:1.8;stroke-linecap:round;opacity:.82;
  filter:drop-shadow(0 0 3px var(--violet));}
.geo-link.faint{stroke:var(--faint);stroke-width:1.2;opacity:.45;filter:none;stroke-dasharray:1.5 5;}
.geo-link.web{stroke:var(--violet-soft);stroke-width:1;opacity:.30;filter:none;}
.geo-link.lit{stroke-width:3;opacity:1;}
.cplay .geo-link{stroke-dasharray:var(--len);stroke-dashoffset:var(--len);animation:geodraw .85s cubic-bezier(.6,0,.3,1) forwards;}
.cplay .geo-link.faint{animation:geodraw 1s ease forwards;}
.cplay .geo-link.web{animation:geodraw 1.1s ease forwards;}
@keyframes geodraw{to{stroke-dashoffset:0;}}

.geo-node{position:absolute;transform:translate(-50%,-50%);cursor:pointer;will-change:left,top;}
.geo-dot{width:31px;height:31px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;
  font-family:var(--jakarta);font-weight:800;font-size:12.5px;border:2.5px solid var(--node);background:var(--av,#8E6BEA);
  box-shadow:0 0 0 2.5px var(--node-glow),0 0 13px 2px var(--node-glow);transition:transform .16s;}
.geo-node.you .geo-dot{width:30px;height:30px;border:none;
  background:radial-gradient(circle at 35% 30%,var(--violet-soft),var(--violet) 70%);
  box-shadow:0 0 0 5px var(--user-glow),0 0 24px 5px var(--user-glow);}
.geo-node.you::before{content:"";position:absolute;left:50%;top:50%;width:30px;height:30px;border-radius:50%;
  transform:translate(-50%,-50%);border:2px solid var(--violet);animation:geobreathe 3.4s ease-in-out infinite;}
@keyframes geobreathe{0%,100%{width:30px;height:30px;opacity:.7;}50%{width:62px;height:62px;opacity:0;}}
.geo-node.faint .geo-dot{width:12px;height:12px;border-width:1.5px;font-size:0;
  background:radial-gradient(circle at 35% 30%,var(--node-hi),var(--node) 75%);
  box-shadow:0 0 0 2px var(--node-glow),0 0 10px 1px var(--node-glow);opacity:.85;}
.geo-node.sel .geo-dot{transform:scale(1.18);box-shadow:0 0 0 3px var(--node-glow),0 0 22px 6px var(--node-glow);}
.geo-node.pulse .geo-dot{animation:geopulse .42s ease;}
@keyframes geopulse{50%{transform:scale(1.28);}}

.geo-tip{position:absolute;left:50%;top:-9px;transform:translate(-50%,-100%);white-space:nowrap;
  font-family:var(--jakarta);font-weight:700;font-size:10.5px;background:var(--surface);color:var(--text);
  padding:3px 9px;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow-card);pointer-events:none;}
.geo-node.tip-bottom .geo-tip{top:auto;bottom:-9px;transform:translate(-50%,100%);}
.geo-node.tip-left .geo-tip{left:auto;right:calc(100% + 9px);top:50%;transform:translate(0,-50%);}
.geo-node.tip-right .geo-tip{left:calc(100% + 9px);top:50%;transform:translate(0,-50%);}

/* settle-in */
.cplay .geo-node{animation:geosettle .58s cubic-bezier(.34,1.56,.64,1) backwards;}
@keyframes geosettle{0%{opacity:0;transform:translate(-50%,-50%) scale(.1);}60%{opacity:1;}100%{opacity:1;transform:translate(-50%,-50%) scale(1);}}

/* zoom controls */
.zoom-ctrl{position:absolute;right:16px;bottom:16px;z-index:6;display:flex;flex-direction:column;gap:2px;
  background:var(--glass-strong);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:14px;
  padding:4px;box-shadow:var(--shadow-card);}
.zoom-ctrl button{width:40px;height:38px;border:none;background:transparent;color:var(--violet);cursor:pointer;border-radius:10px;
  display:flex;align-items:center;justify-content:center;transition:background .15s;}
.zoom-ctrl button:hover{background:var(--surface-2);}
.zoom-ctrl button:active{transform:scale(.92);}
.zoom-ctrl button svg{width:19px;height:19px;}
.zoom-ctrl .div{height:1px;background:var(--border);margin:1px 6px;}

/* ===================== QUICK-VIEW SHEET ===================== */
.qv-scrim{position:absolute;inset:0;z-index:48;background:rgba(20,11,46,.5);backdrop-filter:blur(2px);
  opacity:0;pointer-events:none;}
.screen.qv-open .qv-scrim{opacity:1;pointer-events:auto;}
.qv-sheet{position:absolute;left:0;right:0;bottom:0;z-index:49;background:var(--surface);
  border-radius:30px 30px 0 0;border-top:1px solid var(--border);box-shadow:var(--shadow-sheet);
  padding:10px 0 24px;transform:translateY(102%);}
.screen.qv-open .qv-sheet{transform:translateY(0);}
.qv-grab{width:42px;height:5px;border-radius:5px;background:var(--border-2);margin:4px auto 13px;}

.qv-id{display:flex;align-items:center;gap:13px;padding:0 20px 2px;}
.qv-star{width:50px;height:50px;border-radius:15px;flex:none;display:flex;align-items:center;justify-content:center;position:relative;
  background:linear-gradient(150deg,color-mix(in srgb,var(--node) 30%,var(--surface)),color-mix(in srgb,var(--node) 8%,var(--surface)));
  border:1px solid color-mix(in srgb,var(--node) 42%,transparent);}
.qv-star svg{width:24px;height:24px;color:var(--node);}
.qv-id .nm{font-family:var(--jakarta);font-weight:800;font-size:19px;letter-spacing:-.02em;color:var(--text);}
.qv-who{flex:1;min-width:0;}
.qv-id .loc{font-size:12px;color:var(--muted);margin-top:3px;font-weight:600;}

/* avatar stack (who) */
.qv-avstack{display:flex;flex:none;}
.qv-mini{width:42px;height:42px;border-radius:50%;background:var(--av);border:2.5px solid var(--surface);margin-left:-13px;
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--jakarta);font-weight:800;font-size:15px;
  box-shadow:0 0 0 1px var(--border);}
.qv-avstack .qv-mini:first-child{margin-left:0;}

/* where-now hero + stay bar */
.qv-where{margin:15px 20px 0;border-radius:16px;padding:13px 15px;
  background:linear-gradient(135deg, color-mix(in srgb,var(--node) 13%, var(--surface-2)), var(--surface-2));
  border:1px solid color-mix(in srgb,var(--node) 28%, var(--border));}
.qv-where .now{display:flex;align-items:center;gap:7px;font-family:var(--jakarta);font-weight:800;font-size:16px;color:var(--text);}
.qv-where .now svg{width:15px;height:15px;color:var(--node);flex:none;}
.qv-where .sub{font-size:11.5px;color:var(--muted);margin-top:3px;font-weight:500;}
.qv-where .sub b{color:var(--text);font-weight:700;}
.qv-stay{margin-top:11px;height:6px;border-radius:6px;background:var(--surface-3);overflow:hidden;}
.qv-stay i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--node-hi),var(--node));}
.qv-stay-row{display:flex;justify-content:space-between;margin-top:6px;font-size:10px;font-weight:700;color:var(--faint);}
.qv-stay-row span:last-child{color:var(--node);}
.screen[data-theme="dark"] .qv-stay-row span:last-child{color:var(--node-hi);}

/* route line */
.qv-route{display:flex;align-items:center;gap:7px;margin:13px 20px 0;font-size:12.5px;color:var(--muted);font-weight:600;flex-wrap:wrap;}
.qv-route svg{width:14px;height:14px;color:var(--violet);flex:none;}
.qv-route b{color:var(--text);font-family:var(--jakarta);font-weight:800;}
.qv-route .arr{color:var(--violet);font-family:var(--jakarta);font-weight:800;}
.qv-route .nextc{color:var(--node);font-family:var(--jakarta);font-weight:700;white-space:nowrap;}
.screen[data-theme="dark"] .qv-route .nextc{color:var(--node-hi);}
.qv-id .loc{font-size:12px;color:var(--muted);margin-top:3px;display:flex;align-items:center;gap:5px;font-weight:600;}
.qv-id .loc svg{width:12px;height:12px;color:var(--violet);flex:none;}
.qv-id .close{margin-left:auto;width:34px;height:34px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);
  display:flex;align-items:center;justify-content:center;cursor:pointer;flex:none;}
.qv-id .close svg{width:16px;height:16px;color:var(--muted);}

.qv-meta{display:flex;gap:8px;padding:14px 20px 0;}
.qv-chip{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:13px;padding:9px 11px;}
.qv-chip .k{font-size:9.5px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--faint);}
.qv-chip .v{font-family:var(--jakarta);font-weight:700;font-size:12.5px;margin-top:3px;display:flex;align-items:center;gap:5px;color:var(--text);}
.qv-chip .v svg{width:12px;height:12px;color:var(--node);flex:none;}
.qv-kids{display:flex;align-items:center;gap:5px;}
.qv-kids span{font-family:var(--jakarta);font-weight:800;font-size:12px;color:var(--chip-text);}
.qv-kids .d{width:3px;height:3px;border-radius:50%;background:var(--faint);}

.qv-people{padding:14px 20px 0;display:flex;flex-direction:column;gap:8px;}
.qv-lab{font-family:var(--jakarta);font-weight:800;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:2px;}
.qv-prow{display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--border);border-radius:14px;padding:9px 12px;}
.qv-av{width:38px;height:38px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;color:#fff;
  font-family:var(--jakarta);font-weight:800;font-size:14px;background:var(--av);position:relative;}
.qv-av .ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid color-mix(in srgb,var(--violet) 55%,transparent);}
.qv-pmain{flex:1;min-width:0;}
.qv-pname{font-family:var(--jakarta);font-weight:800;font-size:14px;letter-spacing:-.01em;color:var(--text);display:flex;align-items:center;gap:6px;}
.qv-pname .live{width:7px;height:7px;border-radius:50%;background:#37C98A;box-shadow:0 0 0 3px rgba(55,201,138,.18);flex:none;}
.qv-psub{font-size:11px;color:var(--muted);margin-top:1px;}
.qv-msg{width:38px;height:38px;border-radius:12px;flex:none;border:1px solid color-mix(in srgb,var(--violet) 28%,transparent);
  background:color-mix(in srgb,var(--violet) 12%,transparent);display:flex;align-items:center;justify-content:center;cursor:pointer;}
.qv-msg svg{width:17px;height:17px;color:var(--violet);}
.qv-prow.ghost .qv-av{opacity:.55;filter:grayscale(.25);}
.qv-prow.ghost .qv-pname{color:var(--faint);}
.qv-connect{flex:none;border:1px dashed color-mix(in srgb,var(--violet) 45%,transparent);background:transparent;cursor:pointer;
  font-family:var(--jakarta);font-weight:800;font-size:11.5px;color:var(--violet);padding:7px 11px;border-radius:999px;}

.qv-actions{display:flex;gap:10px;padding:16px 20px 0;}
.qv-profile,.qv-details{flex:1;height:50px;border:none;border-radius:999px;cursor:pointer;text-decoration:none;
  background:linear-gradient(150deg,var(--violet),var(--violet-deep));color:#fff;font-family:var(--jakarta);font-weight:800;font-size:14.5px;
  display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 14px 28px -10px var(--violet-deep);transition:transform .14s;}
.qv-profile:active,.qv-details:active{transform:scale(.97);}
.qv-profile svg,.qv-details svg{width:18px;height:18px;}
.qv-fav{flex:none;width:54px;height:50px;border-radius:999px;cursor:pointer;background:color-mix(in srgb,var(--node) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--node) 32%,transparent);display:flex;align-items:center;justify-content:center;transition:transform .14s;}
.qv-fav:active{transform:scale(.92);}
.qv-fav svg{width:20px;height:20px;color:var(--node);}

/* ===== wider-tribe toggle (map overlay) ===== */
.wt-toggle{position:absolute;top:14px;left:14px;z-index:6;display:flex;align-items:center;gap:8px;cursor:pointer;
  background:var(--glass-strong);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:999px;
  padding:6px 8px 6px 11px;box-shadow:var(--shadow-card);font-family:var(--jakarta);font-weight:700;font-size:11.5px;color:var(--text);}
.wt-toggle .wt-ic{display:flex;}
.wt-toggle .wt-ic svg{width:14px;height:14px;color:var(--node);}
.wt-toggle .wt-lab{white-space:nowrap;}
.wt-toggle .wt-sw{width:30px;height:18px;border-radius:999px;background:color-mix(in srgb,var(--node) 70%,transparent);position:relative;transition:background .18s;flex:none;}
.wt-toggle .wt-sw i{position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .18s;box-shadow:0 1px 3px rgba(0,0,0,.3);}
.wt-toggle.off{color:var(--muted);}
.wt-toggle.off .wt-ic svg{color:var(--faint);}
.wt-toggle.off .wt-sw{background:var(--surface-3);}
.wt-toggle.off .wt-sw i{left:14px;}

/* ===== friend-of-family card (extended tribe) ===== */
.fof-star{width:50px;height:50px;border-radius:15px;flex:none;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,color-mix(in srgb,var(--violet) 26%,var(--surface)),color-mix(in srgb,var(--violet) 7%,var(--surface)));
  border:1px solid color-mix(in srgb,var(--violet) 38%,transparent);}
.fof-star svg{width:24px;height:24px;color:var(--violet);}
.fof-badge{display:inline-block;font-family:var(--jakarta);font-weight:800;font-size:9px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--violet);background:color-mix(in srgb,var(--violet) 14%,transparent);border:1px solid color-mix(in srgb,var(--violet) 30%,transparent);
  padding:2px 7px;border-radius:999px;margin-right:7px;vertical-align:middle;}
.fof-link{margin:15px 20px 0;border-radius:16px;padding:14px 15px;background:var(--surface-2);border:1px solid var(--border);}
.fof-link-head{font-family:var(--jakarta);font-weight:800;font-size:15px;letter-spacing:-.01em;color:var(--text);}
.fof-chips{display:flex;flex-wrap:wrap;gap:7px;margin-top:11px;}
.fof-chip{display:flex;align-items:center;gap:7px;background:var(--surface);border:1px solid var(--border);border-radius:999px;
  padding:4px 12px 4px 4px;font-family:var(--jakarta);font-weight:700;font-size:12px;color:var(--text);}
.fof-av{width:24px;height:24px;border-radius:50%;flex:none;background:var(--av);display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:var(--jakarta);font-weight:800;font-size:11px;}
.fof-why{margin-top:12px;font-size:11.5px;color:var(--muted);font-weight:500;}
.fof-why b{color:var(--text);font-family:var(--jakarta);font-weight:800;}
.fof-request{gap:9px;}
.fof-request svg{width:17px;height:17px;}
.fof-request span{display:inline-block;}
.fof-hide svg{width:17px;height:17px;color:var(--muted);}
.fof-manage{display:block;width:calc(100% - 40px);margin:12px 20px 0;background:transparent;border:none;cursor:pointer;
  font-family:var(--jakarta);font-weight:700;font-size:12px;color:var(--faint);text-align:center;padding:6px;text-decoration:underline;text-underline-offset:3px;}
.fof-manage:hover{color:var(--violet);}

/* toast */
.cc-toast{position:absolute;left:50%;top:18px;transform:translateX(-50%) translateY(-12px);
  z-index:55;background:var(--glass-strong);backdrop-filter:blur(8px);border:1px solid var(--border);
  color:var(--text);font-family:var(--jakarta);font-weight:700;font-size:12px;padding:8px 15px;border-radius:999px;
  box-shadow:var(--shadow-card);opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;white-space:nowrap;}
.cc-toast.on{opacity:1;transform:translateX(-50%) translateY(0);}

/* tab bar */
.tabbar{flex:none;display:flex;align-items:flex-start;justify-content:space-around;padding:9px 8px 26px;
  background:var(--glass-strong);backdrop-filter:blur(14px);border-top:1px solid var(--border);position:relative;z-index:30;}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;cursor:pointer;color:var(--faint);
  font-family:var(--jakarta);font-weight:700;font-size:9.5px;background:none;border:none;padding:2px 0;}
.tab .ticon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;}
.tab .ticon svg{width:22px;height:22px;}
.tab.on{color:var(--violet);}
.tab.on .ticon{background:radial-gradient(circle at 35% 28%,var(--node-hi),var(--node) 72%);
  box-shadow:0 0 0 3px var(--node-glow),0 0 18px 2px var(--node-glow);}
.tab.on .ticon svg{color:#3A2A08;}

@media (prefers-reduced-motion:reduce){
  .cplay .geo-link,.cplay .geo-node,.geo-node.you::before,.geo-node.pulse .geo-dot{animation:none;}
  .cplay .geo-link{stroke-dashoffset:0;}
}
@media (max-width:900px){.stage{gap:36px;}body{padding:40px 16px 70px;}}
