:root{
  --navy:#071b49;
  --navy-2:#0b255f;
  --navy-3:#061634;
  --ink:#10213d;
  --ink-soft:#2d466d;
  --blue:#146AF5;
  --teal:#00C2B8;
  --violet:#7B61FF;
  --muted:#64748b;
  --muted-2:#7d8ca3;
  --line:#e7edf5;
  --bg:#f4f7fb;
  --bg-2:#eef3f9;
  --card:#ffffff;
  --danger:#b91c1c;
  --ok:#0f766e;
  --shadow:0 24px 60px rgba(7,27,73,.08);
  --shadow-lg:0 35px 90px rgba(7,27,73,.12);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Plus Jakarta Sans",Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
.container{width:min(1220px,calc(100% - 42px));margin:0 auto}
.mono{font-variant-numeric:tabular-nums}

/* public landing */
.landing{
  min-height:100vh;
  background:
    radial-gradient(circle at 12% 0%,rgba(0,194,184,.14),transparent 26%),
    radial-gradient(circle at 88% 16%,rgba(20,106,245,.11),transparent 30%),
    linear-gradient(180deg,#f8fbff 0%,#f0f5fb 46%,#f7fafe 100%);
}
.landing::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:linear-gradient(90deg,rgba(255,255,255,.22) 0%,transparent 16%,transparent 84%,rgba(255,255,255,.18) 100%);
  opacity:.7;
}
.topbar{height:92px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:25;background:rgba(248,251,255,.72);backdrop-filter:blur(18px);border-bottom:1px solid rgba(231,237,245,.8)}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;width:100%;gap:24px}
.brand-wrap{display:flex;align-items:center;gap:18px;min-width:0}
.brand-logo{height:58px;width:auto;object-fit:contain}
.brand-mark{height:48px;width:auto;object-fit:contain}
.nav{display:flex;gap:26px;align-items:center;color:var(--ink-soft);font-size:15px;font-weight:500}
.nav a{opacity:.92;transition:.22s ease}
.nav a:hover{color:var(--navy);opacity:1}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;border:0;border-radius:999px;padding:14px 24px;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;font-size:15px;font-weight:700;letter-spacing:-.01em;cursor:pointer;box-shadow:0 14px 28px rgba(20,106,245,.16);transition:transform .2s ease,box-shadow .2s ease,opacity .2s ease}
.btn:hover{transform:translateY(-1px);box-shadow:0 18px 32px rgba(20,106,245,.18)}
.btn.secondary{background:rgba(255,255,255,.85);color:var(--navy);border:1px solid rgba(16,33,61,.08);box-shadow:none}
.btn.secondary:hover{background:#fff}
.btn.ghost{background:transparent;color:var(--navy);border:1px solid rgba(7,27,73,.14);box-shadow:none}
.hero{padding:66px 0 52px;display:grid;grid-template-columns:minmax(0,1.03fr) minmax(430px,.97fr);gap:48px;align-items:center;position:relative}
.eyebrow{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.75);border:1px solid rgba(20,106,245,.12);color:var(--teal);font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:11px;box-shadow:0 10px 20px rgba(7,27,73,.04)}
.eyebrow::before{content:"";width:8px;height:8px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--blue));box-shadow:0 0 0 6px rgba(0,194,184,.1)}
.hero h1{font-size:clamp(48px,5.8vw,74px);line-height:.98;margin:18px 0 18px;color:var(--navy);letter-spacing:-.06em;font-weight:700}
.hero h1 .accent{background:linear-gradient(135deg,var(--blue),var(--violet));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{font-size:19px;line-height:1.7;color:var(--muted);max-width:670px;margin:0}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.hero-quick{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.quick-pill{padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid rgba(16,33,61,.08);color:var(--ink-soft);font-size:13px;font-weight:600}
.hero-visual-wrap{position:relative}
.hero-visual{position:relative;min-height:560px;border-radius:36px;padding:18px;background:linear-gradient(145deg,rgba(255,255,255,.76),rgba(255,255,255,.48));border:1px solid rgba(255,255,255,.8);box-shadow:var(--shadow-lg);backdrop-filter:blur(18px);overflow:hidden}
.hero-visual::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 15%,rgba(0,194,184,.2),transparent 26%),radial-gradient(circle at 18% 84%,rgba(20,106,245,.16),transparent 32%)}
.orbit-card{position:absolute;display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:18px;background:rgba(255,255,255,.92);border:1px solid rgba(16,33,61,.08);box-shadow:0 18px 32px rgba(7,27,73,.08);font-size:13px;color:var(--ink-soft);font-weight:600;z-index:3}
.orbit-card strong{display:block;color:var(--navy);font-size:15px;font-weight:700}
.orbit-1{right:16px;top:26px;animation:floaty 5.6s ease-in-out infinite}
.orbit-2{left:-8px;top:90px;animation:floaty 6s ease-in-out infinite .5s}
.orbit-3{right:4px;bottom:60px;animation:floaty 5s ease-in-out infinite .9s}
.dashboard-mock{position:relative;height:100%;border-radius:28px;background:linear-gradient(180deg,#061634,#082056 58%,#0b2d70 100%);padding:24px 24px 22px;color:#fff;overflow:hidden;z-index:2}
.dashboard-mock::before{content:"";position:absolute;inset:-10px;background:radial-gradient(circle at 78% 14%,rgba(0,194,184,.28),transparent 22%),linear-gradient(180deg,transparent 52%,rgba(255,255,255,.02) 100%);pointer-events:none}
.mock-top{display:flex;align-items:center;justify-content:space-between;gap:16px;position:relative}
.mock-brand{display:flex;align-items:center;gap:14px}
.mock-brand img{height:62px;width:auto}
.mock-badge{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);font-size:12px;color:#dceaff;font-weight:600}
.mock-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;margin-top:22px;position:relative}
.mock-column{display:grid;gap:14px}
.mock-card{border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);padding:18px}
.mock-card h3,.mock-card h4{margin:0;color:#fff;font-size:17px;font-weight:600;letter-spacing:-.02em}
.mock-copy{margin:8px 0 0;color:#c7d7f2;line-height:1.55;font-size:14px}
.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:14px}
.metric{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:16px}
.metric b{display:block;font-size:28px;line-height:1;color:#fff;font-weight:700}
.metric span{display:block;margin-top:8px;color:#c9d5ec;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.pipeline{display:grid;gap:10px;margin-top:14px}
.pipe{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);font-size:13px;color:#dceaff}
.pipe b{font-size:14px;color:#fff;font-weight:700}
.kpi-list{display:grid;gap:10px;margin-top:14px}
.kpi-item{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.kpi-item:last-child{border-bottom:0}
.kpi-item span{font-size:13px;color:#c8d7f0}
.kpi-item strong{font-weight:700;color:#fff}
.section{padding:84px 0;position:relative}
.section h2{font-size:clamp(34px,4.4vw,48px);letter-spacing:-.05em;line-height:1.02;color:var(--navy);margin:0 0 14px;font-weight:700}
.section p.section-lead{font-size:18px;color:var(--muted);max-width:820px;line-height:1.7;margin:0}
.surface{background:rgba(255,255,255,.82);border:1px solid rgba(255,255,255,.72);box-shadow:var(--shadow);backdrop-filter:blur(16px);border-radius:32px;padding:30px}
.stats-strip{margin-top:28px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat-glass{padding:20px;border-radius:22px;background:rgba(255,255,255,.72);border:1px solid rgba(16,33,61,.06);box-shadow:0 15px 28px rgba(7,27,73,.04)}
.stat-glass small{display:block;color:var(--muted-2);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.stat-glass strong{display:block;margin-top:10px;color:var(--navy);font-size:30px;letter-spacing:-.04em;font-weight:700}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:34px}
.card{background:rgba(255,255,255,.88);border:1px solid rgba(16,33,61,.06);border-radius:26px;padding:26px;box-shadow:0 16px 34px rgba(15,23,42,.05);transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 22px 40px rgba(15,23,42,.08);border-color:rgba(20,106,245,.15)}
.card-icon{width:44px;height:44px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(20,106,245,.12),rgba(0,194,184,.12));color:var(--navy);font-size:18px;font-weight:700;margin-bottom:18px}
.card h3{margin:0 0 12px;color:var(--navy);font-size:22px;letter-spacing:-.03em;font-weight:650}
.card p{margin:0;color:var(--muted);line-height:1.7;font-size:15px}
.module-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:30px}
.module-chip{padding:16px 18px;border-radius:18px;background:#fff;border:1px solid var(--line);font-size:14px;font-weight:600;color:var(--ink-soft);box-shadow:0 12px 24px rgba(15,23,42,.04)}
.pricing-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:26px}
.billing-toggle{display:inline-flex;align-items:center;gap:8px;padding:8px;border-radius:999px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 20px rgba(15,23,42,.04)}
.billing-toggle button{border:0;background:transparent;padding:10px 16px;border-radius:999px;color:var(--muted);font-size:14px;font-weight:700;cursor:pointer;transition:.2s}
.billing-toggle button.active{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;box-shadow:0 12px 22px rgba(20,106,245,.14)}
.billing-note{font-size:13px;color:var(--muted)}
.pricing{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.price-card{position:relative;background:rgba(255,255,255,.92);border:1px solid rgba(16,33,61,.07);border-radius:28px;padding:24px 22px;box-shadow:0 18px 38px rgba(15,23,42,.05);transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.price-card:hover{transform:translateY(-5px);box-shadow:0 24px 46px rgba(15,23,42,.08)}
.price-card.featured{border-color:rgba(0,194,184,.46);box-shadow:0 24px 54px rgba(0,194,184,.1)}
.price-card .label-top{display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border-radius:999px;background:#eff6ff;color:#0b4aa2;font-size:12px;font-weight:700}
.price-card.featured .label-top{background:rgba(0,194,184,.12);color:#0d6a63}
.price-card h3{margin:16px 0 8px;color:var(--navy);font-size:24px;letter-spacing:-.03em;font-weight:700}
.price-card p.small{margin:0;color:var(--muted);font-size:14px;line-height:1.65;min-height:70px}
.price-row{display:flex;align-items:flex-end;gap:8px;margin:18px 0 8px}
.price{font-size:44px;line-height:.92;font-weight:700;color:var(--navy);letter-spacing:-.05em}
.price-suffix{font-size:14px;color:var(--muted);padding-bottom:8px}
.price-card .saving{display:inline-flex;margin-top:8px;padding:8px 10px;border-radius:999px;background:#f0fdf9;color:#0f766e;font-size:12px;font-weight:700}
.features{padding:0;margin:22px 0 0;list-style:none;display:grid;gap:12px;color:#475569}
.features li{display:flex;align-items:flex-start;gap:10px;border-top:1px solid #eef2f7;padding-top:12px;font-size:14px;line-height:1.55}
.features li::before{content:"";width:9px;height:9px;border-radius:50%;margin-top:.42em;flex:0 0 auto;background:linear-gradient(135deg,var(--teal),var(--blue))}
.cta-band{margin-top:36px;padding:24px 26px;border-radius:26px;background:linear-gradient(135deg,#071b49,#0a2b6a 68%,#0e3c8d);color:#fff;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;box-shadow:var(--shadow)}
.cta-band h3{margin:0;font-size:28px;letter-spacing:-.04em;font-weight:700}
.cta-band p{margin:6px 0 0;color:#dceaff;max-width:720px;line-height:1.6}
.footer{padding:34px 0 44px;color:var(--muted);border-top:1px solid rgba(16,33,61,.06)}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}
.footer-brand{display:flex;align-items:center;gap:16px}
.footer-brand img{height:42px;width:auto}
.footer small{font-size:13px;color:var(--muted)}

/* login + install */
.login-page{min-height:100vh;display:grid;place-items:center;padding:28px;background:radial-gradient(circle at 10% 0%,rgba(0,194,184,.1),transparent 30%),linear-gradient(135deg,#f9fbfe,#eef4fb 55%,#e8eef7 100%)}
.login-shell{width:min(860px,100%);display:grid;grid-template-columns:1.05fr .95fr;background:rgba(255,255,255,.58);border:1px solid rgba(255,255,255,.74);backdrop-filter:blur(18px);border-radius:34px;box-shadow:var(--shadow-lg);overflow:hidden}
.login-panel{padding:40px 42px;position:relative}
.login-panel.brand{background:linear-gradient(180deg,#071b49,#082058 72%,#0a2b6a);color:#fff;display:flex;flex-direction:column;justify-content:space-between}
.login-panel.brand::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 0%,rgba(0,194,184,.2),transparent 30%),radial-gradient(circle at 84% 70%,rgba(123,97,255,.16),transparent 26%)}
.login-panel.brand > *{position:relative}
.login-brand-logo{height:96px;width:auto;max-width:100%}
.login-brand-copy h2{margin:22px 0 12px;font-size:34px;letter-spacing:-.05em;font-weight:700}
.login-brand-copy p{margin:0;color:#dbe7fb;line-height:1.7;font-size:15px}
.login-mini{display:grid;gap:12px;margin-top:28px}
.login-mini-card{padding:16px 18px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.login-mini-card strong{display:block;color:#fff;font-size:15px;font-weight:700}
.login-mini-card span{display:block;margin-top:6px;font-size:13px;color:#d2dff3;line-height:1.55}
.login-panel.form{background:rgba(255,255,255,.88)}
.login-header h1{margin:0;color:var(--navy);font-size:34px;letter-spacing:-.04em;font-weight:700}
.login-header p{margin:10px 0 26px;color:var(--muted);line-height:1.65;font-size:15px}
.form-group{margin:0 0 16px}
.label{display:block;font-size:13px;font-weight:700;color:#314260;margin-bottom:8px;letter-spacing:.01em}
.input,select,textarea{width:100%;height:50px;border:1px solid #dbe4ef;border-radius:16px;padding:0 15px;background:#fff;color:var(--ink);font-size:15px;transition:border-color .2s ease,box-shadow .2s ease}
.input:focus,select:focus,textarea:focus{outline:none;border-color:rgba(20,106,245,.42);box-shadow:0 0 0 4px rgba(20,106,245,.08)}
textarea{height:130px;padding:14px 15px;resize:vertical;line-height:1.6}
.login-footer-note{font-size:13px;text-align:center;color:var(--muted);margin-top:20px}

/* app shell */
.app-shell{display:grid;grid-template-columns:286px 1fr;min-height:100vh;background:linear-gradient(180deg,#f3f7fb,#eff4fa)}
.sidebar{background:linear-gradient(180deg,#061634,#071b49 70%,#082058);color:#dceaff;padding:24px 20px 22px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.side-top{padding:8px 10px 22px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:18px}
.side-logo{height:62px;width:auto;max-width:100%;object-fit:contain}
.side-tag{margin-top:14px;font-size:12px;color:#b9cae9;line-height:1.55}
.side-nav{display:grid;gap:6px;flex:1}
.side-nav a{display:flex;align-items:center;gap:10px;padding:13px 14px;border-radius:15px;color:#dceaff;font-size:14px;font-weight:600;transition:.2s}
.side-nav a.active,.side-nav a:hover{background:rgba(255,255,255,.1)}
.side-nav .nav-aux{margin-top:8px;padding-top:14px;border-top:1px solid rgba(255,255,255,.08)}
.main{padding:28px}
.page-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;margin-bottom:24px}
.page-title h1{margin:0;color:var(--navy);font-size:32px;letter-spacing:-.045em;font-weight:700}
.page-title p{margin:8px 0 0;color:var(--muted);line-height:1.65;font-size:15px;max-width:760px}
.grid{display:grid;gap:18px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.stat{background:rgba(255,255,255,.88);border:1px solid rgba(16,33,61,.06);border-radius:24px;padding:22px;box-shadow:0 12px 28px rgba(15,23,42,.05)}
.stat span{color:var(--muted-2);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.stat b{display:block;font-size:30px;color:var(--navy);margin-top:10px;letter-spacing:-.04em;font-weight:700}
.table-card{background:rgba(255,255,255,.9);border:1px solid rgba(16,33,61,.06);border-radius:24px;overflow:hidden;box-shadow:0 12px 28px rgba(15,23,42,.05)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:16px;border-bottom:1px solid #eef2f7;vertical-align:top;font-size:14px}
th{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-2);background:#f8fbff;font-weight:700}
.badge{display:inline-flex;border-radius:999px;padding:7px 11px;font-weight:700;font-size:12px;background:#e8f2ff;color:#0b4aa2}
.badge.active{background:#dcfce7;color:#166534}
.badge.suspended{background:#fee2e2;color:#991b1b}
.badge.trial{background:#fef3c7;color:#92400e}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.linkbtn{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(16,33,61,.08);border-radius:12px;padding:10px 13px;background:#fff;font-weight:700;font-size:13px;color:var(--navy)}
.alert{background:#ecfeff;border:1px solid #a5f3fc;border-radius:16px;padding:14px 16px;color:#155e75;margin-bottom:16px;font-size:14px}
.tabs{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.tabs a{padding:10px 14px;border:1px solid rgba(16,33,61,.08);border-radius:12px;background:#fff;font-weight:700;font-size:13px;color:#334155}
.tabs a.active{background:var(--navy);color:#fff}
.two{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.editor-preview{background:linear-gradient(135deg,#071b49,#0c3b83);border-radius:26px;padding:26px;color:#fff;box-shadow:var(--shadow);position:relative;overflow:hidden}
.editor-preview::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 10% 0%,rgba(0,194,184,.18),transparent 28%)}
.editor-preview > *{position:relative}
.editor-preview h2{font-size:32px;letter-spacing:-.05em;line-height:1.05;margin:0 0 12px;font-weight:700}
.editor-preview p{color:#dceaff;line-height:1.7;font-size:15px}
.current-thumb{margin-top:12px;border-radius:18px;overflow:hidden;border:1px solid rgba(16,33,61,.08);background:#f8fbff}
.current-thumb img{width:100%;height:auto}
.card.compact{padding:22px}
.file-help{margin-top:10px;font-size:13px;color:var(--muted)}
.empty-state{padding:40px 24px;color:var(--muted);text-align:center}

@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@media(max-width:1180px){
  .hero{grid-template-columns:1fr;gap:26px}
  .hero-visual{min-height:520px}
  .pricing{grid-template-columns:repeat(2,1fr)}
  .cards,.grid.cols-4,.grid.cols-3,.stats-strip,.module-grid{grid-template-columns:repeat(2,1fr)}
  .app-shell,.two,.login-shell{grid-template-columns:1fr}
  .sidebar{position:relative;height:auto}
}
@media(max-width:760px){
  .container{width:min(100% - 28px,1220px)}
  .topbar{height:84px}
  .brand-logo{height:48px}
  .nav{display:none}
  .hero{padding:40px 0 34px}
  .hero h1{font-size:42px}
  .hero p{font-size:17px}
  .hero-visual{min-height:auto}
  .orbit-card{display:none}
  .mock-grid,.metric-grid,.stats-strip,.cards,.pricing,.grid.cols-4,.grid.cols-3,.module-grid{grid-template-columns:1fr}
  .section{padding:66px 0}
  .cta-band h3{font-size:24px}
  .main{padding:20px}
  .login-panel{padding:28px 24px}
  .login-brand-logo{height:78px}
}

.hero.hero-no-image{grid-template-columns:minmax(0,900px);justify-content:start;padding-top:82px;padding-bottom:72px}
.hero.hero-no-image .hero-copy-block{max-width:920px}
.hero-image-only{min-height:520px;padding:0;background:rgba(255,255,255,.78)}
.hero-uploaded-image{width:100%;height:100%;object-fit:cover;border-radius:28px;display:block}
.benefits-strip .stat-glass strong{font-size:25px;line-height:1.15}
@media(max-width:1180px){.hero.hero-no-image{grid-template-columns:1fr}}

/* v0.1.3 public landing corrections */
.hero.hero-no-image{grid-template-columns:minmax(0,980px);justify-content:center;text-align:left;padding-top:86px;padding-bottom:72px}
.hero.hero-no-image .hero-copy-block{max-width:980px}
.hero.hero-no-image h1{max-width:940px}
.hero.hero-no-image p{max-width:820px}
.hero-image-only{min-height:520px;padding:0;background:rgba(255,255,255,.68)}
.hero-uploaded-image{width:100%;height:100%;min-height:520px;object-fit:cover;border-radius:28px}
.benefits-strip .stat-glass strong{font-size:24px;line-height:1.12}

/* v0.1.3 landing editor */
.landing-editor{display:grid;gap:20px}
.editor-hero-card{position:relative;overflow:hidden;border-radius:30px;background:linear-gradient(135deg,#061634,#08245f 68%,#0a3280);color:#fff;padding:30px;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.14)}
.editor-hero-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 84% 8%,rgba(0,194,184,.22),transparent 28%),radial-gradient(circle at 18% 82%,rgba(123,97,255,.14),transparent 30%);pointer-events:none}
.editor-hero-card > *{position:relative}
.editor-hero-top{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:24px}
.editor-hero-top img{height:62px;width:auto;max-width:100%}
.editor-hero-pill{display:inline-flex;align-items:center;border-radius:999px;padding:9px 14px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);color:#dceaff;font-size:13px;font-weight:650}
.editor-hero-card h2{max-width:900px;margin:0;color:#fff;font-size:36px;line-height:1.05;letter-spacing:-.05em;font-weight:700}
.editor-hero-card p{max-width:820px;margin:14px 0 0;color:#d8e6fb;line-height:1.7;font-size:16px}
.editor-body-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:20px;align-items:start}
.editor-section-title{margin:0 0 16px;color:var(--navy);font-size:20px;letter-spacing:-.03em;font-weight:700}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-grid.full{grid-template-columns:1fr}
.upload-panel{background:#fff;border:1px solid rgba(16,33,61,.07);border-radius:26px;padding:24px;box-shadow:0 16px 34px rgba(15,23,42,.05)}
.upload-drop{border:1px dashed #c6d4e6;border-radius:22px;background:#f8fbff;padding:22px;margin-top:12px}
.upload-drop p{margin:0 0 12px;color:var(--muted);line-height:1.6;font-size:14px}
.image-status{margin-top:14px;padding:14px 16px;border-radius:18px;background:#f6f9fd;border:1px solid var(--line);font-size:13px;color:var(--muted);line-height:1.55}
.image-status strong{display:block;color:var(--navy);font-size:14px;margin-bottom:4px}
.blocks-editor-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.block-editor-card{background:#fff;border:1px solid rgba(16,33,61,.07);border-radius:22px;padding:18px;box-shadow:0 12px 24px rgba(15,23,42,.04)}
.block-editor-card .block-number{display:inline-flex;width:34px;height:34px;align-items:center;justify-content:center;border-radius:12px;background:#eaf7fb;color:var(--navy);font-weight:700;margin-bottom:12px}
.sticky-save{position:sticky;bottom:18px;z-index:20;margin-top:20px;display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding:16px 18px;border-radius:22px;background:rgba(255,255,255,.88);border:1px solid rgba(16,33,61,.08);box-shadow:0 18px 40px rgba(7,27,73,.1);backdrop-filter:blur(14px)}
.sticky-save span{color:var(--muted);font-size:14px}
@media(max-width:1180px){.editor-body-grid,.blocks-editor-grid{grid-template-columns:1fr}.field-grid{grid-template-columns:1fr}.hero.hero-no-image{padding-top:56px}}

/* client portal + recruitment */
.client-shell{display:grid;grid-template-columns:294px 1fr;min-height:100vh;background:linear-gradient(180deg,#f5f8fc,#edf3fa)}
.client-sidebar{background:linear-gradient(180deg,#071b49,#082058 72%,#0a2c70);color:#dceaff;padding:24px 20px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column}
.client-brand{padding:8px 10px 20px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:18px}
.client-brand img{height:58px;width:auto;max-width:100%}
.client-company{margin-top:16px;padding:14px;border-radius:18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1)}
.client-company strong{display:block;color:#fff;font-size:15px;font-weight:700}
.client-company span{display:block;margin-top:5px;color:#b9cae9;font-size:12px;line-height:1.45}
.client-nav{display:grid;gap:6px;flex:1}
.client-nav a{padding:13px 14px;border-radius:15px;color:#dceaff;font-size:14px;font-weight:600;transition:.2s}
.client-nav a.active,.client-nav a:hover{background:rgba(255,255,255,.1)}
.client-main{padding:28px}
.notice-panel{border-radius:22px;padding:18px 20px;background:#fff;border:1px solid rgba(16,33,61,.06);box-shadow:0 12px 26px rgba(15,23,42,.04);display:flex;align-items:flex-start;gap:14px;color:#334155;line-height:1.55}
.notice-panel strong{display:block;color:var(--navy);margin-bottom:4px}
.security-dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--blue));margin-top:6px;flex:0 0 auto;box-shadow:0 0 0 6px rgba(0,194,184,.1)}
.request-list{display:grid;gap:14px;margin-top:20px}
.request-row{display:grid;grid-template-columns:1.3fr .8fr .8fr .55fr;gap:14px;align-items:center;padding:18px;border-radius:22px;background:#fff;border:1px solid rgba(16,33,61,.06);box-shadow:0 12px 26px rgba(15,23,42,.04)}
.request-row h3{margin:0 0 6px;color:var(--navy);font-size:18px;letter-spacing:-.02em}
.request-row p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.status-flow{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.status-flow .step{padding:8px 10px;border-radius:999px;background:#eef4fb;color:#53627a;font-size:12px;font-weight:700}
.status-flow .step.active{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff}
.detail-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:18px}
.timeline{display:grid;gap:12px}
.timeline-item{padding:16px;border-radius:18px;background:#fff;border:1px solid rgba(16,33,61,.06)}
.timeline-item strong{display:block;color:var(--navy);font-size:14px}
.timeline-item p{margin:7px 0 0;color:var(--muted);font-size:14px;line-height:1.6;white-space:pre-wrap}
.message-box{display:grid;gap:12px}
.message-bubble{padding:14px 16px;border-radius:18px;background:#f8fbff;border:1px solid var(--line)}
.message-bubble .meta{font-size:12px;color:var(--muted);margin-bottom:6px}
.notification-panel{display:grid;gap:10px}
.notification-item{padding:14px 16px;border-radius:18px;background:#fff;border:1px solid rgba(16,33,61,.06);display:flex;justify-content:space-between;gap:12px}
.notification-item.unread{border-color:rgba(0,194,184,.35);box-shadow:0 12px 26px rgba(0,194,184,.06)}
.notification-item strong{display:block;color:var(--navy);font-size:14px}
.notification-item span{display:block;color:var(--muted);font-size:13px;margin-top:4px;line-height:1.5}
.kanban-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:18px}
.kanban-col{min-height:160px;border-radius:20px;background:#f8fbff;border:1px solid var(--line);padding:12px}
.kanban-col h4{margin:0 0 12px;color:var(--navy);font-size:13px;text-transform:uppercase;letter-spacing:.06em}
.candidate-card{padding:12px;border-radius:16px;background:#fff;border:1px solid rgba(16,33,61,.07);margin-bottom:10px}
.candidate-card strong{display:block;color:var(--navy);font-size:14px}
.candidate-card span{display:block;color:var(--muted);font-size:12px;margin-top:5px}
.role-note{font-size:12px;color:#b9cae9;line-height:1.45;margin-top:10px}
@media(max-width:980px){.client-shell,.detail-grid{grid-template-columns:1fr}.client-sidebar{position:relative;height:auto}.request-row{grid-template-columns:1fr}.kanban-preview{grid-template-columns:1fr}}


/* v0.2 refined client/workflow layer */
.app-shell{grid-template-columns:280px 1fr;background:#f7f9fc}.sidebar{background:linear-gradient(180deg,#071b49,#08225a);padding:22px 18px}.side-logo{height:56px}.side-tag{font-size:11.5px;opacity:.82}.main{padding:32px}.page-title h1{font-size:28px;font-weight:650}.page-title p{font-size:14px}.card,.stat,.table-card{border-radius:22px;box-shadow:0 14px 34px rgba(7,27,73,.045);border-color:rgba(16,33,61,.055)}.btn{font-weight:650;box-shadow:0 12px 24px rgba(20,106,245,.12)}.btn.small{padding:10px 15px;font-size:13px}.btn.soft{background:#fff;color:var(--navy);border:1px solid var(--line);box-shadow:none}.work-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.workflow-strip{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0 0}.workflow-step{padding:9px 12px;border-radius:999px;background:#f5f8fc;border:1px solid #e8eef6;font-size:12px;font-weight:650;color:#52637b}.workflow-step.on{background:linear-gradient(135deg,rgba(20,106,245,.13),rgba(0,194,184,.13));color:#071b49;border-color:rgba(20,106,245,.18)}.notice-panel{padding:16px 18px;border-radius:20px;background:#fff7ed;border:1px solid #fed7aa;color:#92400e;font-size:14px;line-height:1.55}.notice-panel.ok{background:#ecfdf5;border-color:#bbf7d0;color:#166534}.notice-panel.info{background:#eff6ff;border-color:#bfdbfe;color:#1d4ed8}.license-card{background:linear-gradient(135deg,#071b49,#0b2a67);color:#fff;border-radius:26px;padding:24px;box-shadow:0 24px 60px rgba(7,27,73,.14);position:relative;overflow:hidden}.license-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 82% 10%,rgba(0,194,184,.23),transparent 28%)}.license-card>*{position:relative}.license-code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.14);border-radius:14px;padding:12px 14px;display:inline-flex;margin-top:12px;letter-spacing:.04em}.license-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}.license-meta div{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:13px}.license-meta small{display:block;color:#c9d7f1;font-size:11px;text-transform:uppercase;letter-spacing:.06em;font-weight:700}.license-meta strong{display:block;margin-top:6px;font-weight:650}.client-shell{min-height:100vh;background:#f7f9fc}.client-top{height:76px;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid #e8eef6;display:flex;align-items:center;position:sticky;top:0;z-index:20}.client-top-inner{width:min(1240px,calc(100% - 40px));margin:0 auto;display:flex;align-items:center;justify-content:space-between}.client-brand{display:flex;align-items:center;gap:14px}.client-brand img{height:46px}.client-brand strong{font-weight:650;color:#071b49}.client-nav{display:flex;align-items:center;gap:10px}.client-nav a{padding:10px 13px;border-radius:12px;font-size:13px;font-weight:650;color:#334155}.client-nav a.active,.client-nav a:hover{background:#eef4fb;color:#071b49}.client-main{width:min(1240px,calc(100% - 40px));margin:0 auto;padding:30px 0 54px}.split{display:grid;grid-template-columns:1fr 360px;gap:18px}.message-list{display:grid;gap:12px}.message{padding:14px 16px;border-radius:16px;background:#f8fbff;border:1px solid #e8eef6}.message strong{display:block;color:#071b49;font-size:14px}.message small{display:block;color:#64748b;margin:4px 0 8px}.message p{margin:0;color:#334155;line-height:1.6}.notification-dot{display:inline-flex;min-width:22px;height:22px;align-items:center;justify-content:center;border-radius:999px;background:#00c2b8;color:#06213d;font-size:12px;font-weight:800}.kanban-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.kanban-col{background:#f8fbff;border:1px solid #e8eef6;border-radius:18px;padding:12px}.kanban-col h4{margin:0 0 10px;color:#071b49;font-size:13px}.kanban-card{background:#fff;border:1px solid #e8eef6;border-radius:14px;padding:11px;margin-bottom:8px;font-size:13px;color:#334155}.role-note{font-size:12px;color:#64748b;margin-top:6px;line-height:1.45}@media(max-width:980px){.work-grid,.split{grid-template-columns:1fr}.license-meta,.kanban-preview{grid-template-columns:1fr}.client-nav{display:none}}
