/* ============ Gilbert HQ — shared design system (Bento) ============ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500&display=swap');

:root{
  --bg:#06070a; --ink:#f4f6fb; --muted:#9aa3b5; --faint:#5c6477;
  --surface:#0e1016; --surface-2:#14171f; --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.16);
  --indigo:#6366f1; --violet:#8b5cf6; --teal:#34e3b0; --amber:#f9a826; --pink:#f472b6; --rose:#f2555a;
  --radius:22px; --radius-sm:14px; --pill:999px;
  --spring:cubic-bezier(.2,1.3,.32,1); --ease:cubic-bezier(.4,0,.2,1);
  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --shadow:0 1px 2px rgba(0,0,0,.5),0 18px 48px -16px rgba(0,0,0,.6);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);background:var(--bg);color:var(--ink);min-height:100vh;
  line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative;
  padding-bottom:130px;
}
body::before,body::after{content:"";position:fixed;z-index:-1;border-radius:50%;filter:blur(40px);pointer-events:none}
body::before{width:520px;height:520px;top:-180px;left:-140px;background:radial-gradient(circle,rgba(99,102,241,.22),transparent 70%)}
body::after{width:560px;height:560px;bottom:-220px;right:-160px;background:radial-gradient(circle,rgba(20,184,166,.15),transparent 70%)}
a{color:inherit;text-decoration:none}

/* ---------- slim top header ---------- */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:20px clamp(16px,5vw,36px) 6px;max-width:980px;margin:0 auto}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;font-size:16px}
.brand .mark{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;
  background:#1a1f2b url('https://gilberthq.com/avatar.webp') center 20% / cover;
  color:transparent;font-size:0;border:1px solid var(--line-2);flex-shrink:0}
.status{display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);font-family:var(--mono)}
.statusdot{width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 0 rgba(52,227,176,.7);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(52,227,176,.5)}70%{box-shadow:0 0 0 7px rgba(52,227,176,0)}100%{box-shadow:0 0 0 0 rgba(52,227,176,0)}}

.wrap{max-width:980px;margin:0 auto;padding:8px clamp(16px,5vw,36px) 40px}
.pagetitle{font-size:clamp(26px,5vw,40px);font-weight:800;letter-spacing:-.03em;margin:18px 0 6px;
  opacity:0;animation:rise .7s var(--ease) .05s forwards}
.pagesub{color:var(--muted);font-size:15px;margin-bottom:22px;opacity:0;animation:rise .7s var(--ease) .12s forwards}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}

/* ---------- minimal home hint ---------- */
.home-hint{margin-top:40px;display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;
  color:var(--muted);opacity:0;animation:rise .8s var(--ease) .2s forwards}
.home-hint .big{font-size:clamp(28px,7vw,46px);font-weight:800;letter-spacing:-.03em;color:var(--ink);line-height:1.1}
.home-hint .arrow-down{font-size:22px;color:var(--indigo);animation:bob 1.8s var(--ease) infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(6px)}}

/* ---------- generic tool-page content ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  opacity:0;animation:rise .6s var(--ease) .2s forwards}
.tabs{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 18px}
.tab{padding:9px 16px;border-radius:var(--pill);border:1px solid var(--line);background:var(--surface);
  font-size:14px;font-weight:600;color:var(--muted);cursor:pointer;transition:.2s var(--ease)}
.tab.active{color:#fff;border-color:transparent;background:linear-gradient(135deg,var(--indigo),var(--violet))}
label{display:block;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:14px 0 6px}
input,textarea{width:100%;background:#0a0c12;border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--ink);padding:12px 14px;font-size:15px;font-family:inherit;resize:vertical}
input:focus,textarea:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px rgba(99,102,241,.25)}
.btn{margin-top:16px;width:100%;border:none;border-radius:var(--radius-sm);padding:14px;font-size:16px;font-weight:700;
  cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--indigo),var(--violet));transition:.2s var(--ease)}
.btn:hover{filter:brightness(1.08);transform:translateY(-1px)}
.verdict{margin-top:18px;border-radius:var(--radius-sm);padding:16px 18px;border-left:3px solid var(--teal);
  background:rgba(52,227,176,.08);font-size:14.5px;line-height:1.6}
.pcard{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px;margin-bottom:12px;transition:.2s var(--ease)}
.pcard:hover{border-color:var(--line-2);transform:translateY(-2px)}
.pcard h4{font-size:15px;font-weight:700;margin-bottom:6px}
.pcard p{font-size:13.5px;color:var(--muted);font-family:var(--mono)}

/* ---------- home widgets (tappable, deep-link into each tool) ---------- */
.widgets{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;grid-auto-rows:minmax(118px,auto);margin-top:8px}
.widget{position:relative;overflow:hidden;border-radius:var(--radius);padding:20px;border:1px solid var(--line);
  background:var(--surface);box-shadow:var(--shadow);display:flex;flex-direction:column;color:inherit;
  opacity:0;transform:translateY(22px) scale(.98);animation:tilein .6s var(--spring) forwards;
  transition:transform .3s var(--spring),border-color .25s var(--ease),box-shadow .3s var(--ease)}
