/* =============================================================================
 * Centronic Core - shared site styles
 * Served as a static asset from /assets/styles.css and linked by every page
 * rendered by the Worker. No external fonts/CDNs.
 * ========================================================================== */

:root{
  --bg:#070b16;
  --bg-2:#0a1020;
  --panel:rgba(17,24,43,0.55);
  --panel-2:rgba(22,31,54,0.5);
  --border:rgba(120,150,210,0.16);
  --border-strong:rgba(130,170,255,0.3);
  --text:#e8edf7;
  --muted:#9aa7c4;
  --faint:#6b7894;
  --cyan:#22d3ee;
  --blue:#3b82f6;
  --violet:#8b5cf6;
  --green:#34d399;
  --amber:#fbbf24;
  --shadow:0 24px 60px -28px rgba(0,0,0,0.85);
  --r:18px;
  --r-sm:12px;
  --sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono","SFMono-Regular",Menlo,Consolas,"Liberation Mono",monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--bg)}
body{
  margin:0;font-family:var(--sans);background:transparent;color:var(--text);
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
  min-height:100vh;display:flex;flex-direction:column;
}
main{flex:1 0 auto}
.wrap{width:100%;max-width:1180px;margin:0 auto;padding:0 24px}
a{color:inherit;text-decoration:none}
h1,h2,h3{margin:0;line-height:1.12;letter-spacing:-0.02em}
p{margin:0}
img{display:block;max-width:100%}

/* Background atmosphere ---------------------------------------------------- */
.bg{position:fixed;inset:0;z-index:-1;overflow:hidden;background:
  radial-gradient(1200px 600px at 80% -10%, rgba(59,130,246,0.10), transparent 60%),
  radial-gradient(900px 500px at 10% 0%, rgba(139,92,246,0.10), transparent 55%),
  linear-gradient(180deg,var(--bg),var(--bg-2));}
.bg-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;opacity:0;transition:opacity 1.2s ease}
.bg-canvas.live{opacity:1}
.bg-nebula{mix-blend-mode:screen}
.bg-nebula.live{opacity:0.9}
.bg-glow{position:absolute;border-radius:50%;filter:blur(130px);opacity:0.45;animation:float 24s ease-in-out infinite}
.bg-glow--cyan{width:520px;height:520px;background:rgba(34,211,238,0.16);top:-120px;right:-80px}
.bg-glow--violet{width:560px;height:560px;background:rgba(139,92,246,0.16);bottom:-180px;left:-120px;animation-delay:-8s}
.bg-glow--blue{width:480px;height:480px;background:rgba(59,130,246,0.12);top:40%;left:55%;animation-delay:-16s}
@keyframes float{0%,100%{transform:translate(0,0)}33%{transform:translate(40px,-30px)}66%{transform:translate(-30px,25px)}}
.bg-scan{position:absolute;inset:0;pointer-events:none;
  background:repeating-linear-gradient(0deg,rgba(255,255,255,0.012) 0,rgba(255,255,255,0.012) 1px,transparent 1px,transparent 3px)}
.bg-grain{position:absolute;inset:0;pointer-events:none;opacity:0.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.bg-vignette{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 100% at 50% 0%,transparent 55%,rgba(4,7,15,0.55) 100%)}

/* Topbar ------------------------------------------------------------------- */
.topbar{position:sticky;top:0;z-index:50;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  background:rgba(8,12,22,0.72);border-bottom:1px solid var(--border);
  padding-top:env(safe-area-inset-top,0px)}
