:root{
  --bg:#eef4f1; --surface:#ffffff; --surface-2:#f5f9f7;
  --rail:#ffffff; --rail-tint:#edf6f1;

  --ink:#10221c; --muted:#5a6e66; --faint:#93a59c;
  --line:#e6efea; --line-2:#d6e4dd;

  --c1:#0f9d6e; --c2:#13b981; --c3:#5fd6a8;
  --accent:#0f9d6e; --accent-ink:#0b7d57; --accent-soft:#e0f5ec; --accent-soft-2:#eefaf4;
  --grad:linear-gradient(135deg,#0b7d57 0%,#0f9d6e 50%,#13b981 100%);
  --grad-soft:linear-gradient(135deg,#0f9d6e,#5fd6a8);

  --ok:#0f8a5f; --ok-soft:#e0f4ec; --danger:#c63b51; --danger-soft:#fbeaee;

  --radius:22px; --radius-md:15px; --radius-sm:11px;
  --shadow-xs:0 1px 2px rgba(16,34,28,.05);
  --shadow-sm:0 2px 6px -1px rgba(16,34,28,.07),0 1px 2px rgba(16,34,28,.05);
  --shadow:0 12px 32px -8px rgba(16,34,28,.16),0 4px 10px -4px rgba(15,157,110,.14);
  --shadow-green:0 9px 24px -6px rgba(15,157,110,.5);
  --font-display:'Sora',system-ui,sans-serif;
  --font-body:'Inter',system-ui,-apple-system,Segoe UI,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);
  line-height:1.55;-webkit-font-smoothing:antialiased;font-size:15px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
svg{display:block;flex-shrink:0}
.muted{color:var(--muted)}

/* ───────── Auth pages ───────── */
.auth-bg{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(900px 520px at 16% -8%,#d4efe2,transparent),
             radial-gradient(820px 540px at 100% 108%,#d8f0e6,transparent),var(--bg)}
.auth-card{width:100%;max-width:428px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);padding:46px 40px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.auth-card::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:var(--grad)}
.auth-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px}
.auth-brand .logo-mark{width:34px;height:34px}
.auth-brand span{font-family:var(--font-display);font-weight:700;font-size:1.05rem}
.auth-card h1{font-family:var(--font-display);font-weight:700;font-size:1.75rem;letter-spacing:-.02em}
.center{text-align:center}
.auth-card form{margin-top:24px;display:grid;gap:18px}
label{display:grid;gap:7px;font-size:.82rem;font-weight:500;color:var(--muted)}
input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--ink);font:inherit;font-size:.95rem;outline:none;
  transition:border-color .16s,box-shadow .16s,background .16s}
input::placeholder{color:var(--faint)}
input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft);background:#fff}
input:disabled{background:#eef3f0;color:var(--muted);cursor:not-allowed}
.hint{font-size:.74rem;color:var(--faint);font-weight:400}
.btn{border:none;cursor:pointer;width:100%;padding:13px 16px;border-radius:var(--radius-sm);
  font:inherit;font-size:.95rem;font-weight:600;color:#fff;background:var(--grad-soft);
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:filter .16s,transform .05s;box-shadow:var(--shadow-green)}
.btn:hover{filter:brightness(1.06)}
.btn:active{transform:translateY(1px)}
.auth-card .muted.center{margin-top:22px;font-size:.9rem}
.alert{display:flex;align-items:center;gap:9px;padding:12px 14px;border-radius:var(--radius-sm);
  font-size:.87rem;font-weight:500;margin-bottom:16px}
.alert.error{background:var(--danger-soft);color:var(--danger)}
.alert.ok{background:var(--ok-soft);color:var(--ok)}

/* ───────── Shell ───────── */
.shell{display:flex;min-height:100vh}
.sidebar{width:264px;flex-shrink:0;background:var(--rail);border-right:1px solid var(--line);
  padding:22px 16px 18px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.logo{display:flex;align-items:center;gap:11px;padding:6px 8px 26px}
.logo-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;
  background:var(--grad-soft);color:#fff;box-shadow:var(--shadow-green)}
.logo-word{font-family:var(--font-display);font-weight:700;font-size:1.2rem;letter-spacing:-.01em;color:var(--ink)}

.nav{display:grid;gap:20px;overflow-y:auto;flex:1;align-content:start}
.nav-group{display:grid;gap:3px}
.nav-label{font-size:.67rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);padding:0 12px 7px}
.nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:12px;
  color:var(--muted);font-size:.92rem;font-weight:450;transition:background .15s,color .15s}
