/* ===========================================================================
   Pipeworks — marketing site
   Static rebuild of the Claude Design prototype (Website.html).
   - Brand tokens (shared with the macOS app)
   - Marketing page styles
   - Ported app-component CSS for the living menu-bar popover mock
   =========================================================================== */

/* ---- Pipeworks brand tokens (shared with the app) ---- */
:root {
  --pipe-green:      #1E9E57;
  --pipe-green-deep: #157A42;
  --pipe-rim:        #0C5E34;
  --pipe-sheen:      #54CC85;
  --pipe-hi:         #8BE3AD;
  --brass:           #C8A24B;
  --brass-deep:      #A9853A;
  --brass-hi:        #E6C878;
  --st-green:  #30D158;
  --st-amber:  #FF9F0A;
  --st-red:    #FF453A;
  --st-grey:   #8E8E93;
  --ease-warp: cubic-bezier(.34,1.56,.64,1);
  --ease-out:  cubic-bezier(.22,1,.36,1);
  --sf: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", system-ui, sans-serif;
  --mono: "IBM Plex Mono", "SF Mono", ui-monospace, Menlo, Monaco, monospace;
}
/* App appearance — DARK (charcoal) — scopes the product mock */
.app-dark {
  --bg:          #181a1c;
  --pop-bg:      rgba(34,35,38,0.74);
  --pop-border:  rgba(255,255,255,0.10);
  --surface:     #1f2022;
  --surface-2:   #2a2b2e;
  --surface-3:   #323337;
  --win-bg:      #1c1d1f;
  --field:       #2a2b2e;
  --field-line:  rgba(255,255,255,0.13);
  --text:        #f4f1ea;
  --text-2:      rgba(244,241,234,0.58);
  --text-3:      rgba(244,241,234,0.36);
  --sep:         rgba(255,255,255,0.085);
  --sep-strong:  rgba(255,255,255,0.16);
  --hover:       rgba(255,255,255,0.06);
  --chip-bg:     rgba(255,255,255,0.10);
  --shadow-pop:  0 1px 1px rgba(0,0,0,.4), 0 16px 50px rgba(0,0,0,.55), 0 2px 10px rgba(0,0,0,.4);
  --accent:      var(--pipe-sheen);
  --menubar-bg:  rgba(28,28,30,0.50);
  --menubar-fg:  #f0eee8;
}
.pw-app { font-family: var(--sf); }
::selection { background: rgba(84,204,133,.28); }

/* ===========================================================================
   Marketing site
   =========================================================================== */
:root{
  --s-bg:#0b0c0e;
  --s-bg2:#101216;
  --s-panel:#15171c;
  --s-panel2:#1b1e24;
  --s-line:rgba(255,255,255,.08);
  --s-line2:rgba(255,255,255,.14);
  --s-text:#edeef1;
  --s-dim:#9aa0ab;
  --s-faint:#6b7079;
  --s-accent:#54CC85;
  --s-accent-deep:#1E9E57;
  --s-brass:#C8A24B;
  --s-sans:-apple-system,BlinkMacSystemFont,"SF Pro Text","Helvetica Neue",system-ui,sans-serif;
  --s-mono:"IBM Plex Mono","SF Mono",ui-monospace,Menlo,monospace;
  --s-maxw:1140px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--s-bg);color:var(--s-text);font-family:var(--s-sans);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
::selection{background:rgba(84,204,133,.28);}
.s-wrap{max-width:var(--s-maxw);margin:0 auto;padding:0 28px;}
.s-eyebrow{font-family:var(--s-mono);font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--s-accent);display:inline-flex;align-items:center;gap:9px;}
.s-eyebrow::before{content:"";width:18px;height:1px;background:var(--s-accent);opacity:.6;}

/* ---------- nav ---------- */
.s-nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(16px) saturate(1.4);
  -webkit-backdrop-filter:blur(16px) saturate(1.4);background:rgba(11,12,14,.66);
  border-bottom:1px solid var(--s-line);}