.topbar-inner{display:flex;align-items:center;gap:20px;height:66px}
.brand{display:flex;align-items:center;gap:12px;margin-right:auto}
.brand-logo{height:34px;width:auto;filter:drop-shadow(0 0 10px rgba(56,198,232,0.25))}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-co{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted)}
.brand-co--solo{font-size:15px;font-weight:700;letter-spacing:-0.01em;text-transform:none;color:var(--text)}
.topnav{display:flex;gap:24px;font-size:14px;color:var(--muted)}
.topnav a{position:relative;transition:color .2s;padding:4px 0}
.topnav a:hover,.topnav a.active{color:var(--text)}
.topnav a::after{content:"";position:absolute;left:0;bottom:-4px;height:2px;width:0;
  background:linear-gradient(90deg,var(--cyan),var(--violet));transition:width .25s}
.topnav a:hover::after,.topnav a.active::after{width:100%}

/* Buttons ------------------------------------------------------------------ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--sans);font-size:15px;font-weight:600;cursor:pointer;
  padding:13px 22px;border-radius:12px;border:1px solid transparent;
  transition:transform .15s,box-shadow .2s,background .2s,border-color .2s;white-space:nowrap}
.btn svg{width:17px;height:17px}
.btn:active{transform:translateY(1px)}
.btn-sm{padding:9px 16px;font-size:13.5px;border-radius:10px}
.btn-primary{color:#04111e;background:linear-gradient(135deg,var(--cyan) 0%,var(--blue) 65%,var(--violet) 130%);
  box-shadow:0 12px 30px -12px rgba(34,150,238,0.7),inset 0 1px 0 rgba(255,255,255,0.3)}
.btn-primary:hover{box-shadow:0 16px 38px -10px rgba(34,150,238,0.85);transform:translateY(-2px)}
.btn-ghost{color:var(--text);background:rgba(255,255,255,0.04);border-color:var(--border-strong)}
.btn-ghost:hover{background:rgba(255,255,255,0.08);border-color:rgba(150,190,255,0.5)}

/* Hero --------------------------------------------------------------------- */
.hero{padding:80px 0 40px;position:relative;overflow:visible}
.hero-inner{max-width:880px;position:relative;z-index:1;min-width:0}
.status-aside{padding:14px 16px 12px;align-self:start;max-width:360px}
.status-aside-head{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.status-aside .kicker{margin-bottom:0;font-size:10px;letter-spacing:0.18em;opacity:0.85}
.status-aside .checked{font-size:10px;line-height:1.3;text-align:right;max-width:11em}
.status-list--compact .status-row{padding:7px 6px;gap:8px;border-radius:8px}
.status-list--compact .status-row + .status-row{border-top-color:rgba(120,150,210,0.06)}
.status-list--compact .status-label{font-size:12.5px;font-weight:500;color:var(--muted)}
.status-list--compact .status-dot{width:7px;height:7px}
.status-list--compact .badge{font-size:10px;padding:3px 8px}
.pill{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;
  letter-spacing:0.04em;color:#bfe9f5;padding:7px 14px;border-radius:999px;
  background:rgba(34,211,238,0.08);border:1px solid rgba(34,211,238,0.3)}
.pill-dot{width:8px;height:8px;border-radius:50%;background:var(--cyan);box-shadow:0 0 0 0 rgba(34,211,238,0.6);
  animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,211,238,0.55)}70%{box-shadow:0 0 0 9px rgba(34,211,238,0)}100%{box-shadow:0 0 0 0 rgba(34,211,238,0)}}