.nav-ic{display:grid;place-items:center;color:var(--faint);transition:color .15s}
.nav-item:hover{background:var(--rail-tint);color:var(--ink);text-decoration:none}
.nav-item:hover .nav-ic{color:var(--accent)}
.nav-item.active{background:var(--grad-soft);color:#fff;font-weight:600;box-shadow:var(--shadow-green)}
.nav-item.active .nav-ic{color:#fff}
.nav-text{flex:1}
.nav-badge{font-size:.7rem;font-weight:600;color:#fff;background:var(--grad-soft);padding:1px 8px;border-radius:99px;line-height:1.5}
.nav-item.active .nav-badge{background:rgba(255,255,255,.26)}

.rail-user{display:flex;align-items:center;gap:11px;margin-top:14px;padding:10px;border-radius:14px;
  background:var(--surface-2);border:1px solid var(--line)}
.rail-user-meta{display:flex;flex-direction:column;min-width:0;flex:1}
.rail-user-name{font-size:.86rem;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rail-user-mail{font-size:.74rem;color:var(--faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rail-logout{display:grid;place-items:center;width:32px;height:32px;border-radius:9px;color:var(--faint);flex-shrink:0;transition:background .15s,color .15s}
.rail-logout:hover{background:var(--danger-soft);color:var(--danger)}

/* main */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 38px;
  border-bottom:1px solid var(--line);background:rgba(238,244,241,.82);backdrop-filter:blur(10px);position:sticky;top:0;z-index:5}
.topbar-left{min-width:0}
.page-title{font-family:var(--font-display);font-weight:600;font-size:1.4rem;letter-spacing:-.02em;line-height:1.1}
.topbar-sub{font-size:.82rem;color:var(--muted);margin-top:2px}
.topbar-right{display:flex;align-items:center;gap:13px}
.search{display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:12px;padding:0 13px;height:40px;color:var(--faint);transition:border-color .16s,box-shadow .16s}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.search input{border:none;background:none;padding:0;width:150px;height:auto;font-size:.9rem;box-shadow:none}
.search input:focus{box-shadow:none}
.icon-btn{position:relative;border:1px solid var(--line-2);background:var(--surface);color:var(--muted);
  width:40px;height:40px;border-radius:12px;display:grid;place-items:center;cursor:pointer;transition:color .15s,border-color .15s,background .15s}
.icon-btn:hover{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft-2)}
.icon-btn .dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--danger);border:2px solid var(--surface)}
.avatar{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;background:var(--grad-soft);
  color:#fff;font-size:.84rem;font-weight:600;letter-spacing:.02em;box-shadow:var(--shadow-green)}
.avatar.sm{width:34px;height:34px;border-radius:10px;font-size:.78rem;box-shadow:none}
.avatar.lg{width:64px;height:64px;border-radius:19px;font-size:1.3rem}

.content{padding:34px 38px;max-width:1120px;width:100%;margin:0 auto}

/* gradient hero */
.hero{position:relative;overflow:hidden;border-radius:var(--radius);padding:34px;margin-bottom:24px;
  background:var(--grad);color:#fff;box-shadow:var(--shadow)}
.hero::before{content:"";position:absolute;top:-55%;right:-8%;width:420px;height:420px;border-radius:50%;
  background:radial-gradient(circle,rgba(95,214,168,.5),transparent 60%)}
.hero::after{content:"";position:absolute;bottom:-70%;left:-4%;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,.14),transparent 60%)}
.hero-inner{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:#fff;background:rgba(255,255,255,.18);padding:5px 12px;border-radius:99px;backdrop-filter:blur(4px)}
.hero h2{font-family:var(--font-display);font-weight:700;font-size:2.05rem;letter-spacing:-.025em;margin:14px 0 7px;line-height:1.06;color:#fff}
.lede{color:rgba(255,255,255,.88);font-size:1.02rem;max-width:56ch}

/* stat grid */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:16px;margin-bottom:24px}
.stat{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:22px;box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .18s,box-shadow .18s,border-color .18s}
.stat::after{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--grad-soft);opacity:0;transition:opacity .18s}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2)}
.stat:hover::after{opacity:1}
.stat-icon{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;background:var(--grad-soft);color:#fff;margin-bottom:16px;box-shadow:var(--shadow-green)}
.stat-label{font-size:.74rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--faint)}
.stat-value{font-size:1.3rem;font-weight:600;margin-top:6px;letter-spacing:-.01em}
.stat-value.small{font-size:1rem;word-break:break-word}

