:root {
  --brand: #008573;
  --brand-dark: #006d5e;
  --ink: #0f172a;
  --muted: #64748b;
  --line: #e2e8f0;
  --bg: #f8fafc;
  --panel: #ffffff;
  --ok: #059669;
  --warn: #d97706;
  --err: #dc2626;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Inter',sans-serif;color:var(--ink);background:var(--bg)}
.portal-shell{min-height:100vh;background:radial-gradient(circle at top right,rgba(0,133,115,.08),transparent 44%),var(--bg)}
.portal-header{background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40}
.portal-nav-link{color:#334155;font-weight:600;font-size:.95rem}.portal-nav-link:hover{color:var(--brand)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:16px}
.input-label{display:block;font-size:.9rem;font-weight:600;color:#334155;margin-bottom:8px}
.input-field{width:100%;padding:12px 14px;border:1px solid #cbd5e1;border-radius:10px;font-size:.95rem;color:#0f172a;background:#fff}
.input-label.compact{font-size:.78rem;margin-bottom:5px}
.input-field.compact{padding:8px 10px;font-size:.83rem;border-radius:8px}
.input-field:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px rgba(0,133,115,.15)}
.tab-btn{border:0;border-radius:10px;padding:11px 16px;font-weight:700;font-size:.95rem;color:#475569;background:transparent}
.tab-btn.active{background:var(--brand);color:#fff}
.step-dot{width:30px;height:30px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;background:#e2e8f0;color:#475569}
.step-dot.active{background:var(--brand);color:#fff}.step-dot.done{background:var(--ok);color:#fff}.hidden-step{display:none}
.comparison-table th,.comparison-table td{border-bottom:1px solid var(--line);padding:12px;font-size:.9rem}
.badge-in{color:#065f46;font-weight:700}.badge-out{color:#94a3b8}
.portal-footer{margin-top:56px;background:linear-gradient(135deg,#008573 0%,#006d5e 100%);color:#fff}
.portal-layout{max-width:1320px;margin:0 auto;padding:20px 16px 28px;display:grid;grid-template-columns:280px 1fr;gap:18px}
.sidebar{background:linear-gradient(180deg,#0b3f3b 0%,#0f172a 100%);color:#e2e8f0;border-radius:18px;padding:18px;height:calc(100vh - 108px);position:sticky;top:86px}
.sidebar h2{margin:0;font-size:1rem;color:#fff}.sidebar .sub{font-size:.78rem;color:#99b5bc;margin-top:4px}
.side-group{margin-top:18px}.side-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:#89a2a9;margin:8px 10px}
.side-link{display:block;text-decoration:none;color:#d6e3e7;font-size:.9rem;font-weight:600;padding:10px 12px;border-radius:10px}
.side-link:hover,.side-link.active{background:rgba(0,133,115,.35);color:#fff}
.content-col{min-width:0}.topbar{background:var(--panel);border:1px solid var(--line);border-radius:16px;padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.kpi-grid{margin-top:14px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.kpi-card{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:14px}
.kpi-label{font-size:.8rem;color:#64748b}.kpi-value{font-size:1.35rem;font-weight:800;margin-top:6px}.kpi-meta{font-size:.78rem;color:#64748b;margin-top:4px}
.section-grid{margin-top:14px;display:grid;grid-template-columns:2fr 1fr;gap:12px}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid var(--line);font-size:.88rem}.table th{text-align:left;color:#475569;font-weight:700}
.tag{display:inline-block;border-radius:999px;font-size:.73rem;font-weight:700;padding:4px 10px}.tag.ok{background:#d1fae5;color:#065f46}.tag.warn{background:#ffedd5;color:#9a3412}.tag.info{background:#dbeafe;color:#1e3a8a}
.action-btn{display:block;width:100%;border:1px solid #cbd5e1;background:#fff;color:#0f172a;border-radius:10px;padding:10px;text-align:left;font-size:.86rem;font-weight:600;text-decoration:none}
.action-btn:hover{border-color:var(--brand);color:var(--brand)}
.stack>*+*{margin-top:8px}
.page-title{font-size:1.35rem;font-weight:800}.page-sub{font-size:.88rem;color:#64748b}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.select-field{padding:9px 11px;border:1px solid #cbd5e1;border-radius:9px;background:#fff;font-size:.85rem;color:#334155}
.skeleton{position:relative;overflow:hidden;background:#e2e8f0;border-radius:8px}
.skeleton::after{content:'';position:absolute;inset:0;transform:translateX(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:skeleton 1.2s infinite}
@keyframes skeleton{100%{transform:translateX(100%)}}
.empty-state{border:1px dashed #cbd5e1;border-radius:12px;padding:20px;text-align:center;color:#64748b;font-size:.9rem}
.modal{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;z-index:100}
.modal.open{display:flex}
.modal-panel{width:min(860px,92vw);max-height:86vh;overflow:auto;background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:18px}
.modal-close{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:6px 10px;font-size:.8rem}
.readonly-note{font-size:.8rem;color:#9a3412;background:#ffedd5;border:1px solid #fed7aa;padding:7px 10px;border-radius:8px}
.link-action{color:var(--brand);font-weight:600;font-size:.86rem;text-decoration:none}
.link-action:hover{text-decoration:underline}
.dots-menu{position:relative;display:inline-block}
.dots-btn{border:1px solid #cbd5e1;background:#fff;border-radius:8px;padding:4px 10px;font-size:1rem;line-height:1;cursor:pointer}
.dots-dropdown{position:absolute;right:0;top:36px;min-width:180px;background:#fff;border:1px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 24px rgba(15,23,42,.14);padding:6px;display:none;z-index:30}
.dots-dropdown.open{display:block}
.dots-item{display:block;width:100%;text-align:left;border:0;background:transparent;border-radius:8px;padding:8px 10px;font-size:.84rem;color:#0f172a;cursor:pointer}
.dots-item:hover{background:#f1f5f9}

/* Login layout aligned with suite pages visual scale */
.login-grid{
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:24px 16px 28px;
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:16px;
  align-items:start;
}
.login-grid > *{width:100%}
.login-card{min-height:100%}

/* Brand utility classes (stable, no Tailwind arbitrary syntax dependency) */
.bg-brand{background-color:#008573!important}
.bg-brand-dark{background-color:#006d5e!important}
.bg-brand-10{background-color:rgba(0,133,115,.10)!important}
.text-brand{color:#008573!important}
.border-brand{border-color:#008573!important}
.bg-ink-dark{background-color:#302f2f!important}
.text-ink-dark{color:#302f2f!important}

.hover-bg-brand:hover{background-color:#008573!important}
.hover-bg-brand-dark:hover{background-color:#006d5e!important}
.hover-text-brand:hover{color:#008573!important}
.hover-text-white:hover{color:#fff!important}
.focus-border-brand:focus{border-color:#008573!important}

.bg-white-10{background-color:rgba(255,255,255,.10)!important}
.bg-white-15{background-color:rgba(255,255,255,.15)!important}
.bg-white-20{background-color:rgba(255,255,255,.20)!important}
.text-white-60{color:rgba(255,255,255,.60)!important}
.text-white-80{color:rgba(255,255,255,.80)!important}
.text-white-90{color:rgba(255,255,255,.90)!important}
.text-white-95{color:rgba(255,255,255,.95)!important}
.border-white-15{border-color:rgba(255,255,255,.15)!important}
.border-white-20{border-color:rgba(255,255,255,.20)!important}

.from-brand{--brand-grad-from:#008573}
.to-brand-dark{--brand-grad-to:#006d5e}
.bg-gradient-to-r.from-brand.to-brand-dark{background-image:linear-gradient(to right,var(--brand-grad-from),var(--brand-grad-to))!important}
.bg-gradient-to-b.from-brand.to-brand-dark{background-image:linear-gradient(to bottom,var(--brand-grad-from),var(--brand-grad-to))!important}
.bg-gradient-to-br.from-brand.to-brand-dark{background-image:linear-gradient(to bottom right,var(--brand-grad-from),var(--brand-grad-to))!important}

/* Fallbacks for arbitrary Tailwind color classes when using CDN v2 */
.bg-\[\#008573\]{background-color:#008573!important}
.bg-\[\#006d5e\]{background-color:#006d5e!important}
.bg-\[\#302f2f\]{background-color:#302f2f!important}
.hover\:bg-\[\#006d5e\]:hover{background-color:#006d5e!important}
.text-\[\#008573\]{color:#008573!important}
.text-\[\#302f2f\]{color:#302f2f!important}
.border-\[\#008573\]{border-color:#008573!important}
.bg-\[\#008573\]\/10{background-color:rgba(0,133,115,.1)!important}

.bg-\[\#0f766e\]{background-color:#0f766e!important}
.hover\:bg-\[\#115e59\]:hover{background-color:#115e59!important}
.text-\[\#0f766e\]{color:#0f766e!important}
.border-\[\#0f766e\]{border-color:#0f766e!important}

.bg-\[\#0f172a\]{background-color:#0f172a!important}
.text-\[\#0f172a\]{color:#0f172a!important}

/* Opacity class fallbacks used by suite landing page */
.bg-white\/10{background-color:rgba(255,255,255,.10)!important}
.bg-white\/15{background-color:rgba(255,255,255,.15)!important}
.bg-white\/20{background-color:rgba(255,255,255,.20)!important}
.text-white\/60{color:rgba(255,255,255,.60)!important}
.text-white\/80{color:rgba(255,255,255,.80)!important}
.text-white\/90{color:rgba(255,255,255,.90)!important}
.text-white\/95{color:rgba(255,255,255,.95)!important}
.border-white\/15{border-color:rgba(255,255,255,.15)!important}
.border-white\/20{border-color:rgba(255,255,255,.20)!important}

/* Gradient fallbacks for Tailwind v2 + arbitrary colors */
.bg-gradient-to-r.from-\[\#008573\].to-\[\#006d5e\]{background-image:linear-gradient(to right,#008573,#006d5e)!important}
.bg-gradient-to-b.from-\[\#008573\].to-\[\#006d5e\]{background-image:linear-gradient(to bottom,#008573,#006d5e)!important}
.bg-gradient-to-br.from-\[\#008573\].to-\[\#006d5e\]{background-image:linear-gradient(to bottom right,#008573,#006d5e)!important}

/* Plans page: keep all cards in one row on desktop + stable custom card background */
.plans-grid{display:grid;grid-template-columns:1fr;gap:1.5rem}
.plan-card-custom{background:linear-gradient(135deg,#008573 0%,#006d5e 100%)!important}

@media(min-width:768px){.plans-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.plans-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media(max-width:1100px){.portal-layout{grid-template-columns:1fr}.sidebar{height:auto;position:static}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.section-grid{grid-template-columns:1fr}.login-grid{grid-template-columns:1fr;max-width:760px;padding:18px 16px 24px}}
@media(max-width:640px){.kpi-grid{grid-template-columns:1fr}}