.eyebrow{margin-top:24px;font-family:var(--mono);font-size:13px;letter-spacing:0.22em;text-transform:uppercase;color:var(--faint)}
.hero-title{margin-top:10px;font-size:clamp(42px,8.5vw,92px);font-weight:800;letter-spacing:-0.04em;line-height:1.08;padding-bottom:0.06em}
.grad{display:inline-block;padding-right:0.14em;padding-bottom:0.05em;
  background:linear-gradient(110deg,var(--cyan),var(--blue) 35%,var(--violet) 60%,#e8edf7 78%,var(--cyan) 100%);
  background-size:280% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:sheen 7s ease-in-out infinite}
.home-app-icons{display:grid;grid-template-columns:repeat(auto-fill,minmax(108px,1fr));gap:12px 14px;
  max-width:720px;margin-top:28px}
.home-app{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px 10px 10px;border-radius:14px;
  background:rgba(22,31,54,0.35);border:1px solid var(--border);transition:transform .15s,border-color .2s,box-shadow .2s,background .2s}
.home-app:hover{transform:translateY(-2px);border-color:var(--border-strong);background:rgba(22,31,54,0.48);
  box-shadow:0 12px 28px -16px rgba(34,150,238,0.45)}
.home-app__icon{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:12px;
  background:rgba(8,12,22,0.35)}
.home-app__icon img{width:36px;height:36px;border-radius:10px;object-fit:cover}
.home-app__name{font-size:12px;font-weight:600;line-height:1.25;text-align:center;color:var(--muted);letter-spacing:-0.01em}
.home-app:hover .home-app__name{color:var(--text)}
@keyframes sheen{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-headline{margin-top:18px;font-size:clamp(20px,2.6vw,27px);font-weight:600;color:var(--text);max-width:760px;letter-spacing:-0.01em}
.hero-desc{margin-top:18px;font-size:16.5px;color:var(--muted);max-width:720px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.restricted{display:flex;gap:12px;align-items:flex-start;margin-top:32px;padding:14px 18px;
  border-radius:var(--r-sm);background:rgba(251,191,36,0.06);border:1px solid rgba(251,191,36,0.25);
  font-size:14px;color:#f3e3bf;max-width:660px}
.restricted svg{width:20px;height:20px;color:var(--amber);flex:none;margin-top:1px}
.restricted strong{color:#fbe9bd}

/* Sections ----------------------------------------------------------------- */
.section{padding:44px 0}
.section--tight{padding:20px 0 44px}
.section-head{max-width:680px;margin-bottom:28px}
.section-head--tight{margin-bottom:0}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.kicker{font-family:var(--mono);font-size:12px;letter-spacing:0.22em;text-transform:uppercase;color:var(--cyan);margin-bottom:10px}
.section-title{font-size:clamp(26px,4vw,38px);font-weight:700}
.section-sub{margin-top:14px;color:var(--muted);font-size:16px}

/* Panels & badges ---------------------------------------------------------- */
.panel{position:relative;border-radius:var(--r);padding:26px;background:var(--panel);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow)}
.panel--glass{background:rgba(12,18,32,0.22);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-color:rgba(120,150,210,0.12);box-shadow:0 18px 50px -28px rgba(0,0,0,0.55)}
.panel--glass .status-row:hover{background:rgba(255,255,255,0.04)}
.panel-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.panel-title{font-size:22px;font-weight:700}
.checked{font-family:var(--mono);font-size:12.5px;color:var(--faint)}
.badge{font-family:var(--mono);font-size:11.5px;font-weight:600;letter-spacing:0.04em;
  padding:5px 11px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.badge--online{color:#7ff0c4;background:rgba(52,211,153,0.1);border-color:rgba(52,211,153,0.3)}
.badge--connected{color:#9fecf7;background:rgba(34,211,238,0.1);border-color:rgba(34,211,238,0.3)}
.badge--active{color:#aecbff;background:rgba(59,130,246,0.12);border-color:rgba(59,130,246,0.32)}
.badge--planned{color:var(--muted);background:rgba(154,167,196,0.08);border-color:rgba(154,167,196,0.25)}
.badge--pending{color:#fbe09a;background:rgba(251,191,36,0.1);border-color:rgba(251,191,36,0.32)}
.badge--future{color:#cbb8ff;background:rgba(139,92,246,0.12);border-color:rgba(139,92,246,0.32)}
.badge--module{color:#bcd2ff;background:rgba(99,140,230,0.1);border-color:rgba(99,140,230,0.3)}

/* Status list -------------------------------------------------------------- */
.status-list{list-style:none;margin:0;padding:0;display:grid;gap:2px}
.status-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;padding:13px 12px;border-radius:11px;transition:background .2s}
.status-row:hover{background:rgba(255,255,255,0.03)}
.status-row + .status-row{border-top:1px solid rgba(120,150,210,0.08)}
.status-dot{width:9px;height:9px;border-radius:50%;flex:none}
.status-dot--online{background:var(--green);box-shadow:0 0 10px rgba(52,211,153,0.7)}
.status-dot--connected{background:var(--cyan);box-shadow:0 0 10px rgba(34,211,238,0.7)}
.status-dot--active{background:var(--blue);box-shadow:0 0 10px rgba(59,130,246,0.7)}
.status-dot--planned{background:var(--faint)}
.status-dot--pending{background:var(--amber);box-shadow:0 0 10px rgba(251,191,36,0.6)}
.status-dot--future{background:var(--violet);box-shadow:0 0 10px rgba(139,92,246,0.7)}
.status-label{font-size:15px;font-weight:500}

/* App grid (home + /apps) -------------------------------------------------- */
.app-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));
  gap:14px;
  align-items:start;
}
.app-card{
  position:relative;display:flex;flex-direction:column;gap:11px;
  padding:16px;border-radius:var(--r-sm);
  background:var(--panel-2);border:1px solid var(--border);overflow:hidden;
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  transition:transform .25s,border-color .25s,box-shadow .25s;
  animation:rise .6s both;animation-delay:var(--delay);
}
.app-card:hover{transform:translateY(-3px);border-color:var(--border-strong);box-shadow:0 20px 40px -24px rgba(0,0,0,0.8)}
.app-card__glow{position:absolute;top:-40%;right:-30%;width:200px;height:200px;border-radius:50%;
  background:radial-gradient(circle,var(--accent-glow,rgba(34,211,238,0.18)),transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}
.app-card:hover .app-card__glow{opacity:1}
.app-card > :not(.app-card__glow){position:relative;z-index:2}
.app-top{display:flex;align-items:center;gap:12px}
.app-icon{width:44px;height:44px;border-radius:11px;flex:none;object-fit:cover;
  border:1px solid var(--border);background:#05080f;box-shadow:0 6px 16px -10px rgba(0,0,0,0.8)}
.app-titles{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.app-name{font-size:16px;font-weight:700;line-height:1.15}
.app-titles .badge{align-self:flex-start;font-size:10px;padding:2px 8px}
.app-desc{
  font-size:13px;line-height:1.4;color:var(--muted);margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.app-foot{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding-top:11px;border-top:1px solid rgba(120,150,210,0.12);
}
.app-open{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:600;color:var(--cyan)}
.app-open svg{width:15px;height:15px;transition:transform .2s}
.app-card:hover .app-open svg{transform:translateX(3px)}
.app-foot .op-soon{font-size:8.5px;padding:2px 7px}

/* App detail page ---------------------------------------------------------- */
.app-hero{padding:54px 0 18px;position:relative}
.app-hero--compact{padding:36px 0 8px}
.crumbs{display:flex;align-items:center;gap:8px;font-size:13.5px;color:var(--faint);margin-bottom:22px}
.crumbs a:hover{color:var(--text)}
.crumbs svg{width:14px;height:14px}
.app-hero-top{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.app-hero-icon{width:96px;height:96px;border-radius:22px;flex:none;object-fit:cover;
  border:1px solid var(--border-strong);background:#05080f;box-shadow:0 20px 44px -18px rgba(0,0,0,0.85)}
.app-hero-text h1{font-size:clamp(30px,5vw,46px);font-weight:800;letter-spacing:-0.03em}
.app-hero-text .app-tagline{margin-top:8px;font-size:17px;color:var(--muted);max-width:620px}
.app-hero-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.app-longdesc{margin-top:24px;max-width:760px;color:var(--muted);font-size:16px}

/* Operation buttons (web client - coming soon) ----------------------------- */
.ops-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,250px),1fr));gap:12px;align-items:start}
.op-btn{position:relative;display:flex;align-items:center;gap:13px;text-align:left;width:100%;
  padding:14px 16px;border-radius:var(--r-sm);background:var(--panel-2);border:1px solid var(--border);
  color:var(--text);font-family:var(--sans);cursor:not-allowed;
  transition:transform .2s,border-color .2s,background .2s}
.op-btn:hover{transform:translateY(-3px);border-color:var(--border-strong);background:rgba(255,255,255,0.04)}
.op-btn__icon{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;flex:none;
  color:var(--accent,var(--cyan));background:color-mix(in srgb,var(--accent,var(--cyan)) 12%,transparent);
  border:1px solid color-mix(in srgb,var(--accent,var(--cyan)) 30%,transparent)}
.op-btn__icon svg{width:20px;height:20px}
.op-btn__body{display:flex;flex-direction:column;gap:3px;min-width:0}
.op-btn__name{font-size:15px;font-weight:600;display:flex;align-items:center;gap:8px}
.op-btn__desc{font-size:13px;color:var(--faint)}
.op-soon{font-family:var(--mono);font-size:9px;letter-spacing:0.1em;text-transform:uppercase;
  color:var(--faint);padding:3px 7px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,0.02)}
.op-lock{position:absolute;top:50%;right:14px;transform:translateY(-50%);width:14px;height:14px;color:var(--faint);opacity:0.7}
.op-btn__body{padding-right:18px}

/* Info tiles --------------------------------------------------------------- */
.tile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr));gap:14px}
.tile{padding:18px 20px;border-radius:var(--r-sm);background:var(--panel-2);border:1px solid var(--border)}
.tile h3{font-size:15px;font-weight:700;margin-bottom:6px}
.tile p{font-size:13.5px;color:var(--muted)}
.tile .tile-key{font-family:var(--mono);font-size:11px;color:var(--cyan);letter-spacing:0.06em}

.repo-list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:8px}
.repo-chip{font-family:var(--mono);font-size:12px;color:var(--muted);padding:6px 11px;border-radius:8px;
  background:rgba(255,255,255,0.03);border:1px solid var(--border)}
.repo-chip.merge{color:#9fecf7;border-color:rgba(34,211,238,0.3);background:rgba(34,211,238,0.06)}

/* Footer ------------------------------------------------------------------- */
.footer{margin-top:36px;flex-shrink:0;border-top:1px solid var(--border);background:rgba(8,12,22,0.55);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.footer-inner{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:12px 24px}
.footer-brand{display:flex;align-items:center;gap:10px}
.footer-brand img{height:22px;width:auto}
.footer-brand div{display:flex;flex-direction:column;line-height:1.2}
.footer-brand strong{font-size:13px;font-weight:700}
.footer-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px 14px;
  font-size:11.5px;color:var(--faint);font-family:var(--mono)}
.dev-credit{display:inline-flex;align-items:center;gap:7px;padding:5px 11px 5px 9px;font-size:11px;letter-spacing:0.06em;
  text-transform:lowercase;color:var(--faint);text-decoration:none;border-radius:999px;
  border:1px solid rgba(255,255,255,0.06);background:rgba(255,255,255,0.02);
  transition:color .2s,border-color .2s,box-shadow .25s,transform .15s,background .2s}
.dev-credit__dot{width:6px;height:6px;border-radius:50%;flex:none;
  background:linear-gradient(135deg,var(--cyan),var(--violet));opacity:0.75;
  box-shadow:0 0 10px rgba(34,211,238,0.45);transition:opacity .2s,box-shadow .25s}
.dev-credit__text{background:linear-gradient(120deg,var(--muted),var(--faint));
  -webkit-background-clip:text;background-clip:text;color:transparent;transition:background .25s}
.dev-credit:hover{color:var(--muted);border-color:rgba(150,190,255,0.35);background:rgba(255,255,255,0.05);
  box-shadow:0 0 22px -10px rgba(34,211,238,0.55);transform:translateY(-1px)}
.dev-credit:hover .dev-credit__dot{opacity:1;box-shadow:0 0 14px rgba(139,92,246,0.55)}
.dev-credit:hover .dev-credit__text{background:linear-gradient(120deg,var(--cyan),var(--blue),var(--violet));
  -webkit-background-clip:text;background-clip:text}

/* 404 ---------------------------------------------------------------------- */
.nf{min-height:80vh;display:grid;place-items:center;text-align:center}
.nf-inner{max-width:560px;display:flex;flex-direction:column;align-items:center;gap:6px;padding:40px 0}
.nf-logo{height:60px;width:auto;margin-bottom:14px;filter:drop-shadow(0 0 16px rgba(56,198,232,0.35))}
.nf-code{font-size:clamp(90px,22vw,170px);font-weight:800;letter-spacing:-0.05em;line-height:1;margin-top:10px;
  background:linear-gradient(120deg,var(--cyan),var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.nf-title{font-size:22px;font-weight:700;margin-top:8px}
.nf-desc{color:var(--muted);margin-top:10px}
.nf .btn{margin-top:26px}

/* Toast -------------------------------------------------------------------- */
.toast{position:fixed;left:50%;bottom:30px;transform:translate(-50%,24px);z-index:100;
  font-size:14px;font-weight:500;color:var(--text);padding:13px 20px;border-radius:12px;
  background:rgba(17,24,43,0.92);border:1px solid var(--border-strong);box-shadow:var(--shadow);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;max-width:90vw}
.toast.show{opacity:1;transform:translate(-50%,0)}

/* Auth --------------------------------------------------------------------- */
.auth-slot{display:flex;align-items:center;gap:12px;flex-shrink:0}
.auth-slot--signed-in{gap:8px}
.auth-who{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12.5px;color:var(--muted);max-width:230px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.auth-email{overflow:hidden;text-overflow:ellipsis}
.auth-signout svg{width:17px;height:17px}
.auth-signout-label{white-space:nowrap}
.auth-pip{width:8px;height:8px;border-radius:50%;flex:none}
.auth-pip--ok{background:var(--green);box-shadow:0 0 8px rgba(52,211,153,0.7)}
.auth-pip--wait{background:var(--amber);box-shadow:0 0 8px rgba(251,191,36,0.6)}
.auth-wrap{max-width:520px;margin:0 auto;padding:40px 0}
.auth-card{padding:34px 30px}
.auth-title{margin-top:14px;font-size:clamp(24px,4vw,32px)}
.auth-sub{margin-top:12px;color:var(--muted);font-size:15px;line-height:1.55}
.auth-form{display:flex;flex-direction:column;gap:16px;margin-top:24px}
.auth-label{display:flex;flex-direction:column;gap:7px;font-size:13px;font-weight:600;color:var(--text);letter-spacing:0.01em}
.auth-input{font-size:15px;color:var(--text);background:rgba(255,255,255,0.04);border:1px solid var(--border-strong);
  border-radius:11px;padding:12px 14px;outline:none;transition:border-color .2s,box-shadow .2s;font-family:inherit}
.auth-input:focus{border-color:rgba(150,190,255,0.6);box-shadow:0 0 0 3px rgba(59,130,246,0.18)}
.auth-submit{margin-top:4px;justify-content:center}
.auth-msg{min-height:18px;font-size:13.5px;color:#fbe09a;margin:2px 0 0}
.auth-toggle{margin-top:18px;font-size:13.5px;color:var(--muted)}
.auth-toggle a{color:#9fd8ff}
.auth-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.pill--wait{background:rgba(251,191,36,0.08);border-color:rgba(251,191,36,0.32)}
.pill--wait .pill-dot{background:var(--amber);box-shadow:0 0 0 0 rgba(251,191,36,0.55)}
body[data-requires-approval] main,
body[data-requires-approval] .et-root{opacity:0;transition:opacity .25s ease}
body[data-requires-approval].auth-ready main,
body[data-requires-approval].auth-ready .et-root{opacity:1}

/* Dashboard ---------------------------------------------------------------- */
.dash-page{padding-top:28px;padding-bottom:48px}
.dash-loading{padding:28px 26px;margin-bottom:18px}
.dash-hero{margin-bottom:22px}
.dash-title{font-size:clamp(28px,4.5vw,40px);font-weight:800;margin-top:8px}
.dash-sub{margin-top:10px;color:var(--muted);font-size:15px;line-height:1.55}
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:22px}
.dash-stat{padding:16px 18px;border-radius:var(--r-sm);background:var(--panel-2);border:1px solid var(--border)}
.dash-stat__label{display:block;font-size:11px;font-family:var(--mono);letter-spacing:0.08em;text-transform:uppercase;color:var(--faint)}
.dash-stat__value{display:block;margin-top:8px;font-size:clamp(22px,3vw,28px);font-weight:800;letter-spacing:-0.03em;line-height:1.1}
.dash-stat__hint{display:block;margin-top:6px;font-size:12px;color:var(--muted)}
.dash-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dash-grid--wide .dash-panel:first-child{grid-column:1/-1}
.dash-panel{padding:22px 22px 20px}
.dash-panel__title{font-size:18px;margin-top:6px;margin-bottom:14px}
.dash-panel__body{min-height:40px}
.dash-empty,.dash-note{color:var(--muted);font-size:14px;line-height:1.55}
.dash-soon{margin:10px 0 0;padding-left:18px;color:var(--muted);font-size:14px}
.dash-soon li{margin:4px 0}
.dash-bars{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.dash-bar{display:grid;grid-template-columns:minmax(80px,34%) 1fr auto;align-items:center;gap:10px;font-size:13px}
.dash-bar__label{color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-bar__track{height:8px;border-radius:999px;background:rgba(255,255,255,0.06);overflow:hidden}
.dash-bar__fill{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--blue))}
.dash-bar__count{font-family:var(--mono);font-size:12px;color:var(--muted);min-width:1.5em;text-align:right}
.dash-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.dash-table{width:100%;border-collapse:collapse;font-size:13px}
.dash-table th,.dash-table td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.dash-table th{font-family:var(--mono);font-size:11px;letter-spacing:0.06em;text-transform:uppercase;color:var(--faint);font-weight:600}
.dash-table tbody tr:last-child td{border-bottom:none}

/* Animations --------------------------------------------------------------- */
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

@media (max-width:760px){
  .wrap{padding-left:max(24px,env(safe-area-inset-left,0px));padding-right:max(24px,env(safe-area-inset-right,0px))}
  .topbar-inner{flex-wrap:wrap;height:auto;gap:8px 12px;padding:10px 0;align-items:center}
  .brand{order:1;min-width:0;margin-right:0;flex:1 1 auto;padding-left:6px}
  .brand-text{display:none}
  .brand-logo{height:30px}
  .auth-slot{order:2;margin-left:auto}
  .auth-slot--signed-in{gap:6px}
  .topnav{order:3;width:100%;gap:18px;font-size:13.5px;padding-top:8px;padding-left:4px;border-top:1px solid var(--border)}
  .auth-who{max-width:none}
  .auth-email{display:none}
  .auth-signout{padding:8px 10px;min-width:38px;justify-content:center}
  .auth-signout-label{display:none}
  .dash-grid{grid-template-columns:1fr}
  .dash-bar{grid-template-columns:1fr auto;grid-template-rows:auto auto}
  .dash-bar__track{grid-column:1/-1}
  .hero{padding:44px 0 26px}
  .status-aside{max-width:100%}
  .footer-inner{padding:12px 18px}
  .footer-meta{justify-content:flex-start}
  .app-hero-icon{width:76px;height:76px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .bg-canvas{display:none}
}
