/* ============================================================
   Turkhud & Co — Client Hub
   Brand: Empty White #F4F4F4 · Neutral Grey #858685 · Digital Black #0C0C0C
   Typeface: Object Sans (brand) — swap in when licensed; Inter as stand-in.
   ============================================================ */

:root{
  --white:#F4F4F4;
  --grey:#858685;
  --black:#0C0C0C;

  --bg:#0C0C0C;
  --surface:#141415;
  --surface-2:#1b1b1d;
  --line:rgba(244,244,244,.08);
  --line-strong:rgba(244,244,244,.16);
  --text:#F4F4F4;
  --text-dim:#a7a7a6;
  --text-faint:#6f6f6e;

  --good:#7FE3A4;      /* used sparingly, like the brand's +% green */
  --warn:#E9C46A;
  --urgent:#E88B7D;

  --r-lg:24px;
  --r-md:18px;
  --r-sm:12px;
  --shadow:0 24px 60px -20px rgba(0,0,0,.7);
  --font:"Object Sans","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--font);
  background:#070708;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:100dvh;
  padding:24px 16px 12px;
  gap:14px;
}

/* ambient gradient field behind the phone, echoing the brand boards */
.ambient{
  position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(120% 80% at 15% 0%, rgba(244,244,244,.06), transparent 55%),
    radial-gradient(100% 90% at 100% 100%, rgba(133,134,133,.10), transparent 60%),
    linear-gradient(160deg,#0a0a0b 0%,#101012 45%,#070708 100%);
}

/* ---------- device shell (phone frame on desktop, full-bleed on mobile) ---------- */
.device{
  position:relative;z-index:1;
  width:100%;max-width:420px;
  height:min(860px,92dvh);
  background:var(--bg);
  border:1px solid var(--line-strong);
  border-radius:46px;
  box-shadow:var(--shadow), 0 0 0 10px #161617, 0 0 0 11px #050506;
  overflow:hidden;
  display:flex;flex-direction:column;
}
.device__notch{
  position:absolute;top:0;left:50%;transform:translateX(-50%);
  width:140px;height:26px;background:#050506;
  border-bottom-left-radius:16px;border-bottom-right-radius:16px;z-index:40;
}
.app{
  flex:1;overflow-y:auto;overflow-x:hidden;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.app::-webkit-scrollbar{display:none}

.proto-note{
  position:relative;z-index:1;
  font-size:11px;letter-spacing:.04em;color:var(--text-faint);text-align:center;
}

@media (max-width:480px){
  body{padding:0;gap:0}
  .device{max-width:none;height:100dvh;border-radius:0;border:none;box-shadow:none}
  .device__notch{display:none}
  .proto-note{display:none}
  /* no edge-to-edge on mobile, so the big top offset (for a notch) isn't needed */
  .topbar{padding-top:16px}
  .pad-top{padding-top:18px}
}

/* ---------- reusable bits ---------- */
.screen{padding:0 20px 120px;animation:rise .42s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.pad-top{padding-top:46px}

.brandmark{display:inline-flex;align-items:center;gap:10px}
.brandmark svg{width:30px;height:30px;display:block}
.brandmark .wm{display:flex;flex-direction:column;line-height:1}
.brandmark .wm b{font-weight:700;font-size:15px;letter-spacing:.02em}
.brandmark .wm span{font-size:9px;letter-spacing:.34em;color:var(--text-faint);text-transform:uppercase;margin-top:3px}

.eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--text-faint);font-weight:600}
h1{font-size:30px;line-height:1.08;font-weight:700;letter-spacing:-.02em}
h2{font-size:21px;line-height:1.15;font-weight:600;letter-spacing:-.01em}
h3{font-size:15px;font-weight:600}
.lead{color:var(--text-dim);font-size:14.5px;line-height:1.5}
.muted{color:var(--text-faint)}

/* buttons */
.btn{
  appearance:none;border:none;cursor:pointer;font-family:inherit;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:15px 20px;border-radius:14px;width:100%;
  transition:transform .15s ease, background .2s ease, opacity .2s ease;
}
.btn:active{transform:scale(.975)}
.btn--primary{background:var(--white);color:var(--black)}
.btn--primary:hover{background:#fff}
.btn--ghost{background:transparent;color:var(--text);border:1px solid var(--line-strong)}
.btn--ghost:hover{background:rgba(244,244,244,.05)}
.btn--quiet{background:var(--surface-2);color:var(--text)}
.btn--quiet:hover{background:#222224}
.btn--sm{padding:11px 15px;font-size:13.5px;width:auto;border-radius:11px}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

.stack > * + *{margin-top:12px}

/* card */
.card{
  background:linear-gradient(180deg,var(--surface) 0%, #101011 100%);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:18px;
}
.card--tap{cursor:pointer;transition:border-color .2s ease, transform .15s ease, background .2s ease}
.card--tap:hover{border-color:var(--line-strong);background:linear-gradient(180deg,#17171a 0%,#121214 100%)}
.card--tap:active{transform:scale(.99)}

/* pill / badge */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  letter-spacing:.02em;padding:5px 10px;border-radius:999px;border:1px solid var(--line-strong);color:var(--text-dim)}
.pill--good{color:var(--good);border-color:rgba(127,227,164,.3);background:rgba(127,227,164,.08)}
.pill--warn{color:var(--warn);border-color:rgba(233,196,106,.3);background:rgba(233,196,106,.08)}
.pill--urgent{color:var(--urgent);border-color:rgba(232,139,125,.3);background:rgba(232,139,125,.08)}
.pill .dot{width:6px;height:6px;border-radius:50%;background:currentColor}

/* top bar */
.topbar{position:sticky;top:0;z-index:30;background:rgba(12,12,12,.82);backdrop-filter:blur(16px);
  display:flex;align-items:center;gap:12px;padding:46px 20px 14px;border-bottom:1px solid var(--line)}
.topbar .back{appearance:none;border:1px solid var(--line-strong);background:transparent;color:var(--text);
  width:38px;height:38px;border-radius:11px;cursor:pointer;font-size:18px;display:grid;place-items:center;flex:none;transition:background .2s}
.topbar .back:hover{background:rgba(244,244,244,.06)}
.topbar .ttl{font-weight:600;font-size:15px;letter-spacing:-.01em;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* progress ring for countdown */
.ring{--p:0;width:46px;height:46px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:conic-gradient(var(--ring-c) calc(var(--p)*1%), rgba(244,244,244,.09) 0);
  font-size:12px;font-weight:700}
.ring i{width:38px;height:38px;border-radius:50%;background:var(--surface);display:grid;place-items:center;font-style:normal;line-height:1.05;text-align:center}
.ring i b{font-size:13px;font-weight:700;display:block}
.ring i s{font-size:8px;text-decoration:none;color:var(--text-faint);letter-spacing:.05em}

/* deadline row */
.deadline{display:flex;align-items:center;gap:14px}
.deadline .meta{flex:1;min-width:0}
.deadline .meta h3{margin-bottom:3px}
.deadline .meta p{font-size:12.5px;color:var(--text-faint)}
.deadline .chev{color:var(--text-faint);font-size:20px;flex:none}

/* bank grid */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bank{display:flex;align-items:center;gap:12px;padding:15px 14px;border-radius:14px;border:1px solid var(--line-strong);
  background:var(--surface-2);color:var(--text);cursor:pointer;transition:border-color .2s,background .2s,transform .15s;text-align:left}
.bank:hover{border-color:rgba(244,244,244,.32);background:#242427}
.bank:active{transform:scale(.98)}
.bank .logo{width:40px;height:40px;border-radius:10px;flex:none;display:grid;place-items:center;
  font-weight:800;font-size:16px;color:#fff}
.bank .nm{font-size:15px;font-weight:600;line-height:1.15;color:var(--text)}
.bank.sel{border-color:rgba(244,244,244,.55);background:#26262a}
.bank.sel::after{content:"✓";margin-left:auto;font-size:13px;font-weight:800;color:var(--good)}

/* bank logo chip — real logo on white, letter-badge fallback */
.banklogo{width:40px;height:40px;border-radius:10px;flex:none;display:grid;place-items:center;
  background:#fff;overflow:hidden}
.banklogo img{width:74%;height:74%;object-fit:contain;display:block}
.banklogo.ltr{color:#fff;font-weight:800;font-size:16px}

/* calendar */
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-head h3{font-size:15px;font-weight:600}
.cal-nav{display:flex;gap:8px}
.cal-nav button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line-strong);background:transparent;
  color:var(--text);cursor:pointer;font-size:15px;display:grid;place-items:center;transition:background .2s}
.cal-nav button:hover:not(:disabled){background:rgba(244,244,244,.06)}
.cal-nav button:disabled{opacity:.28;cursor:default}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;animation:rise .35s ease both}
.cal-dow{font-size:9.5px;color:var(--text-faint);text-align:center;font-weight:700;letter-spacing:.05em;padding-bottom:3px}
.cal-day{height:30px;display:flex;align-items:center;justify-content:center;border-radius:8px;
  font-size:12.5px;color:var(--text-dim);position:relative}
.cal-day.out{color:var(--text-faint);opacity:.3}
.cal-day.today{border:1px solid var(--line-strong);color:var(--text)}
.cal-day.has{cursor:pointer;color:var(--text);font-weight:700}
.cal-day.has .cdot{width:4px;height:4px;border-radius:50%;background:var(--warn);position:absolute;bottom:3px;left:50%;transform:translateX(-50%)}
.cal-day.sel{background:var(--white);color:var(--black);font-weight:700}
.cal-day.sel .cdot{background:var(--black)}

.search{width:100%;background:var(--surface);border:1px solid var(--line-strong);border-radius:13px;
  padding:13px 15px;color:var(--text);font-family:inherit;font-size:14.5px;outline:none}
.search::placeholder{color:var(--text-faint)}
.search:focus{border-color:rgba(244,244,244,.3)}

/* numbered guide steps */
.steps{counter-reset:s;list-style:none}
.steps li{position:relative;padding:0 0 22px 46px;counter-increment:s}
.steps li::before{content:counter(s);position:absolute;left:0;top:-2px;width:30px;height:30px;border-radius:50%;
  background:var(--white);color:var(--black);font-weight:700;font-size:13px;display:grid;place-items:center}
.steps li::after{content:"";position:absolute;left:14.5px;top:30px;bottom:2px;width:1px;background:var(--line-strong)}
.steps li:last-child::after{display:none}
.steps li h3{margin-bottom:4px}
.steps li p{font-size:13px;color:var(--text-dim);line-height:1.5}
.steps li .tip{margin-top:7px;font-size:12px;color:var(--text-faint);display:flex;gap:7px}
.steps li .tip b{color:var(--text-dim);font-weight:600}

/* uploader */
.drop{border:1.5px dashed var(--line-strong);border-radius:var(--r-md);padding:30px 20px;text-align:center;
  background:var(--surface);transition:border-color .2s,background .2s;cursor:pointer}
.drop:hover{border-color:rgba(244,244,244,.4);background:var(--surface-2)}
.drop .ic{font-size:30px;margin-bottom:10px}
.drop h3{margin-bottom:5px}
.drop p{font-size:12.5px;color:var(--text-faint)}
.filechip{display:flex;align-items:center;gap:11px;background:var(--surface-2);border:1px solid var(--line);
  border-radius:12px;padding:11px 13px}
.filechip .fi{width:30px;height:30px;border-radius:8px;background:var(--white);color:var(--black);
  display:grid;place-items:center;font-weight:800;font-size:10px;flex:none}
.filechip .fmeta{flex:1;min-width:0}
.filechip .fmeta b{font-size:13px;font-weight:600;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.filechip .fmeta span{font-size:11px;color:var(--text-faint)}
.filechip .rm{background:none;border:none;color:var(--text-faint);cursor:pointer;font-size:18px;padding:4px}
.filechip .rm:hover{color:var(--urgent)}

textarea.note{width:100%;background:var(--surface);border:1px solid var(--line-strong);border-radius:13px;
  padding:13px 15px;color:var(--text);font-family:inherit;font-size:14px;outline:none;resize:none;min-height:84px}
textarea.note:focus{border-color:rgba(244,244,244,.3)}

/* checklist */
.check{display:flex;align-items:flex-start;gap:12px;padding:13px 0;border-bottom:1px solid var(--line)}
.check:last-child{border-bottom:none}
.check .box{width:22px;height:22px;border-radius:7px;border:1.5px solid var(--line-strong);flex:none;margin-top:1px;
  display:grid;place-items:center;font-size:13px;transition:.2s}
.check.done .box{background:var(--good);border-color:var(--good);color:var(--black)}
.check .ctext h3{font-size:14px;margin-bottom:2px}
.check.done .ctext h3{color:var(--text-faint);text-decoration:line-through}
.check .ctext p{font-size:12px;color:var(--text-faint)}

/* success */
.success{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:70px}
.success .seal{width:96px;height:96px;border-radius:50%;background:radial-gradient(circle at 50% 35%,rgba(127,227,164,.25),transparent 70%);
  display:grid;place-items:center;margin-bottom:24px;animation:pop .5s cubic-bezier(.2,.8,.2,1) both}
.success .seal svg{width:54px;height:54px}
@keyframes pop{from{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}

/* bottom nav */
.tabbar-host{flex:none}
.tabbar-host:empty{display:none}
.tabbar{display:flex;
  background:rgba(12,12,12,.9);backdrop-filter:blur(18px);border-top:1px solid var(--line);
  padding:10px 12px calc(12px + env(safe-area-inset-bottom, 0px))}
.tabbar button{flex:1;background:none;border:none;cursor:pointer;color:var(--text-faint);
  display:flex;flex-direction:column;align-items:center;gap:5px;font-family:inherit;font-size:10px;font-weight:600;
  letter-spacing:.02em;padding:4px;transition:color .2s}
.tabbar button.active{color:var(--white)}
.tabbar button svg{width:22px;height:22px}

.fade-row > *{animation:rise .5s cubic-bezier(.2,.7,.2,1) both}
.fade-row > *:nth-child(2){animation-delay:.05s}
.fade-row > *:nth-child(3){animation-delay:.1s}
.fade-row > *:nth-child(4){animation-delay:.15s}
.fade-row > *:nth-child(5){animation-delay:.2s}

.hr{height:1px;background:var(--line);border:none;margin:22px 0}
.hint{display:flex;gap:9px;font-size:12.5px;color:var(--text-faint);background:var(--surface);
  border:1px solid var(--line);border-radius:12px;padding:12px 14px;line-height:1.45}
.hint b{color:var(--text-dim);font-weight:600}

/* one-time "add to home screen" install hint */
.install-hint{position:absolute;left:12px;right:12px;bottom:86px;z-index:60;
  background:var(--surface-2);border:1px solid var(--line-strong);border-radius:16px;
  padding:14px 12px 14px 14px;display:flex;gap:12px;align-items:flex-start;
  box-shadow:0 18px 44px -12px rgba(0,0,0,.75);animation:rise .4s cubic-bezier(.2,.7,.2,1) both}
.install-hint .ih-star{width:34px;height:34px;flex:none;border-radius:9px}
.install-hint .ih-body{flex:1;min-width:0}
.install-hint .ih-body b{font-size:13.5px;font-weight:600;display:block}
.install-hint .ih-body span{font-size:11.5px;color:var(--text-dim);line-height:1.45;display:block;margin-top:3px}
.install-hint .ih-x{background:none;border:none;color:var(--text-faint);font-size:20px;line-height:1;cursor:pointer;padding:0 4px;flex:none}
.install-hint .ih-x:hover{color:var(--text)}
.install-hint .ih-install{width:auto;margin-top:9px;padding:9px 16px}
.install-hint svg.shareic{vertical-align:-2px}
