*{box-sizing:border-box} body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#f4f7fb;color:#132033}.layout{display:flex;min-height:100vh}.sidebar{width:260px;background:#101827;color:#fff;padding:18px;position:fixed;left:0;top:0;bottom:0;overflow:auto}.brand{font-size:22px;font-weight:700;margin-bottom:20px}.nav{display:block;color:#d9e5ff;text-decoration:none;padding:11px 12px;border-radius:10px;margin:5px 0}.nav:hover,.nav.active{background:#243758;color:#fff}.nav-title{margin-top:18px;margin-bottom:8px;font-size:12px;text-transform:uppercase;color:#92a4c4}.main{margin-left:260px;width:calc(100% - 260px)}.topbar{height:64px;background:#fff;border-bottom:1px solid #dde5f2;display:flex;align-items:center;justify-content:space-between;padding:0 22px;position:sticky;top:0;z-index:5}.content{padding:22px}.card{background:#fff;border:1px solid #e1e9f4;border-radius:16px;padding:18px;box-shadow:0 6px 18px rgba(21,35,55,.06);margin-bottom:18px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.stat{font-size:28px;font-weight:700}.btn{border:0;border-radius:10px;padding:10px 14px;background:#2563eb;color:#fff;text-decoration:none;cursor:pointer;display:inline-block}.btn.secondary{background:#64748b}.btn.danger{background:#dc2626}.btn.warning{background:#ca8a04}.btn.success{background:#16a34a}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:14px;overflow:hidden}.table th,.table td{border-bottom:1px solid #e7edf6;padding:11px;text-align:left;vertical-align:top}.table th{background:#eef4ff}.alert{padding:12px 14px;border-radius:12px;margin-bottom:14px}.alert-success{background:#dcfce7;color:#14532d}.alert-danger{background:#fee2e2;color:#7f1d1d}.alert-warning{background:#fef3c7;color:#78350f}.alert-info{background:#dbeafe;color:#1e3a8a}.form-row{margin-bottom:14px}.form-row label{display:block;font-weight:600;margin-bottom:6px}.input,select,textarea{width:100%;padding:11px;border:1px solid #cdd8ea;border-radius:10px;background:#fff}.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#e0e7ff;color:#3730a3;font-size:12px}.actions{display:flex;gap:8px;flex-wrap:wrap}.small{font-size:12px;color:#64748b}.code{background:#0f172a;color:#e2e8f0;padding:12px;border-radius:10px;overflow:auto}@media(max-width:780px){.sidebar{position:relative;width:100%;height:auto}.layout{display:block}.main{margin-left:0;width:100%}.topbar{height:auto;gap:8px;align-items:flex-start;flex-direction:column;padding:12px}.content{padding:12px}.table{font-size:13px;display:block;overflow-x:auto}}
.grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:12px 0}.grid2 label{display:flex;flex-direction:column;font-weight:600;gap:6px}.grid2 input,.grid2 select,.grid2 textarea,.inline-form select{padding:10px;border:1px solid #d7dce5;border-radius:10px}.grid2 textarea{min-height:90px}.check{display:flex!important;flex-direction:row!important;align-items:center;gap:8px}.inline{margin-top:28px}.grid2 small{font-weight:400;color:#6b7280}.primary{background:#2563eb;color:#fff}.muted{color:#6b7280}.module-badges{display:flex;gap:6px;flex-wrap:wrap}.badge.soft{background:#eef2ff;color:#3730a3}@media(max-width:760px){.grid2{grid-template-columns:1fr}.inline{margin-top:0}}

/* Settings Center v2.2 */
.settings-hero{background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff;border-radius:24px;padding:24px;margin-bottom:20px;display:flex;justify-content:space-between;gap:16px;align-items:flex-start;box-shadow:0 14px 35px rgba(37,99,235,.22)}
.settings-hero h1{margin:4px 0 8px;font-size:32px;letter-spacing:-.03em}.settings-hero p{margin:0;color:#dbeafe;max-width:780px;line-height:1.55}.settings-hero a{color:#fff;text-decoration:underline}.eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:#bfdbfe;font-weight:700}.hero-status{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;min-width:260px}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;background:rgba(255,255,255,.14);color:#fff;padding:7px 10px;font-size:12px;font-weight:700;border:1px solid rgba(255,255,255,.18)}.pill.good{background:#dcfce7;color:#166534;border-color:#bbf7d0}.pill.warn{background:#fef3c7;color:#92400e;border-color:#fde68a}.pill.off{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.settings-layout{display:grid;grid-template-columns:230px minmax(0,1fr);gap:18px;align-items:start}.settings-tabs{position:sticky;top:80px;background:#fff;border:1px solid #e1e9f4;border-radius:18px;padding:10px;box-shadow:0 6px 18px rgba(21,35,55,.05)}.settings-tabs a{display:block;padding:11px 12px;border-radius:12px;text-decoration:none;color:#334155;font-weight:700;margin:3px 0}.settings-tabs a:hover{background:#eff6ff;color:#1d4ed8}.settings-card{background:#fff;border:1px solid #e1e9f4;border-radius:22px;padding:20px;box-shadow:0 8px 24px rgba(15,23,42,.06);margin-bottom:18px;scroll-margin-top:85px}.settings-card.highlight{border-color:#bfdbfe;box-shadow:0 12px 34px rgba(37,99,235,.10)}.card-title-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:16px}.card-title-row h2{margin:0 0 5px;font-size:21px;color:#0f172a}.card-title-row p{margin:0;color:#64748b;line-height:1.45}.pretty-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.pretty-grid.one-line{grid-template-columns:minmax(220px,420px)}.pretty-grid label{display:flex;flex-direction:column;gap:7px;font-weight:800;color:#1e293b}.pretty-grid input,.pretty-grid select,.pretty-grid textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:12px 13px;background:#f8fafc;color:#0f172a;outline:none;transition:.15s}.pretty-grid input:focus,.pretty-grid select:focus,.pretty-grid textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.12);background:#fff}.pretty-grid small{font-weight:500;color:#64748b;line-height:1.4}.toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:10px 0 16px}.toggle-grid.single{grid-template-columns:1fr}.pretty-toggle{position:relative;display:grid;grid-template-columns:48px 1fr;gap:10px;align-items:center;border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:13px;cursor:pointer;min-height:74px}.pretty-toggle input{display:none}.pretty-toggle span{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;transition:.18s}.pretty-toggle span:after{content:'';position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;left:3px;top:3px;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:.18s}.pretty-toggle input:checked + span{background:#2563eb}.pretty-toggle input:checked + span:after{left:21px}.pretty-toggle b{display:block;color:#0f172a}.pretty-toggle small{display:block;color:#64748b;margin-top:3px;line-height:1.35;font-weight:500}.warning-toggle input:checked + span{background:#f59e0b}.danger-zone .key-status{border:1px dashed #cbd5e1;border-radius:14px;background:#f8fafc;padding:12px;font-weight:700;color:#475569}.mini-check{margin-top:6px!important;display:flex!important;flex-direction:row!important;align-items:center;font-size:13px;font-weight:700!important;color:#b91c1c!important}.mini-check input{width:auto!important}.notice-box{margin-top:14px;background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a;border-radius:16px;padding:14px;line-height:1.5}.settings-actions-sticky{position:sticky;bottom:0;background:rgba(244,247,251,.92);backdrop-filter:blur(10px);border:1px solid #e1e9f4;border-radius:18px;padding:12px;display:flex;gap:10px;justify-content:flex-end;box-shadow:0 -8px 24px rgba(15,23,42,.08)}
@media(max-width:980px){.settings-layout{grid-template-columns:1fr}.settings-tabs{position:relative;top:0;display:flex;overflow-x:auto;gap:8px}.settings-tabs a{white-space:nowrap}.settings-hero{flex-direction:column}.hero-status{justify-content:flex-start}.pretty-grid,.toggle-grid{grid-template-columns:1fr}.settings-actions-sticky{justify-content:stretch}.settings-actions-sticky .btn{flex:1;text-align:center}}

/* v2.3 polish: stronger wrapping, settings width fixes, module-ready design tokens */
:root{
  --bg:#f4f7fb; --card:#ffffff; --text:#122033; --muted:#667085; --line:#e6ebf2;
  --primary:#2563eb; --primary2:#1d4ed8; --danger:#dc2626; --success:#16a34a; --warn:#d97706;
  --radius:18px; --shadow:0 12px 35px rgba(15,23,42,.08);
}
*{box-sizing:border-box}
body{background:var(--bg); color:var(--text); font-family:Inter, system-ui, -apple-system, Segoe UI, Arial, sans-serif;}
.layout{min-height:100vh}.main{min-width:0}.content{max-width:1280px;margin:0 auto;padding:22px;width:100%}
.card,.settings-card{border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);background:var(--card)}
.btn{border-radius:12px;padding:10px 14px;border:1px solid var(--line);text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;white-space:nowrap;cursor:pointer;font-weight:700}
.btn.primary,.btn:not(.secondary):not(.danger){background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover,.btn:not(.secondary):not(.danger):hover{background:var(--primary2)}
.btn.secondary{background:#fff;color:#1f2937}.btn.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);vertical-align:top;overflow-wrap:anywhere}.table th{background:#f8fafc;text-align:left;font-size:13px;color:#475569}.badge{display:inline-flex;padding:4px 8px;border-radius:999px;background:#eef2ff;color:#3730a3;font-weight:700;font-size:12px}
.sidebar{background:#101827;color:#dbeafe}.sidebar .brand{font-weight:900;letter-spacing:.3px}.sidebar .nav{border-radius:12px;margin:3px 10px;color:#dbeafe}.sidebar .nav:hover,.sidebar .nav.active{background:#1d4ed8;color:#fff}.nav-title{color:#93c5fd;margin:18px 14px 8px;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.topbar{background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 12px rgba(15,23,42,.04)}
.alert{border-radius:14px;padding:12px 14px;margin-bottom:14px;overflow-wrap:anywhere}.alert-success{background:#dcfce7;color:#166534}.alert-danger{background:#fee2e2;color:#991b1b}
.settings-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:24px;margin-bottom:18px;background:linear-gradient(135deg,#0f172a,#1e40af);color:#fff;border-radius:24px;box-shadow:var(--shadow)}
.settings-hero h1{margin:4px 0 8px;font-size:30px;line-height:1.15}.settings-hero p{margin:0;color:#dbeafe;max-width:780px;overflow-wrap:anywhere}.settings-hero a{color:#fff;text-decoration:underline}.eyebrow{font-size:12px;text-transform:uppercase;letter-spacing:.12em;color:#bfdbfe;font-weight:800}.hero-status{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;min-width:220px}.pill{display:inline-flex;align-items:center;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.16);font-size:12px;font-weight:800}.pill.good{background:#dcfce7;color:#166534}.pill.warn{background:#fef3c7;color:#92400e}.pill.off{background:#fee2e2;color:#991b1b}
.settings-layout{display:grid;grid-template-columns:245px minmax(0,1fr);gap:18px;align-items:start}.settings-tabs{position:sticky;top:16px;border:1px solid var(--line);background:#fff;border-radius:18px;padding:10px;box-shadow:var(--shadow)}.settings-tabs a{display:block;padding:11px 12px;border-radius:12px;color:#334155;text-decoration:none;font-weight:700;overflow-wrap:anywhere}.settings-tabs a:hover{background:#eff6ff;color:#1d4ed8}.settings-panels{min-width:0}.settings-card{padding:22px;margin-bottom:18px;overflow:hidden}.card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.card-title-row h2{margin:0 0 6px;font-size:21px}.card-title-row p{margin:0;color:var(--muted);overflow-wrap:anywhere;line-height:1.5}.pretty-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.pretty-grid.small-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.pretty-grid label{display:flex;flex-direction:column;gap:7px;font-weight:800;color:#1f2937;min-width:0;overflow-wrap:anywhere}.pretty-grid input,.pretty-grid select,.pretty-grid textarea{width:100%;min-width:0;border:1px solid #d9e2ef;border-radius:12px;padding:12px 13px;font:inherit;background:#fff;color:#111827;outline:none}.pretty-grid input:focus,.pretty-grid select:focus,.pretty-grid textarea:focus{border-color:#60a5fa;box-shadow:0 0 0 4px rgba(37,99,235,.10)}.field-help,.pretty-grid small{font-weight:500;color:var(--muted);font-size:12px;line-height:1.45;overflow-wrap:anywhere}.toggle-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.toggle-grid.single{grid-template-columns:1fr}.pretty-toggle{display:grid;grid-template-columns:42px minmax(0,1fr);gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:16px;padding:14px;background:#fbfdff;min-width:0}.pretty-toggle input{display:none}.pretty-toggle span{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;margin-top:2px;transition:.2s}.pretty-toggle span:before{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:.2s;box-shadow:0 1px 4px rgba(0,0,0,.2)}.pretty-toggle input:checked + span{background:#2563eb}.pretty-toggle input:checked + span:before{transform:translateX(18px)}.pretty-toggle b{display:block;line-height:1.35;overflow-wrap:anywhere}.pretty-toggle small{display:block;color:var(--muted);margin-top:3px;line-height:1.45;overflow-wrap:anywhere}.danger-zone{background:#fff7ed;border:1px solid #fed7aa;border-radius:14px;padding:12px}.key-status{padding:10px 12px;background:#fff;border:1px dashed #f59e0b;border-radius:12px;font-weight:700;color:#92400e;overflow-wrap:anywhere}.mini-check{display:flex!important;flex-direction:row!important;align-items:center!important;gap:8px!important;margin-top:8px!important;font-weight:600!important}.mini-check input{width:auto!important}.notice-box{border:1px solid #bfdbfe;background:#eff6ff;color:#1e3a8a;border-radius:16px;padding:13px 15px;margin-bottom:16px;line-height:1.55;overflow-wrap:anywhere}.settings-actions-sticky{position:sticky;bottom:0;display:flex;gap:10px;justify-content:flex-end;background:rgba(244,247,251,.92);backdrop-filter:blur(8px);padding:14px 0;margin-top:6px;border-top:1px solid var(--line)}
.ai-test-output{white-space:pre-wrap;overflow-wrap:anywhere;background:#0f172a;color:#e2e8f0;border-radius:16px;padding:16px;line-height:1.55;max-height:440px;overflow:auto}.status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.status-card{padding:14px;border:1px solid var(--line);border-radius:16px;background:#fff}.status-card b{display:block;overflow-wrap:anywhere}.status-card small{color:var(--muted);overflow-wrap:anywhere}
@media(max-width:980px){.settings-layout{grid-template-columns:1fr}.settings-tabs{position:relative;top:auto;display:flex;overflow:auto;gap:6px}.settings-tabs a{white-space:nowrap}.pretty-grid,.pretty-grid.small-grid,.toggle-grid{grid-template-columns:1fr}.settings-hero{flex-direction:column}.hero-status{justify-content:flex-start}.content{padding:14px}.card-title-row{flex-direction:column}}
@media(max-width:620px){.settings-card{padding:16px;border-radius:16px}.settings-hero{padding:18px;border-radius:18px}.settings-hero h1{font-size:24px}.settings-actions-sticky{flex-direction:column}.btn{width:100%}.table{font-size:13px}.main{padding-left:0}}
.danger-card{border:1px solid #fecaca;background:#fff7f7}
.error-code{white-space:pre-wrap;word-break:break-word;max-height:420px;overflow:auto;border-left:4px solid #dc2626}
/* Public SaaS portal v2.7 */
.public-page{background:linear-gradient(135deg,#eef6ff,#f8fafc);min-height:100vh}.public-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.public-card{background:#fff;border:1px solid var(--line,#e6ebf2);border-radius:24px;box-shadow:0 18px 50px rgba(15,23,42,.10);padding:26px;margin:18px 0;overflow:hidden}.public-card.big{max-width:820px}.public-card.narrow{max-width:520px;margin:40px auto}.public-card h1{margin:6px 0 10px;font-size:34px;letter-spacing:-.03em}.public-card p{line-height:1.6;color:#475569;overflow-wrap:anywhere}.public-actions{margin:18px 0}.portal-shell{max-width:1180px;margin:0 auto;padding:18px}.portal-top{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff;border:1px solid var(--line,#e6ebf2);border-radius:18px;padding:14px 18px;margin-bottom:18px;box-shadow:0 8px 25px rgba(15,23,42,.06)}.portal-top a{color:#1d4ed8;text-decoration:none;font-weight:700}.plan-card h3{margin-top:0}.single-col{grid-template-columns:1fr!important}.inline-review textarea{width:100%;min-height:62px;border:1px solid #d9e2ef;border-radius:10px;padding:9px;margin-bottom:8px}.payment-method-box{border:1px solid #e6ebf2;border-radius:16px;padding:14px;background:#f8fafc}@media(max-width:700px){.public-card h1{font-size:26px}.portal-top{flex-direction:column;align-items:flex-start}.public-hero{align-items:flex-start}.public-card{padding:18px;border-radius:18px}}
/* v2.8 tenant/AI subscription polish */
.span2{grid-column:1/-1}.check-row{display:flex!important;align-items:center;gap:10px;min-height:42px}.check-row input[type="checkbox"]{width:auto!important}.mono-wrap{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;white-space:normal;overflow-wrap:anywhere}.stat{font-size:32px;font-weight:800;margin:8px 0}.badge.good,.pill.good{background:#dcfce7;color:#166534}.badge.warn,.pill.warn{background:#fef3c7;color:#92400e}.public-card .card{box-shadow:none}.plan-card small{display:block;overflow-wrap:anywhere;color:#64748b;margin-top:4px}
.split-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}.muted{color:#64748b}.settings-card .card-title-row.sub{margin-top:18px;border-top:1px solid #e5e7eb;padding-top:16px}.single-grid{grid-template-columns:1fr}.field-help{display:block;max-width:100%;white-space:normal;overflow-wrap:anywhere}.public-card input,.public-card textarea,.public-card select{max-width:100%}.mono-wrap{white-space:normal;overflow-wrap:anywhere;word-break:break-word}.btn.small{padding:6px 10px;font-size:12px}.btn.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}

/* v3.1 workflow based user panel */
.portal-app-page{background:#f4f7fb;min-height:100vh;color:#122033}.portal-app{display:flex;min-height:100vh}.portal-side{width:280px;background:#0f172a;color:#dbeafe;position:fixed;left:0;top:0;bottom:0;overflow:auto;padding:16px 12px;z-index:30}.portal-brand{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 14px}.portal-brand a{color:#fff;text-decoration:none;font-weight:900;font-size:20px}.portal-menu-close{display:none;background:rgba(255,255,255,.12);color:#fff;border:0;border-radius:10px;width:36px;height:36px;font-size:22px}.portal-company-card{background:linear-gradient(135deg,#1e293b,#1d4ed8);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:14px;margin:4px 6px 14px;box-shadow:0 10px 28px rgba(0,0,0,.18)}.portal-company-name{font-weight:900;color:#fff;overflow-wrap:anywhere}.portal-user-name{font-size:13px;color:#bfdbfe;margin-top:4px;overflow-wrap:anywhere}.portal-mode-badge{margin-top:10px;display:inline-flex;background:#dcfce7;color:#166534;border-radius:999px;padding:5px 8px;font-size:11px;font-weight:900}.portal-mode-badge.locked{background:#fef3c7;color:#92400e}.portal-nav-title{font-size:11px;color:#93c5fd;text-transform:uppercase;letter-spacing:.08em;font-weight:900;margin:16px 12px 6px}.portal-nav-link{display:flex;align-items:center;justify-content:space-between;gap:8px;color:#dbeafe;text-decoration:none;border-radius:13px;padding:11px 12px;margin:3px 4px;font-weight:800}.portal-nav-link:hover,.portal-nav-link.active{background:#1d4ed8;color:#fff}.portal-nav-link em{font-style:normal;font-size:10px;color:#bfdbfe;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:2px 6px}.portal-main{margin-left:280px;min-width:0;width:calc(100% - 280px)}.portal-topbar{height:68px;background:#fff;border-bottom:1px solid #e6ebf2;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0 20px;position:sticky;top:0;z-index:20;box-shadow:0 3px 14px rgba(15,23,42,.04)}.portal-topbar b{display:block;font-size:18px}.portal-topbar small{display:block;color:#64748b;line-height:1.35;max-width:780px;overflow-wrap:anywhere}.portal-menu-btn{display:none;border:1px solid #dbe3ef;border-radius:12px;background:#fff;color:#0f172a;padding:9px 12px;font-weight:900}.portal-top-actions{display:flex;gap:10px;align-items:center}.portal-top-actions a{color:#1d4ed8;text-decoration:none;font-weight:800}.portal-content{padding:22px;max-width:1320px;margin:0 auto}.workspace-hero{background:linear-gradient(135deg,#0f172a,#1d4ed8);border-radius:24px;color:#fff;padding:24px;margin-bottom:18px;display:flex;align-items:flex-start;justify-content:space-between;gap:18px;box-shadow:0 18px 45px rgba(37,99,235,.18)}.workspace-hero.compact{padding:22px}.workspace-hero h1{margin:5px 0 8px;font-size:32px;letter-spacing:-.03em}.workspace-hero p{margin:0;color:#dbeafe;max-width:850px;line-height:1.55;overflow-wrap:anywhere}.action-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:0 0 18px}.quick-action{background:#fff;border:1px solid #e6ebf2;border-radius:18px;padding:16px;text-decoration:none;color:#122033;box-shadow:0 10px 26px rgba(15,23,42,.06);display:flex;flex-direction:column;gap:5px;min-height:96px}.quick-action.primary{background:#1d4ed8;color:#fff}.quick-action.primary span{color:#dbeafe}.quick-action b{font-size:16px}.quick-action span{font-size:13px;color:#64748b;line-height:1.35}.portal-grid{display:grid;gap:16px}.portal-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.portal-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.portal-card,.metric-card,.workflow-card,.empty-state-card{background:#fff;border:1px solid #e6ebf2;border-radius:20px;padding:18px;box-shadow:0 10px 28px rgba(15,23,42,.06);min-width:0;overflow:hidden}.metric-card span{display:block;color:#64748b;font-weight:800;font-size:13px}.metric-card b{font-size:34px;display:block;margin:8px 0;color:#0f172a}.metric-card small{color:#64748b;line-height:1.4}.info-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:12px 0}.info-list.mini{grid-template-columns:1fr}.info-list div{border:1px solid #eef2f7;border-radius:14px;padding:10px;background:#f8fafc}.info-list span{display:block;color:#64748b;font-size:12px;font-weight:800}.info-list b{display:block;margin-top:3px;overflow-wrap:anywhere}.mode-checks{display:flex;gap:8px;flex-wrap:wrap}.mode-checks span{border-radius:999px;padding:7px 10px;font-weight:900;font-size:12px}.mode-checks .on{background:#dcfce7;color:#166534}.mode-checks .off{background:#fee2e2;color:#991b1b}.next-step-list{display:grid;gap:10px}.next-step-list a{display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid #e6ebf2;border-radius:16px;padding:14px;text-decoration:none;color:#122033;background:#f8fafc}.next-step-list b{font-size:15px}.next-step-list span{color:#64748b;line-height:1.35}.workflow-line{display:flex;gap:8px;overflow:auto;padding:6px 0 16px}.workflow-line div{white-space:nowrap;border:1px solid #dbe3ef;background:#fff;border-radius:999px;padding:9px 12px;font-weight:900;color:#475569}.workflow-line .on{background:#1d4ed8;color:#fff;border-color:#1d4ed8}.workflow-card{text-decoration:none;color:#122033;display:flex;flex-direction:column;gap:8px;min-height:132px}.workflow-card b{font-size:18px}.workflow-card span{color:#64748b;line-height:1.45}.module-shortcut{border:1px solid #e6ebf2;border-radius:16px;padding:14px;background:#f8fafc;display:grid;gap:8px}.module-shortcut span{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;color:#64748b;overflow-wrap:anywhere}.empty-inline{grid-column:1/-1;color:#64748b;padding:12px;border:1px dashed #cbd5e1;border-radius:14px}.queue-tabs{display:flex;gap:8px;overflow:auto;margin:0 0 16px}.queue-tabs a{white-space:nowrap;text-decoration:none;color:#334155;background:#fff;border:1px solid #e6ebf2;border-radius:999px;padding:10px 13px;font-weight:900}.queue-tabs a.active{background:#1d4ed8;color:#fff;border-color:#1d4ed8}.empty-state-card{text-align:center;padding:34px;margin-bottom:18px}.empty-state-card .empty-icon{width:58px;height:58px;border-radius:50%;background:#eff6ff;color:#1d4ed8;display:inline-flex;align-items:center;justify-content:center;font-weight:900;font-size:28px;margin-bottom:12px}.empty-state-card p{max-width:720px;margin:0 auto 16px;color:#64748b;line-height:1.55}.table-wrap{overflow:auto}.portal-overlay{display:none}.public-shell{max-width:1180px}
@media(max-width:1150px){.action-strip,.portal-grid.four{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-topbar small{max-width:520px}}
@media(max-width:860px){.portal-side{transform:translateX(-100%);transition:.22s}.portal-app.portal-open .portal-side{transform:translateX(0)}.portal-app.portal-open .portal-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:25}.portal-menu-close,.portal-menu-btn{display:inline-flex;align-items:center;justify-content:center}.portal-main{margin-left:0;width:100%}.portal-topbar{height:auto;min-height:64px;padding:12px}.portal-topbar small{display:none}.portal-content{padding:14px}.workspace-hero{flex-direction:column;border-radius:18px;padding:18px}.workspace-hero h1{font-size:25px}.portal-grid.two,.portal-grid.three,.portal-grid.four,.action-strip{grid-template-columns:1fr}.next-step-list a{flex-direction:column;align-items:flex-start}.portal-top-actions{font-size:13px}.info-list{grid-template-columns:1fr}}

/* v3.2 icon based admin/user menus + workflow progress */
.sidebar .brand{display:flex;align-items:center;gap:10px;margin:0 8px 18px}.brand-icon{width:34px;height:34px;border-radius:13px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.1)}
.sidebar .nav{display:flex;align-items:center;gap:10px;min-width:0}.sidebar .nav span:last-child{min-width:0;overflow-wrap:anywhere}.nav-ico{width:28px;height:28px;flex:0 0 28px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);font-size:15px}.sidebar .nav.active .nav-ico,.sidebar .nav:hover .nav-ico{background:rgba(255,255,255,.18)}
.portal-nav-link{min-width:0}.portal-nav-main{display:flex;align-items:center;gap:10px;min-width:0}.portal-nav-main span{min-width:0;overflow-wrap:anywhere}.portal-nav-ico{width:30px;height:30px;flex:0 0 30px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.09);font-style:normal;font-size:15px}.portal-nav-link.active .portal-nav-ico,.portal-nav-link:hover .portal-nav-ico{background:rgba(255,255,255,.18)}
.qa-icon{width:38px;height:38px;border-radius:15px;display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#1d4ed8;font-size:20px;margin-bottom:3px}.quick-action.primary .qa-icon{background:rgba(255,255,255,.18);color:#fff}.workflow-progress-card{margin-bottom:18px}.progress-percent{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:8px 12px;background:#dcfce7;color:#166534;font-weight:900}.progress-track{height:13px;border-radius:999px;background:#e5e7eb;overflow:hidden;margin:14px 0 18px}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#0f766e);border-radius:999px;transition:width .3s ease}.progress-steps{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.progress-step{border:1px solid #e6ebf2;background:#f8fafc;border-radius:16px;padding:12px;min-width:0}.progress-step .step-icon{width:34px;height:34px;border-radius:13px;display:flex;align-items:center;justify-content:center;background:#e2e8f0;margin-bottom:8px}.progress-step b{display:block;color:#334155;overflow-wrap:anywhere}.progress-step small{display:block;margin-top:4px;color:#64748b;line-height:1.35}.progress-step.done{border-color:#bfdbfe;background:#eff6ff}.progress-step.done .step-icon{background:#2563eb;color:#fff}.progress-step.current{border-color:#fde68a;background:#fffbeb}.progress-step.current .step-icon{background:#f59e0b;color:#fff}.workflow-card:before{content:attr(data-icon);width:42px;height:42px;border-radius:16px;display:flex;align-items:center;justify-content:center;background:#eff6ff;color:#1d4ed8;font-size:22px;margin-bottom:4px}.module-shortcut{position:relative}.module-shortcut:before{content:attr(data-icon);position:absolute;right:14px;top:14px;width:36px;height:36px;border-radius:14px;background:#eef2ff;display:flex;align-items:center;justify-content:center;font-size:18px}
@media(max-width:1150px){.progress-steps{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(max-width:760px){.progress-steps{grid-template-columns:1fr}.workflow-progress-card .card-title-row{align-items:flex-start}.progress-percent{align-self:flex-start}}


/* =========================================================
   v3.4 full responsive admin + user panel polish
   ========================================================= */
html{scroll-behavior:smooth}body{min-width:0}.layout,.admin-layout{width:100%;min-width:0}.brand{display:flex;align-items:center;justify-content:space-between;gap:10px}.brand>span{display:inline-flex;align-items:center;gap:8px;min-width:0}.brand-icon{display:inline-flex;margin-right:4px}.admin-menu-close,.admin-menu-btn,.portal-menu-close,.portal-menu-btn{border:0;cursor:pointer}.admin-menu-close{display:none;width:36px;height:36px;border-radius:12px;background:rgba(255,255,255,.10);color:#fff;font-size:24px;line-height:1}.admin-menu-btn{display:none;width:42px;height:42px;border-radius:14px;background:#eef2ff;color:#1d4ed8;font-size:21px;align-items:center;justify-content:center}.admin-overlay,.portal-overlay{display:none}.topbar{gap:12px}.topbar-title{display:flex;flex-direction:column;line-height:1.2;min-width:0}.topbar-title small{color:#64748b;font-size:12px}.admin-info{white-space:nowrap}.content,.portal-content{overflow-wrap:anywhere}.table-wrap,.responsive-table{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:720px}.card,.portal-card,.settings-card-v3,.settings-card{min-width:0}.actions,.inline-actions-v3{min-width:0}.btn{max-width:100%;text-align:center}.input,select,textarea,input{max-width:100%}.mono-wrap,.code{white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.nav,.portal-nav-link{display:flex;align-items:center;gap:10px;min-width:0}.nav span:last-child,.portal-nav-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-ico,.portal-nav-ico{width:26px;height:26px;min-width:26px;border-radius:10px;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;font-style:normal}.nav.active .nav-ico,.nav:hover .nav-ico{background:rgba(255,255,255,.15)}

/* user portal responsive base */
.portal-app{min-height:100vh;background:#f4f7fb}.portal-side{position:fixed;left:0;top:0;bottom:0;width:286px;background:#101827;color:#dbeafe;overflow:auto;z-index:40;padding:16px}.portal-main{margin-left:286px;min-width:0}.portal-topbar{position:sticky;top:0;z-index:20;min-height:66px;background:#fff;border-bottom:1px solid #dde5f2;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:12px 22px}.portal-topbar>div{min-width:0}.portal-topbar small{display:block;color:#64748b;line-height:1.35}.portal-content{max-width:1280px;margin:0 auto;padding:22px;width:100%}.portal-brand{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.portal-brand a{color:#fff;text-decoration:none;font-weight:900;font-size:18px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-menu-close{display:none;width:36px;height:36px;border-radius:12px;background:rgba(255,255,255,.10);color:#fff;font-size:24px}.portal-menu-btn{display:none;width:42px;height:42px;border-radius:14px;background:#eef2ff;color:#1d4ed8;font-size:21px;align-items:center;justify-content:center;flex:0 0 auto}.portal-company-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);border-radius:18px;padding:14px;margin-bottom:14px}.portal-company-name{font-weight:900;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-user-name{font-size:13px;color:#bfdbfe;margin-top:4px}.portal-mode-badge{display:inline-flex;margin-top:10px;padding:6px 9px;border-radius:999px;background:#dcfce7;color:#166534;font-weight:800;font-size:12px}.portal-mode-badge.locked{background:#fef3c7;color:#92400e}.portal-nav-title{margin:18px 10px 8px;color:#93c5fd;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:900}.portal-nav-link{color:#dbeafe;text-decoration:none;padding:10px 11px;border-radius:14px;margin:4px 0;justify-content:space-between}.portal-nav-link:hover,.portal-nav-link.active{background:#1d4ed8;color:#fff}.portal-nav-main{display:inline-flex;align-items:center;gap:10px;min-width:0}.portal-nav-link em{font-size:10px;color:#bfdbfe;font-style:normal;background:rgba(255,255,255,.10);padding:3px 6px;border-radius:999px;flex:0 0 auto}.portal-top-actions{display:flex;gap:10px;align-items:center;white-space:nowrap}.portal-top-actions a{color:#1d4ed8;text-decoration:none;font-weight:800}.portal-grid{display:grid;gap:16px}.portal-grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.portal-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}.portal-grid.four{grid-template-columns:repeat(4,minmax(0,1fr))}.workspace-hero{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;background:linear-gradient(135deg,#0f172a,#1d4ed8);color:#fff;border-radius:26px;padding:26px;margin-bottom:18px;box-shadow:0 14px 35px rgba(37,99,235,.18)}.workspace-hero h1{margin:6px 0 8px;font-size:30px}.workspace-hero p{margin:0;color:#dbeafe;line-height:1.55;max-width:780px}.hero-status{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.pill{white-space:nowrap}.action-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin:16px 0}.quick-action{display:flex;flex-direction:column;gap:5px;text-decoration:none;border:1px solid #e1e9f4;background:#fff;border-radius:18px;padding:16px;color:#132033;box-shadow:0 8px 24px rgba(15,23,42,.06);min-width:0}.quick-action.primary{background:#eff6ff;border-color:#bfdbfe}.quick-action span:last-child{color:#64748b;font-size:13px}.qa-icon{font-size:24px}.metric-card,.portal-card{background:#fff;border:1px solid #e1e9f4;border-radius:18px;padding:16px;box-shadow:0 8px 24px rgba(15,23,42,.06);min-width:0}.metric-card span{color:#64748b}.metric-card b{display:block;font-size:28px;margin:7px 0}.info-list{display:grid;gap:8px}.info-list div{display:flex;justify-content:space-between;gap:10px;border-bottom:1px dashed #e2e8f0;padding:7px 0}.info-list span{color:#64748b}.mode-checks{display:flex;gap:8px;flex-wrap:wrap}.mode-checks span{padding:7px 10px;border-radius:999px;font-weight:800;font-size:12px}.mode-checks .on{background:#dcfce7;color:#166534}.mode-checks .off{background:#fee2e2;color:#991b1b}.card-title-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px}.next-step-list{display:grid;gap:10px}.next-step-list a{display:block;text-decoration:none;color:#132033;border:1px solid #e2e8f0;border-radius:15px;padding:13px}.next-step-list span{display:block;color:#64748b;margin-top:4px}.workflow-progress-card{overflow:hidden}.progress-percent{font-weight:900;background:#eef2ff;color:#3730a3;border-radius:999px;padding:7px 10px;white-space:nowrap}.progress-track{height:10px;background:#e2e8f0;border-radius:999px;overflow:hidden;margin:14px 0}.progress-track span{display:block;height:100%;background:linear-gradient(90deg,#2563eb,#16a34a);border-radius:inherit}.progress-steps{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}.progress-step{border:1px solid #e2e8f0;background:#f8fafc;border-radius:16px;padding:12px;min-width:0}.progress-step.done{background:#dcfce7;border-color:#bbf7d0}.progress-step.current{background:#eff6ff;border-color:#bfdbfe}.progress-step b,.progress-step small{display:block;overflow:hidden;text-overflow:ellipsis}.progress-step small{color:#64748b;margin-top:3px}.step-icon{display:inline-flex;font-size:20px;margin-bottom:5px}.module-shortcut:before{content:attr(data-icon);display:inline-flex;font-size:24px;margin-bottom:8px}.module-shortcut{background:#fff;border:1px solid #e1e9f4;border-radius:18px;padding:16px;box-shadow:0 8px 24px rgba(15,23,42,.06);min-width:0}.module-shortcut b,.module-shortcut span{display:block;overflow-wrap:anywhere}.module-shortcut span{color:#64748b;margin:4px 0 12px}.public-shell{max-width:1060px;margin:0 auto;padding:20px}.portal-top{display:flex;justify-content:space-between;gap:14px;align-items:center;background:#fff;border:1px solid #e1e9f4;border-radius:18px;padding:14px;margin-bottom:16px}.portal-top a{text-decoration:none;color:#1d4ed8}

/* tablet */
@media(max-width:1180px){.content,.portal-content{padding:18px}.portal-grid.four,.action-strip{grid-template-columns:repeat(2,minmax(0,1fr))}.progress-steps{grid-template-columns:repeat(4,minmax(0,1fr))}.settings-v3{padding-left:0;padding-right:0}}
@media(max-width:980px){.sidebar{width:286px;position:fixed;transform:translateX(-105%);transition:transform .22s ease;z-index:50;box-shadow:18px 0 45px rgba(15,23,42,.30)}.admin-layout.admin-open .sidebar{transform:translateX(0)}.admin-menu-close,.admin-menu-btn{display:inline-flex}.main{margin-left:0!important;width:100%!important}.admin-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.50);z-index:45;opacity:0;pointer-events:none;transition:.2s}.admin-layout.admin-open .admin-overlay{opacity:1;pointer-events:auto}.topbar{height:auto;min-height:62px;align-items:center;position:sticky;top:0;z-index:30}.admin-info{font-size:13px}.portal-side{transform:translateX(-105%);transition:transform .22s ease;box-shadow:18px 0 45px rgba(15,23,42,.30)}.portal-app.portal-open .portal-side{transform:translateX(0)}.portal-overlay{display:block;position:fixed;inset:0;background:rgba(15,23,42,.50);z-index:35;opacity:0;pointer-events:none;transition:.2s}.portal-app.portal-open .portal-overlay{opacity:1;pointer-events:auto}.portal-main{margin-left:0}.portal-menu-btn,.portal-menu-close{display:inline-flex}.portal-topbar{padding:11px 16px}.portal-top-actions a:first-child{display:none}.workspace-hero{flex-direction:column}.hero-status{justify-content:flex-start}.portal-grid.three{grid-template-columns:repeat(2,minmax(0,1fr))}.table{min-width:820px}.settings-shell-v3,.settings-layout{grid-template-columns:1fr!important}.settings-nav-v3,.settings-tabs{position:relative!important;top:auto!important;display:flex!important;overflow-x:auto!important;gap:8px!important;white-space:nowrap!important}.settings-nav-v3 a,.settings-tabs a{flex:0 0 auto!important}}

/* mobile */
@media(max-width:700px){body{font-size:14px}.content,.portal-content{padding:12px}.topbar{padding:10px 12px}.topbar-title strong{font-size:15px}.admin-info{white-space:normal;text-align:right}.sidebar,.portal-side{width:min(88vw,320px);padding:14px}.card,.portal-card,.metric-card,.module-shortcut{border-radius:16px;padding:14px}.grid,.portal-grid.two,.portal-grid.three,.portal-grid.four,.action-strip,.pretty-grid,.form-grid-v3,.form-grid-v3.three,.grid2{grid-template-columns:1fr!important}.workspace-hero{border-radius:20px;padding:20px}.workspace-hero h1{font-size:24px}.hero-status{width:100%}.pill,.badge-v3{white-space:normal}.card-title-row{flex-direction:column;align-items:stretch}.progress-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.progress-step{padding:10px}.table th,.table td{padding:10px}.actions,.inline-actions-v3{gap:7px}.actions .btn,.inline-actions-v3 .btn,.btn-v3{width:100%;white-space:normal}.portal-top{flex-direction:column;align-items:flex-start}.portal-top>div{width:100%;display:flex;flex-wrap:wrap;gap:8px}.settings-hero-v3,.settings-hero{border-radius:20px;padding:20px}.settings-hero-v3 h1,.settings-hero h1{font-size:25px}.form-row{margin-bottom:12px}.input,select,textarea,.field-v3 input,.field-v3 select,.field-v3 textarea{font-size:16px}.savebar-v3,.settings-actions-sticky{position:relative;bottom:auto;flex-direction:column}.savebar-v3 .inline-actions-v3{width:100%}.info-list div{flex-direction:column;gap:2px}.module-badges{gap:5px}}
@media(max-width:420px){.progress-steps{grid-template-columns:1fr}.topbar{gap:8px}.admin-menu-btn,.portal-menu-btn{width:38px;height:38px}.metric-card b{font-size:24px}.sidebar,.portal-side{width:92vw}.settings-nav-v3 a,.settings-tabs a{font-size:13px;padding:10px}.btn{padding:9px 11px}}