.s-nav .in{display:flex;align-items:center;gap:18px;height:60px;}
.s-brand{display:flex;align-items:center;gap:11px;}
.s-brand .ic{width:28px;height:28px;border-radius:7px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.5);}
.s-brand .ic img{width:100%;height:100%;display:block;}
.s-brand .nm{font-family:var(--s-mono);font-weight:500;font-size:17px;letter-spacing:-.5px;}
.s-nav .links{margin-left:auto;display:flex;align-items:center;gap:26px;}
.s-nav .links a.nlink{font-size:13.5px;color:var(--s-dim);transition:color .15s;}
.s-nav .links a.nlink:hover{color:var(--s-text);}
.s-nav .links .s-btn{margin-left:6px;}
@media(max-width:720px){.s-nav .links a.nlink{display:none;}}

/* ---------- buttons ---------- */
.s-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--s-sans);font-size:14px;
  font-weight:600;padding:11px 18px;border-radius:11px;cursor:pointer;border:1px solid transparent;
  transition:transform .14s var(--s-ease,ease),filter .15s,background .15s,border-color .15s;white-space:nowrap;}
.s-btn.primary{background:linear-gradient(180deg,var(--s-accent),var(--s-accent-deep));
  color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.38);border-color:var(--s-accent-deep);
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset,0 8px 22px rgba(30,158,87,.28);}
.s-btn.primary:hover{filter:brightness(1.05);transform:translateY(-1px);}
.s-btn.ghost{background:rgba(255,255,255,.03);border-color:var(--s-line2);color:var(--s-text);}
.s-btn.ghost:hover{background:rgba(255,255,255,.07);}
.s-btn.sm{padding:8px 14px;font-size:13px;border-radius:9px;}
.s-btn .glyph{display:inline-flex;}

/* ---------- hero shared ---------- */
.s-hero{position:relative;overflow:hidden;padding-top:18px;}
.s-hero .glow{position:absolute;inset:0;pointer-events:none;z-index:0;
  background:radial-gradient(900px 460px at 18% 4%,rgba(30,158,87,.16),transparent 60%),
    radial-gradient(700px 380px at 92% 30%,rgba(200,162,75,.08),transparent 62%);}
.s-hero .grid-bg{position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--s-line) 1px,transparent 1px),linear-gradient(90deg,var(--s-line) 1px,transparent 1px);
  background-size:54px 54px;mask-image:radial-gradient(80% 60% at 50% 0%,#000,transparent 78%);
  -webkit-mask-image:radial-gradient(80% 60% at 50% 0%,#000,transparent 78%);}
.s-hero .in{position:relative;z-index:1;}

/* product hero */
.hero-product{display:grid;grid-template-columns:1.05fr 1fr;gap:56px;align-items:center;
  padding:64px 0 84px;}
.hero-copy h1{font-size:clamp(38px,5.4vw,68px);line-height:1.02;letter-spacing:-.025em;
  margin:20px 0 0;font-weight:680;text-wrap:balance;}
.hero-copy h1 .accent{color:var(--s-accent);}
.hero-copy .sub{font-size:clamp(16px,1.5vw,19px);color:var(--s-dim);line-height:1.6;
  margin:22px 0 0;max-width:30em;}
.hero-cta{display:flex;align-items:center;gap:16px;margin-top:34px;flex-wrap:wrap;}
.hero-meta{font-family:var(--s-mono);font-size:12px;color:var(--s-faint);margin-top:18px;
  display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.hero-meta b{color:var(--s-dim);font-weight:500;}
.hero-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--s-faint);}

/* statement hero (kept for completeness; product hero is the shipped default) */
.hero-statement{text-align:center;padding:62px 0 80px;display:flex;flex-direction:column;align-items:center;}
.hero-statement .bigicon{width:108px;height:108px;border-radius:25px;overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.55),0 0 0 1px rgba(255,255,255,.05);margin-bottom:30px;}
.hero-statement .bigicon img{width:100%;height:100%;display:block;}
.hero-statement h1{font-size:clamp(46px,8vw,104px);line-height:.96;letter-spacing:-.04em;
  margin:14px 0 0;font-weight:700;font-family:var(--s-mono);}
.hero-statement .sub{font-size:clamp(17px,1.7vw,21px);color:var(--s-dim);line-height:1.55;
  margin:24px auto 0;max-width:24em;}
.hero-statement .hero-cta{justify-content:center;}
.hero-statement .stage{margin-top:54px;}