/* panel */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);margin-bottom:24px}
.panel-head{display:flex;align-items:flex-start;gap:15px;margin-bottom:22px}
.panel-icon{display:grid;place-items:center;width:46px;height:46px;border-radius:14px;background:var(--grad-soft);color:#fff;flex-shrink:0;box-shadow:var(--shadow-green)}
.panel-head h3{font-family:var(--font-display);font-weight:600;font-size:1.2rem;letter-spacing:-.01em}
.checks{list-style:none;display:grid;gap:13px}
.checks li{display:flex;align-items:center;gap:11px;color:var(--ink);font-size:.94rem}
.check-tick{display:grid;place-items:center;width:25px;height:25px;border-radius:8px;background:var(--ok-soft);color:var(--ok);flex-shrink:0}

/* forms in panels */
.form{display:grid;gap:18px;max-width:430px}
.form .btn{width:auto;justify-self:start;padding:12px 26px}
.profile-id{display:flex;align-items:center;gap:17px;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--line)}
.profile-name{font-family:var(--font-display);font-weight:600;font-size:1.3rem}

@media(max-width:820px){
  .shell{flex-direction:column}
  .sidebar{width:100%;height:auto;position:static;flex-direction:row;align-items:center;gap:8px;padding:10px 14px;overflow-x:auto;border-right:none;border-bottom:1px solid var(--line)}
  .logo{padding:0 12px 0 2px}.logo-word{display:none}
  .nav{grid-auto-flow:column;gap:8px;flex:1}.nav-group{grid-auto-flow:column;gap:4px}
  .nav-label{display:none}.nav-text,.nav-badge{display:none}.nav-item{padding:10px}
  .rail-user{margin-top:0;margin-left:auto;background:none;border:none;padding:4px}.rail-user-meta{display:none}.search{display:none}
  .topbar{padding:15px 18px}.content{padding:22px 18px}.hero{padding:24px 22px}.hero h2{font-size:1.65rem}
}

/* ── AI OCR feature ── */
.hint{color:var(--faint);font-size:.84rem;margin-top:16px}
.ghost{border:1px solid var(--line-2);background:var(--surface);color:var(--ink);cursor:pointer;
  padding:11px 18px;border-radius:var(--radius-sm);font:inherit;font-size:.9rem;font-weight:500;transition:background .15s,border-color .15s}
.ghost:hover{background:var(--surface-2);border-color:var(--accent-soft);text-decoration:none}
.ghost:disabled{opacity:.5;cursor:not-allowed}

.uploader{display:grid;gap:18px;justify-items:start}
.drop{width:100%;border:2px dashed var(--line-2);border-radius:var(--radius-md);background:var(--surface-2);
  padding:42px 24px;text-align:center;cursor:pointer;display:grid;gap:10px;justify-items:center;transition:border-color .15s,background .15s}
.drop:hover{border-color:var(--accent);background:var(--accent-soft)}
.drop.has{border-color:var(--accent);border-style:solid}
.drop-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;background:var(--grad-soft);color:#fff;box-shadow:var(--shadow-green)}
.drop-title{font-family:var(--font-display);font-weight:600;font-size:1.04rem}
.drop-sub{color:var(--faint);font-size:.85rem}

.preview-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:20px}
.preview-actions{display:flex;gap:10px;align-items:center}
.preview-actions form{margin:0}

.table-scroll{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius-md)}
table.data{width:100%;border-collapse:collapse;font-size:.88rem;min-width:760px}
table.data thead th{background:var(--surface-2);text-align:left;padding:12px 14px;font-weight:600;font-size:.72rem;
  text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-bottom:1px solid var(--line);white-space:nowrap}
table.data td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top}
table.data tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:var(--surface-2)}
td.num{color:var(--faint);font-variant-numeric:tabular-nums;width:38px}
td.addr{min-width:180px;color:var(--muted)}
.null{color:var(--faint);font-size:.78rem;font-style:italic}
.del{border:none;background:none;color:var(--faint);cursor:pointer;font-size:.95rem;padding:4px 8px;border-radius:7px;transition:background .15s,color .15s}
.del:hover{background:var(--danger-soft);color:var(--danger)}
.panel .btn{width:auto}

/* OCR cost / credit bar */
.cost-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:22px;box-shadow:var(--shadow-sm)}
.cost-item{display:flex;flex-direction:column;gap:2px;padding-right:18px;border-right:1px solid var(--line)}
.cost-item:last-of-type{border-right:none}
.cost-label{font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint)}
.cost-value{font-family:var(--font-display);font-weight:600;font-size:1.15rem;color:var(--ink)}
.cost-link{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-size:.85rem;font-weight:500;
  color:var(--accent);padding:8px 12px;border-radius:9px;transition:background .15s}
.cost-link:hover{background:var(--accent-soft);text-decoration:none}
@media(max-width:620px){.cost-link{margin-left:0}}