.widget:nth-child(1){animation-delay:.05s}.widget:nth-child(2){animation-delay:.11s}
.widget:nth-child(3){animation-delay:.17s}.widget:nth-child(4){animation-delay:.23s}
.widget:nth-child(5){animation-delay:.29s}.widget:nth-child(6){animation-delay:.35s}
@keyframes tilein{to{opacity:1;transform:translateY(0) scale(1)}}
.widget.link:hover{transform:translateY(-5px) scale(1.012);border-color:var(--line-2);
  box-shadow:var(--shadow),0 24px 60px -18px rgba(99,102,241,.4)}
.widget.link:active{transform:translateY(-1px) scale(.99)}
.widget.link::after{content:"";position:absolute;top:0;left:-60%;width:50%;height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.14),transparent);
  transform:skewX(-18deg);transition:left .7s var(--ease);pointer-events:none}
.widget.link:hover::after{left:130%}
.col2{grid-column:span 2}.row2{grid-row:span 2}
.w-indigo{background:linear-gradient(155deg,#1c1b3a,#0c0a18)}
.w-teal{background:linear-gradient(155deg,#08222e,#0a1018)}
.w-amber{background:linear-gradient(155deg,#231507,#120c14)}
.w-green{background:linear-gradient(155deg,#08220f,#0a1410)}
.w-pink{background:linear-gradient(155deg,#240a1a,#100a14)}
.w-violet{background:linear-gradient(155deg,#1a0a24,#0e0a18)}
.widget .ic{display:grid;place-items:center;width:44px;height:44px;border-radius:13px;font-size:22px;
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1)}
.widget .w-head{display:flex;align-items:center;justify-content:space-between}
.widget .go{color:var(--faint);font-size:17px;transition:transform .22s var(--ease),color .22s var(--ease)}
.widget.link:hover .go{transform:translateX(4px);color:var(--indigo)}
.widget h3{font-size:17px;font-weight:700;letter-spacing:-.01em;margin-top:auto;padding-top:12px}
.widget .stat{margin-top:6px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.widget .stat .num{font-size:clamp(20px,3vw,26px);font-weight:800;letter-spacing:-.02em}
.widget .stat .num.up{color:var(--teal)}.widget .stat .num.down{color:var(--rose)}
.widget .stat .lbl{font-size:12.5px;color:var(--muted)}
.widget .sub{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.45}
.widget .badge{position:absolute;top:16px;right:16px;font-size:10.5px;font-family:var(--mono);letter-spacing:.05em;
  text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.06);border:1px solid var(--line);border-radius:7px;padding:3px 8px}
.widget.soon{opacity:.62}
.chip{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-family:var(--mono);
  background:rgba(52,227,176,.12);color:var(--teal);border:1px solid rgba(52,227,176,.3);border-radius:7px;padding:2px 8px;margin-top:8px;align-self:flex-start}
.chip.warn{background:rgba(249,168,38,.12);color:var(--amber);border-color:rgba(249,168,38,.3)}

@media(max-width:760px){.widgets{grid-template-columns:repeat(2,1fr)}.col2{grid-column:span 2}.row2{grid-row:span 1}}
@media(max-width:430px){.widgets{grid-template-columns:1fr}.col2{grid-column:span 1}}

/* ====================================================================
   BOTTOM DOCK — always-visible bar (with HQ) + slide-up launcher drawer
   ==================================================================== */
.dock-scrim{position:fixed;inset:0;background:rgba(4,5,8,.6);backdrop-filter:blur(2px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;z-index:40}
.dock-scrim.open{opacity:1;visibility:visible}

.dock{position:fixed;left:50%;bottom:calc(14px + env(safe-area-inset-bottom));transform:translateX(-50%);
  z-index:50;width:min(460px,calc(100vw - 24px));
  background:rgba(15,17,25,.85);backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);
  border:1px solid var(--line-2);border-radius:26px;box-shadow:0 22px 64px -14px rgba(0,0,0,.75);
  display:flex;flex-direction:column-reverse;overflow:hidden}

/* always-visible bar */
.dock-bar{display:flex;align-items:center;gap:10px;padding:10px 12px}
.hqbtn{display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:18px;font-weight:700;font-size:14.5px;
  background:linear-gradient(135deg,var(--indigo),var(--violet));color:#fff;flex-shrink:0;transition:.2s var(--ease)}
.hqbtn:hover{filter:brightness(1.08)}
.hqbtn .b{font-size:16px}
.opener{flex:1;display:flex;align-items:center;justify-content:center;gap:9px;padding:11px 14px;border-radius:18px;
  background:rgba(255,255,255,.05);border:1px solid var(--line);color:var(--ink);font-family:inherit;font-weight:600;
  font-size:14px;cursor:pointer;transition:.2s var(--ease)}
.opener:hover{background:rgba(255,255,255,.09)}
.opener .grip{width:26px;height:4px;border-radius:99px;background:var(--line-2)}
.opener .chev{color:var(--muted);transition:transform .42s var(--spring)}
.dock.open .opener .chev{transform:rotate(180deg)}

/* slide-up drawer */
.dock-drawer{max-height:0;opacity:0;overflow:hidden;
  transition:max-height .44s var(--spring),opacity .3s var(--ease)}
.dock.open .dock-drawer{max-height:70vh;opacity:1;overflow-y:auto}
.dock-search{margin:14px 14px 6px}
.dock-search input{background:rgba(255,255,255,.05);border:1px solid var(--line);font-size:14px;padding:11px 14px}
.dock-list{padding:6px 12px 8px;display:flex;flex-direction:column;gap:8px}
.dock-card{display:flex;align-items:center;gap:13px;padding:13px 14px;border-radius:16px;
  background:rgba(255,255,255,.035);border:1px solid var(--line);transition:.2s var(--ease)}
.dock-card:hover{background:rgba(255,255,255,.07);border-color:var(--line-2);transform:translateY(-1px)}
.dock-card.current{border-color:rgba(99,102,241,.5);background:rgba(99,102,241,.12)}
.dock-card .dc-ic{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;font-size:20px;flex-shrink:0;
  background:rgba(255,255,255,.06);border:1px solid var(--line)}
.dock-card .dc-tx{min-width:0}
.dock-card .dc-tx b{display:block;font-size:14.5px;font-weight:700}
.dock-card .dc-tx span{display:block;font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dock-card.soon{opacity:.5}
.dock-card.soon .pill{margin-left:auto;font-size:10px;font-family:var(--mono);text-transform:uppercase;color:var(--muted);
  border:1px solid var(--line);border-radius:6px;padding:2px 7px}
.dock-sep{height:1px;background:var(--line);margin:6px 18px}
/* classified row */
.dock-card.classified{background:linear-gradient(135deg,rgba(242,85,90,.1),rgba(139,92,246,.08));
  border-color:rgba(242,85,90,.28)}
.dock-card.classified .dc-ic{background:rgba(242,85,90,.14);border-color:rgba(242,85,90,.3)}
.dock-card.classified .lock{margin-left:auto;color:var(--muted);font-size:15px}

/* classified password modal */
.modal-scrim{position:fixed;inset:0;z-index:60;background:rgba(4,5,8,.72);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;padding:22px;
  opacity:0;visibility:hidden;transition:opacity .25s var(--ease),visibility .25s}
.modal-scrim.open{opacity:1;visibility:visible}
.modal{width:min(360px,100%);background:var(--surface);border:1px solid var(--line-2);border-radius:24px;padding:26px 24px;
  text-align:center;transform:scale(.94);transition:transform .35s var(--spring)}
.modal-scrim.open .modal{transform:scale(1)}
.modal .m-lock{font-size:34px}
.modal h3{font-size:19px;font-weight:800;margin:10px 0 4px;letter-spacing:-.01em}
.modal p{font-size:13px;color:var(--muted);margin-bottom:18px}
.modal input{text-align:center;letter-spacing:.1em}
.modal.shake{animation:shake .4s}
@keyframes shake{0%,100%{transform:scale(1) translateX(0)}25%{transform:translateX(-8px)}75%{transform:translateX(8px)}}
.m-err{color:var(--rose);font-size:12.5px;margin-top:10px;min-height:16px}

@media (prefers-reduced-motion:reduce){
  *,::after,::before{animation:none!important;transition:none!important}
  .pagetitle,.pagesub,.panel,.home-hint{opacity:1!important;transform:none!important}
}