/* ---------- desktop / popover mock ---------- */
.dt-mock{position:relative;border-radius:16px;overflow:hidden;border:1px solid var(--s-line2);
  background:
    radial-gradient(120% 90% at 30% 0%,#1b4a37 0%,#123026 38%,#0c1b18 100%);
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 2px 0 rgba(255,255,255,.05) inset;}
.dt-mock.tall{min-height:430px;}
.dt-bar{display:flex;align-items:center;gap:18px;height:30px;padding:0 14px;
  background:rgba(20,22,25,.5);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,.06);position:relative;z-index:2;}
.dt-bar .mleft{display:flex;align-items:center;gap:17px;font-size:12.5px;color:rgba(255,255,255,.82);}
.dt-bar .mleft .b{font-weight:700;}
.dt-bar .mright{margin-left:auto;display:flex;align-items:center;gap:15px;color:rgba(255,255,255,.8);}
.dt-bar .mright .clock{font-size:12.5px;font-variant-numeric:tabular-nums;}
.dt-bar .pwglyph{width:24px;height:24px;display:flex;align-items:center;justify-content:center;
  border-radius:6px;padding:2px;}
.dt-bar .pwglyph.lit{background:rgba(255,255,255,.16);}
.dt-bar .pwglyph img{width:21px;height:21px;display:block;}
.dt-stage{position:relative;padding:14px 18px 40px;display:flex;justify-content:flex-end;}
.hero-statement .dt-stage{justify-content:center;}
.dt-pop{transform-origin:top right;opacity:1;pointer-events:none;}
@media (prefers-reduced-motion:no-preference){
  .dt-pop{animation:popdrop .5s cubic-bezier(.22,1,.36,1) both;}
}
@keyframes popdrop{0%{transform:translateY(-10px) scale(.98)}100%{transform:none}}
.dt-connector{position:absolute;top:30px;width:2px;height:16px;background:rgba(255,255,255,.12);z-index:1;}

/* ---------- section scaffold ---------- */
.s-sec{padding:88px 0;position:relative;}
.s-sec.alt{background:linear-gradient(180deg,var(--s-bg),var(--s-bg2) 50%,var(--s-bg));}
.s-head{max-width:640px;margin:0 0 48px;}
.s-head h2{font-size:clamp(28px,3.4vw,42px);line-height:1.08;letter-spacing:-.02em;margin:16px 0 0;font-weight:680;text-wrap:balance;}
.s-head p{font-size:16.5px;color:var(--s-dim);line-height:1.6;margin:16px 0 0;}
.s-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.s-head.center .s-eyebrow{justify-content:center;}

/* features */
.feat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.feat{background:var(--s-panel);border:1px solid var(--s-line);border-radius:16px;padding:26px;
  position:relative;overflow:hidden;transition:border-color .18s,transform .18s;}
.feat:hover{border-color:var(--s-line2);transform:translateY(-2px);}
.feat .ficon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,rgba(84,204,133,.18),rgba(84,204,133,.04));
  border:1px solid rgba(84,204,133,.22);color:var(--s-accent);margin-bottom:18px;}
.feat h3{font-size:18px;font-weight:650;margin:0;letter-spacing:-.01em;}
.feat p{font-size:14.5px;color:var(--s-dim);line-height:1.6;margin:9px 0 0;}
.feat .spark{margin-top:16px;}
@media(max-width:760px){.feat-grid{grid-template-columns:1fr;}}

/* forwards */
.fwd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.fwd{background:var(--s-panel);border:1px solid var(--s-line);border-radius:14px;padding:22px;}
.fwd .tag{font-family:var(--s-mono);font-size:11px;font-weight:600;letter-spacing:.08em;
  color:var(--s-accent);text-transform:uppercase;}
.fwd h4{font-size:16.5px;margin:8px 0 0;font-weight:620;}
.fwd p{font-size:13.5px;color:var(--s-dim);line-height:1.55;margin:8px 0 16px;}
.fwd .cmd{font-family:var(--s-mono);font-size:11.5px;color:var(--s-dim);background:#0c0d10;
  border:1px solid var(--s-line);border-radius:9px;padding:11px 12px;line-height:1.5;overflow-x:auto;white-space:nowrap;}
.fwd .cmd .fl{color:var(--s-accent);}
.fwd .cmd .ar{color:var(--s-faint);}
@media(max-width:820px){.fwd-grid{grid-template-columns:1fr;}}

/* states showcase */
.states-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.state-card{background:var(--s-panel);border:1px solid var(--s-line);border-radius:16px;
  padding:24px;text-align:center;}
.state-bar{height:46px;border-radius:10px;background:linear-gradient(#26272b,#1b1c1f);
  border:1px solid rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;gap:0;
  margin-bottom:20px;}
.state-bar img{width:26px;height:26px;display:block;}
.state-card h4{font-size:16px;margin:0;font-weight:620;}
.state-card .k{font-family:var(--s-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  color:var(--s-faint);margin-bottom:8px;}
.state-card p{font-size:13.5px;color:var(--s-dim);line-height:1.55;margin:9px 0 0;}
@media(max-width:760px){.states-row{grid-template-columns:1fr;}}

/* trust / install */
.trust{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:center;}
.trust-badge{display:inline-flex;align-items:center;gap:10px;font-family:var(--s-mono);font-size:12px;
  letter-spacing:.06em;color:var(--s-accent);border:1px solid rgba(84,204,133,.25);
  background:rgba(84,204,133,.06);border-radius:999px;padding:7px 14px;}
.steps{display:flex;flex-direction:column;gap:2px;}
.step{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--s-line);}
.step:last-child{border-bottom:none;}
.step .n{flex:none;width:30px;height:30px;border-radius:9px;display:flex;align-items:center;justify-content:center;
  font-family:var(--s-mono);font-size:13px;font-weight:600;color:var(--s-accent);
  background:rgba(84,204,133,.1);border:1px solid rgba(84,204,133,.2);}
.step h4{margin:2px 0 0;font-size:15.5px;font-weight:620;}
.step p{margin:6px 0 0;font-size:13.5px;color:var(--s-dim);line-height:1.55;}
.step code{font-family:var(--s-mono);font-size:12.5px;color:var(--s-text);background:rgba(255,255,255,.06);
  padding:1px 6px;border-radius:5px;}
@media(max-width:820px){.trust{grid-template-columns:1fr;gap:28px;}}

/* download band */
.dl-band{text-align:center;background:
   radial-gradient(700px 320px at 50% 0%,rgba(30,158,87,.18),transparent 64%),var(--s-panel);
  border:1px solid var(--s-line2);border-radius:24px;padding:56px 32px;position:relative;overflow:hidden;}
.dl-band .bigicon{display:block;width:56px;height:56px;border-radius:14px;overflow:hidden;margin:0 auto 18px;
  box-shadow:0 12px 30px rgba(0,0,0,.5);}
.dl-band .bigicon img{width:100%;height:100%;display:block;}
.dl-band h2{font-size:clamp(28px,3.6vw,42px);letter-spacing:-.02em;margin:0;font-weight:700;}
.dl-band p{color:var(--s-dim);font-size:16px;margin:14px auto 0;max-width:30em;line-height:1.55;}
.dl-band .dl-cta{margin-top:30px;display:flex;flex-direction:column;align-items:center;gap:14px;}
.dl-band .req{font-family:var(--s-mono);font-size:12px;color:var(--s-faint);}
.dl-band .tip{font-size:13px;color:var(--s-dim);}
.dl-band .tip a{color:var(--s-accent);border-bottom:1px solid rgba(84,204,133,.3);}
.dl-toast{font-family:var(--s-mono);font-size:12.5px;color:var(--s-accent);
  background:rgba(84,204,133,.08);border:1px solid rgba(84,204,133,.25);border-radius:9px;
  padding:8px 14px;}
.dl-toast[hidden]{display:none;}

/* footer */
.s-foot{border-top:1px solid var(--s-line);padding:54px 0 40px;margin-top:20px;}
.foot-top{display:flex;gap:40px;justify-content:space-between;flex-wrap:wrap;}
.foot-cols{display:flex;gap:64px;flex-wrap:wrap;}
.foot-col h5{font-family:var(--s-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--s-faint);margin:0 0 14px;}
.foot-col a{display:block;font-size:13.5px;color:var(--s-dim);margin-bottom:10px;transition:color .15s;}
.foot-col a:hover{color:var(--s-text);}
.foot-sign{margin-top:44px;display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:18px;padding-top:26px;border-top:1px solid var(--s-line);}
.tricolore{display:inline-flex;height:13px;border-radius:2px;overflow:hidden;border:1px solid var(--s-line2);}
.tricolore i{width:8px;display:block;}
.tricolore .g{background:#1c9e5a;}.tricolore .w{background:#f4f5f7;}.tricolore .r{background:#d63b28;}
.foot-sign .sig{font-family:var(--s-mono);font-size:11px;letter-spacing:.12em;color:var(--s-dim);
  display:flex;align-items:center;gap:12px;}
.foot-sign .cop{font-family:var(--s-mono);font-size:11px;color:var(--s-faint);}

@media(max-width:880px){
  .hero-product{grid-template-columns:1fr;gap:36px;padding:44px 0 64px;}
  .hero-product .stage{order:2;}
}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;max-width:760px;margin:0 auto;}
.price-card{background:var(--s-panel);border:1px solid var(--s-line);border-radius:18px;padding:30px;position:relative;}
.price-card.hot{border-color:rgba(84,204,133,.42);box-shadow:0 0 0 1px rgba(84,204,133,.16),0 22px 54px rgba(0,0,0,.42);}
.price-card .badge{position:absolute;top:18px;right:18px;font-family:var(--s-mono);font-size:10.5px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--s-accent);border:1px solid rgba(84,204,133,.3);border-radius:999px;padding:4px 9px;}
.price-card .pname{font-family:var(--s-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--s-accent);}
.price-card .amt{display:flex;align-items:baseline;gap:7px;margin:14px 0 3px;}
.price-card .amt .num{font-size:46px;font-weight:700;letter-spacing:-.03em;color:var(--s-text);}
.price-card .amt .per{font-size:14px;color:var(--s-dim);}
.price-card .once{font-size:13.5px;color:var(--s-faint);}
.price-card ul{list-style:none;padding:0;margin:22px 0 26px;display:flex;flex-direction:column;gap:11px;}
.price-card li{display:flex;gap:10px;font-size:14px;color:var(--s-dim);align-items:flex-start;line-height:1.4;}
.price-card li svg{color:var(--s-accent);flex:none;margin-top:1px;}
.price-card .s-btn{width:100%;justify-content:center;}
.price-note{text-align:center;color:var(--s-dim);font-size:14.5px;margin-top:26px;}
.price-note a{color:var(--s-accent);border-bottom:1px solid rgba(84,204,133,.32);}
@media(max-width:720px){.price-grid{grid-template-columns:1fr;}}

/* faq */
.faq-list{max-width:760px;margin:0 auto;border-top:1px solid var(--s-line);}
.faq{border-bottom:1px solid var(--s-line);}
.faq summary{list-style:none;cursor:pointer;padding:22px 4px;display:flex;align-items:center;gap:16px;
  font-size:16.5px;font-weight:600;color:var(--s-text);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary .q{flex:1;text-wrap:balance;}
.faq summary .chev{transition:transform .2s;color:var(--s-faint);display:inline-flex;flex:none;}
.faq[open] summary .chev{transform:rotate(90deg);color:var(--s-accent);}
.faq .a{padding:0 4px 24px 40px;color:var(--s-dim);font-size:14.5px;line-height:1.65;max-width:62ch;}
.faq .a code{font-family:var(--s-mono);font-size:.9em;color:var(--s-text);background:rgba(255,255,255,.06);padding:1px 6px;border-radius:5px;}

/* ===========================================================================
   App component CSS (ported from the macOS app's ui.jsx) — for the
   non-interactive menu-bar popover mock in the hero.
   =========================================================================== */

/* warp toggle */
.pw-toggle{position:relative;width:40px;height:24px;border-radius:13px;border:none;
  background:var(--surface-3);padding:0;flex:none;box-shadow:inset 0 0 0 1px rgba(0,0,0,.06);}
.app-dark .pw-toggle{box-shadow:inset 0 0 0 1px rgba(255,255,255,.07);}
.pw-toggle.on{background:linear-gradient(180deg,var(--pipe-sheen),var(--pipe-green));box-shadow:inset 0 0 0 1px rgba(0,0,0,.10);}
.pw-toggle.amber{background:linear-gradient(180deg,#ffc04d,var(--st-amber));}
.pw-toggle.red{background:linear-gradient(180deg,#ff7a70,var(--st-red));}
.pw-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;
  background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.28),0 0 1px rgba(0,0,0,.2);}
.pw-toggle.on .pw-knob,.pw-toggle.amber .pw-knob,.pw-toggle.red .pw-knob{left:18px;}

/* status dot */
.pw-dot{position:relative;border-radius:50%;flex:none;}
.pw-dot.connected{background:var(--st-green);box-shadow:0 0 0 3px color-mix(in srgb,var(--st-green) 22%,transparent);}
.pw-dot.failed{background:var(--st-red);box-shadow:0 0 0 3px color-mix(in srgb,var(--st-red) 20%,transparent);}
.pw-dot.idle{background:var(--st-grey);box-shadow:none;opacity:.85;}
.pw-dot.connecting{background:var(--st-amber);}
.pw-dot.connecting::after{content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1.5px solid var(--st-amber);animation:amberPulse 1.3s ease-out infinite;}
@keyframes amberPulse{0%{transform:scale(.7);opacity:.9}100%{transform:scale(1.9);opacity:0}}

/* type chip */
.pw-chip{font-family:var(--mono);font-size:9.5px;font-weight:600;letter-spacing:.04em;
  padding:1.5px 5px;border-radius:5px;background:var(--chip-bg);color:var(--text-2);
  text-transform:uppercase;line-height:1.4;flex:none;}
.pw-chip.SOCKS{color:var(--pipe-green);background:color-mix(in srgb,var(--pipe-green) 14%,transparent);}
.app-dark .pw-chip.SOCKS{color:var(--pipe-sheen);}

/* popover button */
.pw-btn{font-family:var(--sf);font-size:13px;font-weight:500;border-radius:7px;padding:6px 13px;
  border:1px solid var(--field-line);background:var(--field);color:var(--text);
  display:inline-flex;align-items:center;gap:6px;}

/* sparkline flow */
.spk-line{stroke-dasharray:3 0;animation:spkflow 2.4s linear infinite;}
@keyframes spkflow{to{stroke-dashoffset:-24;}}

/* ---------- popover (menu-bar) ---------- */
.pw-pop{width:350px;border-radius:13px;overflow:hidden;position:relative;
  background:var(--pop-bg);backdrop-filter:blur(30px) saturate(1.7);-webkit-backdrop-filter:blur(30px) saturate(1.7);
  border:1px solid var(--pop-border);box-shadow:var(--shadow-pop);}
.pw-pop-head{display:flex;align-items:center;gap:9px;padding:11px 12px 10px;border-bottom:1px solid var(--sep);}
.pw-pop-head .ic{width:22px;height:22px;border-radius:6px;overflow:hidden;flex:none;
  display:flex;align-items:center;justify-content:center;}
.pw-pop-head .ic img{width:100%;height:100%;display:block;}
.pw-pop-head .title{flex:1;min-width:0;font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em;}
.pw-pop-head .count{font-size:11px;color:var(--text-3);font-weight:500;margin-right:2px;}
.pw-pop-body{max-height:340px;overflow-y:auto;padding:6px;}
.pw-row{position:relative;display:flex;align-items:center;gap:11px;padding:9px 12px;
  border-bottom:1px solid var(--sep);}
.pw-row:last-child{border-bottom:none;}
.pw-row .dotcol{width:11px;display:flex;justify-content:center;flex:none;}
.pw-row .main{flex:1;min-width:0;}
.pw-row .name-line{display:flex;align-items:center;gap:7px;margin-bottom:2px;}
.pw-row .name{font-size:13.5px;font-weight:600;color:var(--text);white-space:nowrap;
  overflow:hidden;text-overflow:ellipsis;}
.pw-route{display:flex;align-items:center;gap:5px;font-family:var(--mono);font-size:11px;color:var(--text-2);min-width:0;}
.pw-route .arr{color:var(--text-3);display:inline-flex;flex:none;}
.pw-route .to{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.pw-route .to.socks{color:var(--accent);}
.pw-fail{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--st-red);font-family:var(--mono);}
.pw-stat{display:flex;flex-direction:column;align-items:flex-end;gap:2px;flex:none;}
.pw-stat .up{font-family:var(--mono);font-size:10px;color:var(--text-3);}
.pw-connecting{font-size:11px;color:var(--st-amber);font-weight:500;flex:none;}
.pw-foot{display:flex;align-items:center;gap:8px;padding:8px 10px;border-top:1px solid var(--sep);
  background:color-mix(in srgb,var(--surface) 30%,transparent);}
.pw-foot .new{flex:1;justify-content:center;font-weight:600;background:transparent;border:1px dashed var(--field-line);}
.pw-foot .ico-btn{background:transparent;border:none;color:var(--text-2);padding:6px 9px;}
