
:root{
  color-scheme: light;
  /* Nizam Foundation: typography */
  --font-sans:'Manrope','Segoe UI',system-ui,sans-serif;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --type-font-sans: var(--font-sans);
  --type-font-display: var(--font-display);
  --type-font-mono: ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;
  /* Nizam Foundation: color — neutral-first, teal accent */
  --bg-base:#F8FBFC;
  --bg-muted:#F3F6F9;
  --bg-raised:#FFFFFF;
  --bg-overlay:#F6FAFB;
  --bg-hover:#EEF2F5;
  --surface:var(--bg-raised);
  --surface-2:var(--bg-muted);
  --surface-3:var(--bg-overlay);
  --glass:rgba(255,255,255,.92);
  --border:#E6EDF3;
  --border-strong:#D1DCE6;
  --border-muted:rgba(15,23,42,.08);
  --text:#0F172A;
  --text-muted:#64748B;
  --text-faint:#94A3B8;
  --accent:#2F9696;
  --accent-hover:#237E7E;
  --accent-dark:#1A6B6B;
  --accent-soft:#E7F6F5;
  --accent-gold:#D97706;
  --accent-gold-soft:#FFF7ED;
  --danger:#DC2626;
  --danger-soft:#FEF2F2;
  --success:#16A34A;
  --success-soft:#ECFDF5;
  --warning:#D97706;
  --warning-soft:#FFF7ED;
  --info:#2563EB;
  --info-soft:#EFF6FF;
  --pattern-ink:rgba(47,150,150,.04);
  --bg-glow-1: transparent;
  --bg-glow-2: transparent;
  /* Marketing page aliases (match Nizam theme) */
  --mk-font-display: var(--font-display);
  --mk-ink: var(--text);
  --mk-muted: var(--text-muted);
  --mk-soft: var(--text-faint);
  --mk-primary: var(--accent);
  --mk-primary-strong: var(--accent-dark);
  --mk-card: var(--bg-raised);
  --mk-border: var(--border);
  --mk-border-strong: var(--border-strong);
  --mk-page-line: var(--border);
  /* Nizam Foundation: spacing (8px base), radius (cards 14–16px), shadow (minimal) */
  --space-0:0;
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-8:32px;
  --space-10:40px;
  --space-12:48px;
  --space-16:64px;
  --space-20:80px;
  --space-24:96px;
  --space-32:128px;
  --radius-xs:4px;
  --radius-sm:8px;
  --radius-md:12px;
  --radius-lg:14px;
  --radius-xl:16px;
  --radius-2xl:20px;
  --radius-full:999px;
  --shadow-xs:0 1px 2px rgba(15,23,42,.04);
  --shadow-card:0 2px 8px rgba(15,23,42,.06);
  --shadow-modal:0 8px 24px rgba(15,23,42,.08);
  --shadow-soft:var(--shadow-card);
  --shadow-lift:var(--shadow-modal);
  --shadow:var(--shadow-card);
  --shadow-sm:var(--shadow-xs);
  /* Layout: flush sidebar + centered main */
  --sidebar-w:280px;
  --sidebar-w-collapsed:88px;
  --topbar-h:56px;
  --content-max:1200px;
  --main-padding:32px;
  /* Token aliases */
  --color-brand-primary: var(--accent);
  --color-brand-accent: var(--accent-soft);
  --color-bg-default: var(--bg-base);
  --color-bg-subtle: var(--bg-muted);
  --color-bg-elevated: var(--bg-raised);
  --color-bg-overlay: var(--bg-overlay);
  --color-text-primary: var(--text);
  --color-text-secondary: var(--text-muted);
  --color-text-muted: var(--text-faint);
  --color-text-inverse: #fff;
  --color-border-default: var(--border);
  --color-border-muted: var(--border-strong);
  --color-divider: var(--border);
  --color-state-success: var(--success);
  --color-state-warning: var(--warning);
  --color-state-danger: var(--danger);
  --color-state-info: var(--info);
  --color-focus-ring: rgba(47,150,150,.25);
  --color-focus-ring-strong: rgba(47,150,150,.4);
  --type-size-xs:.75rem;
  --type-size-sm:.875rem;
  --type-size-md:1rem;
  --type-size-lg:1.125rem;
  --type-size-xl:1.25rem;
  --type-size-2xl:1.5rem;
  --type-size-hero:2rem;
  --type-size-display:2.75rem;
  --type-weight-regular:400;
  --type-weight-medium:500;
  --type-weight-semibold:600;
  --type-weight-bold:700;
  --type-line-tight:1.2;
  --type-line-normal:1.5;
  --type-line-relaxed:1.6;
  --type-letter-tight:-.02em;
  --type-letter-normal:0;
  --duration-80:80ms;
  --duration-120:120ms;
  --duration-180:180ms;
  --duration-240:240ms;
  --easing-standard: cubic-bezier(.2,.0,.0,1);
  --easing-decelerate: cubic-bezier(0,.0,.2,1);
  --easing-accelerate: cubic-bezier(.4,0,1,1);
}
[data-theme="dark"]{
  color-scheme: dark;
  --bg-base:#0b1220;
  --bg-muted:#0f172a;
  --bg-raised:#151f33;
  --bg-overlay:#0f1a2e;
  --bg-hover:#1a2840;
  --surface:var(--bg-raised);
  --surface-2:#0f1a2e;
  --surface-3:#0c162b;
  --glass:rgba(15,23,42,.85);
  --border:rgba(148,163,184,.18);
  --border-strong:rgba(148,163,184,.26);
  --border-muted:rgba(226,232,240,.10);
  --text:#e2e8f0;
  --text-muted:#94a3b8;
  --text-faint:#64748b;
  --accent:#2dd4bf;
  --accent-hover:#5eead4;
  --accent-dark:#14b8a6;
  --accent-soft:rgba(45,212,191,.18);
  --accent-gold:#f6c177;
  --accent-gold-soft:rgba(246,193,119,.14);
  --danger:#fb7185;
  --danger-soft:rgba(251,113,133,.15);
  --success:#34d399;
  --success-soft:rgba(52,211,153,.15);
  --warning:#fbbf24;
  --warning-soft:rgba(251,191,36,.14);
  --info:#60a5fa;
  --info-soft:rgba(96,165,250,.14);
  --shadow:0 12px 32px rgba(0,0,0,.45);
  --shadow-soft:0 8px 24px rgba(0,0,0,.35);
  --shadow-lift:0 16px 40px rgba(0,0,0,.55);
  --shadow-card:0 8px 24px rgba(0,0,0,.38);
  --bg-glow-1: rgba(45,212,191,.08);
  --bg-glow-2: rgba(96,165,250,.06);
}
*{box-sizing:border-box}
html{font-size:16px}
body{margin:0;font-family:var(--font-sans);color:var(--text);background:var(--bg-base);line-height:1.55;min-height:100vh}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
button,select,input,textarea{font:inherit}
:focus{outline:none}
:focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring)}
kbd{font-size:.8rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:6px 8px;border-radius:8px;border:1px solid var(--border);background:var(--bg-overlay);color:var(--text-muted)}
.skip-link{position:absolute;left:-9999px;top:8px;background:var(--bg-raised);border:1px solid var(--border);border-radius:999px;padding:10px 14px;box-shadow:var(--shadow-sm);color:var(--text);z-index:999}
.skip-link:focus{left:12px}

/* Auth / login */
.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 18px}
.login-panel{width:min(520px,92vw);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-soft);padding:28px 26px}
.login-panel .brand{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}
.login-panel .brand .mark{font-family:var(--font-display);font-size:2rem;color:var(--accent);letter-spacing:-.02em}
.login-panel p{margin:8px 0}
.stack{display:flex;flex-direction:column;gap:12px}
.field label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-block{display:block;width:100%}
.divider-row{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--text-faint);font-size:.85rem}
.divider-row:before,.divider-row:after{content:"";height:1px;flex:1;background:var(--border)}

.hidden{display:none!important}
.muted{color:var(--text-muted)}
.danger-text{color:var(--danger)}
.heading-1{font-family:var(--font-sans);font-size:1.5rem;letter-spacing:-.01em;line-height:1.25;margin:0 0 10px;font-weight:700}
.heading-2{font-family:var(--font-sans);font-size:1.25rem;letter-spacing:-.01em;line-height:1.3;margin:0 0 10px;font-weight:700}
.heading-3{font-family:var(--font-sans);font-size:1rem;margin:0 0 8px;font-weight:650}
.eyebrow{font-size:.75rem;color:var(--accent-gold);text-transform:uppercase;letter-spacing:.18em;margin:0 0 10px;font-weight:600}
.section-title{font-family:var(--font-sans);font-size:1rem;font-weight:600;letter-spacing:-.01em;margin:0 0 12px;color:var(--text)}
.section-title::after{content:"";display:block;width:40px;height:2px;border-radius:999px;margin-top:8px;background:var(--accent)}
.divider{height:1px;background:var(--border);margin:14px 0}
.panel{position:relative;overflow:hidden;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:18px}
.panel::after{content:"";display:none}
.hero{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-bottom:20px}
.hero-card{min-height:180px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:20px;position:relative}
.hero-card::before{content:"";display:none}
.hero-card > *{position:relative}
.hero-card h1{font-family:var(--font-display);font-size:2.35rem;letter-spacing:-.02em;line-height:1.12;margin:0 0 10px}
.hero-card h2{font-family:var(--font-display);font-size:1.7rem;letter-spacing:-.01em;line-height:1.18;margin:0 0 10px}
.hero-card p{margin:0;color:var(--text-muted)}
.hero-card p + p{margin-top:10px}
.hero-card .stack{gap:10px}
.notice{border:1px solid var(--border);background:rgba(37,99,235,.06);border-radius:var(--radius-md);padding:12px 14px;box-shadow:var(--shadow-xs);color:var(--text);font-size:.85rem}
.notice.error{border-color:rgba(180,35,24,.35);background:rgba(180,35,24,.10);color:var(--danger)}
.notice.success{border-color:rgba(6,118,71,.28);background:rgba(6,118,71,.10);color:var(--success)}

/* Utilities (keep CSP style-src strict) */
.mt-4{margin-top:4px}
.mt-8{margin-top:8px}
.mt-12{margin-top:12px}
.mt-16{margin-top:16px}
.mt-20{margin-top:20px}
.mt-24{margin-top:24px}
.mt-28{margin-top:28px}
.mb-8{margin-bottom:8px}
.mb-12{margin-bottom:12px}
.mb-16{margin-bottom:16px}
.p-16{padding:16px}
.p-32{padding:32px}
.pad-8-12{padding:8px 12px}
.fs-13{font-size:.8125rem}
.fs-14{font-size:.875rem}
.flex{display:flex}
.flex-between{display:flex;justify-content:space-between}
.flex-wrap{flex-wrap:wrap}
.align-center{align-items:center}
.flex-1{flex:1}
.gap-6{gap:6px}
.gap-8{gap:8px}
.gap-10{gap:10px}
.gap-12{gap:12px}
.gap-16{gap:16px}
.grid{display:grid}
.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.small{font-size:.8rem}
.w-auto{width:auto}
.overflow-auto{overflow:auto}
.py-8{padding:8px 0}
.py-12{padding:12px 0}
.my-0{margin:0}
.pl-20{padding-left:20px}
.border-b{border-bottom:1px solid var(--border)}
.fw-600{font-weight:600}
.pre-wrap{white-space:pre-wrap}
.input-compact{width:auto;padding:6px 10px}
.card-link{display:block;margin-bottom:12px;text-decoration:none;color:inherit}
.link-block{display:block;text-decoration:none;color:inherit}
.minw-260{min-width:260px}
.maxw-400{max-width:400px}
.label-block{display:block}
.label{display:block;font-size:.85rem;color:var(--text-muted);margin-bottom:6px}
.row{display:flex;align-items:center;gap:8px}

/* Loading skeleton */
.skeleton{background:linear-gradient(90deg,var(--bg-muted),var(--bg-overlay),var(--bg-muted));background-size:200% 100%;border-radius:var(--radius-md);animation:shim 1.4s ease-in-out infinite}
.skeleton.h-16{height:16px}
.skeleton.h-28{height:28px}
.skeleton.w-60{width:60%}
.skeleton.w-70{width:70%}
.skeleton.w-90{width:90%}
.skeleton.mb-8{margin-bottom:8px}
.skeleton.mb-16{margin-bottom:16px}
@keyframes shim{0%{background-position:200% 0}100%{background-position:-200% 0}}

.app-shell{display:flex;flex-direction:column;min-height:100vh}
.app-topbar{height:var(--topbar-h);background:var(--bg-raised);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;padding:0 16px;position:sticky;top:0;z-index:100;box-shadow:none}
.app-topbar-brand{font-family:var(--font-sans);font-size:1.05rem;text-decoration:none;color:var(--text);font-weight:800;letter-spacing:-.01em}
.app-topbar-search-trigger{flex:1;max-width:620px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:var(--bg-overlay);border:1px solid var(--border);border-radius:12px;cursor:pointer;color:var(--text-faint);box-shadow:none}
.app-topbar-search-trigger:hover{background:var(--bg-hover);color:var(--text)}
.app-topbar-actions{display:flex;align-items:center;gap:8px}
.app-topbar-spacer{flex:1}
.topbar-ws-select{width:auto;max-width:180px;padding:6px 10px;margin:0}
#notif-badge{position:absolute;top:4px;right:4px;display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 5px;border-radius:999px;background:var(--danger);color:#fff;font-size:.7rem;font-weight:700;line-height:1}
.topbar-user{font-size:.875rem;color:var(--text-muted);font-weight:600;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Topbar icon buttons */
.btn-icon{width:36px;height:36px;padding:0;display:inline-flex;align-items:center;justify-content:center;position:relative}
.btn-icon .icon{display:inline-flex;align-items:center;justify-content:center}
.btn-icon svg{display:block}

.app-body{display:flex;min-height:calc(100vh - var(--topbar-h))}
.app-sidebar{width:var(--sidebar-w);background:var(--bg-overlay);border-right:1px solid var(--border);padding:16px 12px;position:sticky;top:var(--topbar-h);height:calc(100vh - var(--topbar-h));overflow:auto;flex-shrink:0}
.app-sidebar-nav{display:flex;flex-direction:column;gap:2px}
.nav-link{display:flex;align-items:center;gap:10px;padding:10px 11px;border-radius:12px;text-decoration:none;color:var(--text-muted);font-size:.9rem;font-weight:650;border:1px solid transparent;position:relative;transition:background var(--duration-120) var(--easing-standard), color var(--duration-120) var(--easing-standard), border-color var(--duration-120) var(--easing-standard)}
.nav-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-faint);flex:0 0 auto}
.nav-link:hover .nav-icon{color:var(--text)}
.nav-label{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-link:hover{background:var(--bg-hover);color:var(--text);border-color:var(--border)}
.nav-link.active{background:var(--bg-muted);color:var(--text);border-color:var(--border-strong)}
.nav-link.active::before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:3px;border-radius:999px;background:var(--accent)}
.suite-switcher{margin:14px 8px 6px;padding:12px;border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:var(--shadow-xs)}
.suite-switcher .input{margin-top:6px}
.suite-links{display:grid;gap:6px;margin-top:10px}
.suite-link{display:block;padding:8px 10px;border:1px solid var(--border);border-radius:10px;color:var(--text-muted);text-decoration:none;background:var(--bg-overlay)}
.suite-link:hover{color:var(--text);border-color:var(--border-strong);text-decoration:none}
.app-sidebar-pages{margin-top:14px}
.app-sidebar-pages-title{font-size:.75rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;margin:10px 10px}
.sidebar-section{margin:0}
.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;margin:0 0 2px;color:var(--text-faint);font-size:.75rem;text-transform:uppercase;letter-spacing:.08em}
.sidebar-section-actions{display:flex;align-items:center;gap:6px}
.sidebar-action-btn{width:22px;height:22px;border-radius:8px}
.sidebar-action-btn.btn-icon{width:22px;height:22px}
.sidebar-action-btn{padding:0}
.sidebar-action-btn{line-height:1}
.sidebar-section-body{display:flex;flex-direction:column;gap:2px}
.sidebar-divider{height:1px;background:var(--border);margin:10px 10px}
.pill{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 6px;border-radius:999px;background:var(--accent-soft);border:1px solid rgba(15,118,110,.22);color:var(--text);font-size:.72rem;font-weight:700;line-height:1}
.tree-pad-8{padding-left:8px}
.tree-pad-20{padding-left:20px}
.tree-pad-24{padding-left:24px}
.indent-0{margin-left:0}
.indent-16{margin-left:16px}
.indent-32{margin-left:32px}
.indent-48{margin-left:48px}
.indent-64{margin-left:64px}
.page-tree-item{display:block;padding:4px 6px;border-radius:var(--radius-md);text-decoration:none;color:var(--text);flex:1}
.page-tree-item:hover{background:var(--bg-hover)}
.page-tree-item.active{background:var(--accent-soft)}
.page-tree-node{display:flex;flex-direction:column}
.page-tree-row{display:flex;align-items:center;gap:6px;padding:2px 6px;border-radius:var(--radius-md)}
.page-tree-row:hover{background:var(--bg-hover)}
.page-tree-toggle{width:18px;height:18px;border:0;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.85rem}
.page-tree-toggle:disabled{opacity:.4;cursor:default}
.page-tree-action{margin-left:auto;opacity:0}
.page-tree-node:hover .page-tree-action{opacity:1}
.page-tree-children.hidden{display:none}

.app-main{flex:1;padding:var(--main-padding);min-width:0}
.app-main-inner{max-width:var(--content-max);margin:0 auto;width:100%}
.dashboard-hero{max-width:980px;margin:0 auto}
.tagline{font-size:1.05rem;line-height:1.8}

/* Global page wrapper (applied in client.js to every route) */
.page{display:flex;flex-direction:column;gap:20px}
.page > .heading-2{margin:0;font-size:1.35rem;line-height:1.3;letter-spacing:-.01em;font-weight:800;color:var(--text)}
.page > .heading-3{margin:0 0 6px;font-weight:750}
.page > section.panel{padding:18px}
.page .card{box-shadow:var(--shadow-card)}
.page .card .heading-2,.page .card .heading-3{margin-top:0}
.page .empty-state{margin:18px 0}

/* New shared layout classes */
/* Nizam Foundation: page header pattern — title + description + optional chips + actions right */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}
.page-title-wrap{min-width:0;flex:1}
.page-title{font-family:var(--font-display);font-size:clamp(1.5rem,2.5vw,2rem);line-height:1.2;letter-spacing:var(--type-letter-tight);font-weight:700;color:var(--text)}
.page-description{font-size:var(--type-size-sm);color:var(--text-muted);margin:4px 0 0;line-height:1.5;max-width:56ch}
.page-header-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.page-header-actions{margin-left:auto;flex-shrink:0}
.needs-attention-panel{background:var(--bg-raised);border:1px solid var(--border);border-left:4px solid var(--warning);border-radius:var(--radius-xl);box-shadow:var(--shadow-card);padding:var(--space-4);margin-bottom:var(--space-6)}
.needs-attention-panel h3{font-size:var(--type-size-sm);font-weight:600;margin:0 0 10px;color:var(--text)}
.needs-attention-panel ul{margin:0;padding:0;list-style:none}
.needs-attention-panel li{margin:6px 0;font-size:var(--type-size-sm)}
.needs-attention-panel a{text-decoration:none}
.needs-attention-panel a:hover{text-decoration:underline}
.page-subtitle{margin-top:4px;color:var(--text-muted);font-size:.9rem}
.page-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.page-wide{max-width:var(--content-max);width:100%}
/* Chips: calm pastel backgrounds (status, assurances, filters) */
.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:var(--radius-full);font-size:var(--type-size-xs);font-weight:500;border:1px solid transparent}
.chip-default{background:var(--surface-2);color:var(--text-muted);border-color:var(--border)}
.chip-primary{background:var(--accent-soft);color:var(--accent-dark);border-color:rgba(47,150,150,.25)}
.chip-success{background:var(--success-soft);color:var(--success)}
.chip-warning{background:var(--warning-soft);color:var(--warning)}
.chip-danger{background:var(--danger-soft);color:var(--danger)}
.chip-info{background:var(--info-soft);color:var(--info)}
.chip-outline{background:transparent;color:var(--text-muted);border-color:var(--border)}

/* Access suite: Members & Roles — polished list cards */
.access-section{margin-top:var(--space-6)}
.access-section-head{font-size:var(--type-size-xs);font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-4)}
.access-list{display:flex;flex-direction:column;gap:var(--space-3)}
.access-member-card,.access-role-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-5);padding:var(--space-5) var(--space-6);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);transition:background var(--duration-120) var(--easing-standard),border-color var(--duration-120) var(--easing-standard),box-shadow var(--duration-120) var(--easing-standard)}
.access-member-card:hover,.access-role-card:hover{background:var(--bg-overlay);border-color:var(--border-strong);box-shadow:var(--shadow-card)}
.access-member-card .access-card-main,.access-role-card .access-card-main{flex:1;min-width:0}
.access-member-card .access-card-title,.access-role-card .access-card-title{font-weight:600;font-size:var(--type-size-lg);letter-spacing:var(--type-letter-tight);color:var(--text);margin:0}
.access-member-card .access-card-meta,.access-role-card .access-card-meta{font-size:var(--type-size-sm);color:var(--text-muted);margin-top:var(--space-1);line-height:1.4}
.access-member-card .access-card-chips,.access-role-card .access-card-chips{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);margin-top:var(--space-3)}
.access-member-card .access-card-action,.access-role-card .access-card-action{flex-shrink:0}
.access-role-card.role-owner{border-left:4px solid var(--accent)}
.access-role-card.role-admin{border-left:4px solid var(--accent-soft);border-left-color:rgba(47,150,150,.5)}
.access-role-card.role-default{border-left:4px solid transparent}
.access-role-badge{font-size:var(--type-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:2px 8px;border-radius:var(--radius-xs);background:var(--surface-2)}
.access-view-only{font-size:var(--type-size-xs);color:var(--text-muted);padding:6px 12px;background:var(--surface-2);border-radius:var(--radius-sm);border:1px solid var(--border)}
.access-empty{text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-muted);font-size:var(--type-size-sm);background:var(--bg-muted);border-radius:var(--radius-lg);border:1px dashed var(--border)}

.section{border:1px solid var(--border);border-radius:16px;background:var(--bg-raised);box-shadow:var(--shadow-card)}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}
.section-title-sm{font-size:.85rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted)}
.section-actions{display:flex;gap:8px;align-items:center}
.section-body{padding:16px}

.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.toolbar .input{min-width:220px}
.toolbar .input.flex-1{min-width:280px}

.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-cols-7{grid-template-columns:repeat(7,minmax(0,1fr))}
@media (max-width: 900px){
  .grid-cols-2{grid-template-columns:1fr}
  .grid-cols-7{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 600px){
  .grid-cols-7{grid-template-columns:1fr}
}

/* Forms */
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.form-grid .mb-12{margin:0}
.input-readonly{background:var(--bg-muted);border-color:var(--border);color:var(--text-muted)}
.inline-field{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text)}
.inline-field input{margin:0}
@media (max-width: 900px){
  .form-grid{grid-template-columns:1fr}
}
.dashboard-quick-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-top:14px}
.quick-action-card{display:block;text-decoration:none;color:inherit;cursor:pointer;border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:var(--shadow-card);padding:14px 14px;transition:transform .08s ease,background .15s ease,border-color .15s ease,box-shadow .15s ease}
.quick-action-card:hover{background:var(--bg-overlay);border-color:var(--border-strong);transform:translateY(-1px);text-decoration:none;box-shadow:var(--shadow-lift)}
.quick-action-card:active{transform:translateY(0)}
.quick-action-card h3{margin:0 0 6px;font-size:1rem;letter-spacing:-.01em}
.quick-action-card p{margin:0}
.suite-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:14px}
.suite-card{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:18px;background:var(--bg-raised);box-shadow:none;padding:18px;transition:background var(--duration-180) var(--easing-standard),border-color var(--duration-180) var(--easing-standard)}
.suite-card::before{content:"";display:none}
.suite-card:hover{background:var(--bg-overlay);border-color:var(--border-strong);transform:none;box-shadow:none}
.suite-card h3{margin:0 0 8px;font-size:1.2rem;letter-spacing:-.01em}
.suite-card .suite-meta{font-size:.86rem;color:var(--text-muted);margin-bottom:10px;line-height:1.5}
.home-hero{border:1px solid var(--border);border-radius:18px;background:var(--bg-raised);box-shadow:none;padding:18px;margin-bottom:16px}
.suite-page-hero{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border:1px solid var(--border);border-radius:18px;background:var(--bg-raised);box-shadow:none;padding:18px}
.suite-hero-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:10px;min-width:300px}
.suite-stat{border:1px solid var(--border);border-radius:12px;background:var(--bg-raised);padding:10px 12px;display:flex;flex-direction:column;gap:2px}
.suite-stat strong{font-size:1.05rem}
.suite-stat span{font-size:.78rem;color:var(--text-muted)}
.suite-section{margin-top:16px}
.suite-section-head{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-bottom:10px}
.suite-section-head h3{margin:0;font-size:1.02rem;letter-spacing:.02em;text-transform:uppercase;color:var(--text)}
.suite-section-head p{margin:0;color:var(--text-muted);font-size:.83rem}
.feature-suite-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:10px}
.feature-suite-card{border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:var(--shadow-xs);padding:12px}
.feature-suite-title{font-weight:700;letter-spacing:-.01em}
.feature-suite-meta{font-size:.8rem;color:var(--text-muted);margin-top:4px;min-height:30px}
.suites-hero{position:relative;overflow:hidden;background:
  radial-gradient(900px circle at -10% -40%, rgba(37,99,235,.14), transparent 52%),
  radial-gradient(740px circle at 120% 20%, rgba(15,118,110,.12), transparent 56%),
  linear-gradient(130deg,var(--bg-raised),var(--bg-overlay))}
.suites-wing-stack{display:flex;flex-direction:column;gap:20px;margin-top:18px}
.suites-wing{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:20px;background:
  radial-gradient(640px circle at 0% 0%, rgba(37,99,235,.09), transparent 55%),
  radial-gradient(520px circle at 100% 30%, rgba(15,118,110,.08), transparent 52%),
  linear-gradient(160deg,var(--bg-raised),var(--bg-overlay));box-shadow:var(--shadow-lift);padding:18px}
.suites-wing-header{padding:2px 2px 14px;border-bottom:1px solid var(--border)}
.suites-wing-kicker{font-size:.74rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.suites-wing-header h2{margin:6px 0 6px;font-size:1.48rem;letter-spacing:-.02em}
.suites-wing-header p{margin:0;color:var(--text-muted);font-size:.9rem}
.suites-subwing{margin-top:14px}
.suites-subwing-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.suites-subwing-head h3{margin:0;font-size:.86rem;letter-spacing:.11em;text-transform:uppercase;color:var(--text-faint)}
.suite-catalog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:12px}
.suite-catalog-card{position:relative;overflow:hidden;border:1px solid var(--border);border-radius:16px;background:var(--bg-raised);box-shadow:none;padding:14px;display:flex;flex-direction:column;min-height:180px;transition:background var(--duration-180) var(--easing-standard),border-color var(--duration-180) var(--easing-standard)}
.suite-catalog-card::before{content:"";display:none}
.suite-catalog-card::after{content:"";display:none}
.suite-catalog-card.live{border-color:rgba(15,118,110,.35)}
.suite-catalog-card.soon{border-color:rgba(148,163,184,.38)}
.suite-catalog-card:hover{transform:none;box-shadow:none;background:var(--bg-overlay);border-color:var(--border-strong)}
.suite-catalog-card-head{display:flex;justify-content:flex-end}
.suite-catalog-status{display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 10px;border-radius:999px;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.suite-catalog-card.live .suite-catalog-status{background:rgba(6,118,71,.12);border:1px solid rgba(6,118,71,.28);color:var(--success)}
.suite-catalog-card.soon .suite-catalog-status{background:rgba(181,71,8,.12);border:1px solid rgba(181,71,8,.28);color:var(--warning)}
.suite-catalog-card h3{position:relative;margin:8px 0 8px;font-size:1.05rem;letter-spacing:-.01em;line-height:1.28}
.suite-catalog-card p{position:relative;margin:0;color:var(--text-muted);font-size:.86rem;line-height:1.52;flex:1}
.suite-catalog-actions{position:relative;margin-top:12px;display:flex;align-items:center;min-height:30px}
.suite-catalog-soon{font-size:.82rem;font-weight:700;color:var(--text-muted)}
@media (max-width: 900px){
  .suite-page-hero{flex-direction:column}
  .suite-hero-stats{width:100%;min-width:0}
  .suite-catalog-grid{grid-template-columns:1fr}
}
.workspace-picker-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}
.empty-state{max-width:720px;margin:48px auto;padding:24px;border:1px solid var(--border);border-radius:var(--radius-xl);background:var(--bg-raised);box-shadow:var(--shadow-soft);position:relative;overflow:hidden}
.empty-state::before{content:"";position:absolute;inset:-2px;pointer-events:none;opacity:.9;background:radial-gradient(circle at 1px 1px, var(--pattern-ink) 1px, transparent 0);background-size:22px 22px;mask-image:radial-gradient(circle at 20% 0%, #000 0%, transparent 70%)}
.empty-state > *{position:relative}
.empty-state h3{margin:0 0 8px;font-family:var(--font-sans);font-size:1.25rem;letter-spacing:-.01em}
.empty-state p{margin:0}
.page-editor{max-width:var(--content-max);width:100%;margin:0 auto}
.page-editor.fullwidth{max-width:100%}
.page-editor-shell{display:flex;align-items:flex-start;gap:24px}
.page-editor-shell .page-editor{flex:1;min-width:0}
.page-cover{width:100%;height:220px;border-radius:var(--radius-lg);background:var(--bg-muted);border:1px solid var(--border);box-shadow:var(--shadow-sm);background-size:cover;background-position:center;margin-bottom:14px;position:relative;overflow:hidden}
.page-cover-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.page-cover .page-cover-actions{position:absolute;right:10px;bottom:10px;display:flex;gap:8px}
.page-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;flex-wrap:wrap}
.page-header-actions{flex-wrap:wrap}
.page-title-row{display:flex;align-items:flex-end;gap:12px;min-width:0;flex:1}
.page-icon{width:44px;height:44px;border-radius:14px;border:1px solid var(--border);background:var(--bg-overlay);display:flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:var(--shadow-xs);flex:0 0 auto}
.page-icon.btn{padding:0}
.page-title-wrap{flex:1;min-width:0}
.page-editor-title{width:100%;font-family:var(--font-display);font-size:2.4rem;letter-spacing:-.02em;border:0;outline:none;background:transparent;color:var(--text);padding:8px 0;margin:2px 0 12px}
.page-editor-blocks{width:100%;margin-top:6px}
.page-editor-blocks{display:flex;flex-direction:column;gap:8px}
.page-comments-panel{width:320px;flex:0 0 320px;background:var(--bg-overlay);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow-xs);position:sticky;top:calc(var(--topbar-h) + 20px);max-height:calc(100vh - var(--topbar-h) - 40px);overflow:auto}
.page-comments-panel.hidden{display:none}
.page-comments-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}
.page-comments-controls{margin-top:12px}
.page-comments-list{margin-top:12px;display:flex;flex-direction:column;gap:10px}
.comment-item{padding:10px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-muted)}
.comment-item.resolved{opacity:.7}
.page-comments-composer{margin-top:12px;border-top:1px solid var(--border);padding-top:12px}
#page-comments-btn.active{background:var(--bg-hover);color:var(--text)}
.comment-reply-banner{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 10px;border:1px dashed var(--border);border-radius:var(--radius-md);background:var(--bg-muted);margin-bottom:8px;font-size:.85rem}
.comment-reply-banner.hidden{display:none}
.block{padding:6px 8px;border-radius:var(--radius-md);outline:none}
.block:focus{box-shadow:0 0 0 2px var(--color-focus-ring)}
.block-quote{border-left:3px solid var(--border-strong);padding-left:12px;color:var(--text)}
.block-callout{background:var(--bg-muted);border:1px solid var(--border);padding:10px 12px}
.block-code{background:var(--bg-muted);border:1px solid var(--border);padding:10px 12px;border-radius:var(--radius-md);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:pre;overflow:auto}
.block-divider{padding:10px 0}
.block-divider hr{border:0;border-top:1px solid var(--border);margin:0}
.block-heading_1{font-family:var(--font-display);font-size:1.75rem}
.block-heading_2{font-family:var(--font-display);font-size:1.35rem}
.block-heading_3{font-weight:700}
.block-asset{background:var(--bg-muted);border:1px dashed var(--border-strong);padding:10px 12px}

/* Lexical block editor */
.lex-blocks{display:flex;flex-direction:column;gap:10px;padding:6px 4px}
.lex-selection-bar{position:sticky;top:calc(var(--topbar-h) + 8px);z-index:140;display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;background:var(--glass);backdrop-filter:blur(12px);border:1px solid var(--border);box-shadow:var(--shadow-sm)}
.lex-block-wrap{position:relative;border-radius:12px;padding:8px 10px;background:transparent;border:1px solid transparent;transition:background .12s ease,border-color .12s ease,box-shadow .12s ease}
.lex-block-wrap:hover{background:var(--bg-overlay);border-color:var(--border);box-shadow:var(--shadow-xs)}
[data-theme="dark"] .lex-block-wrap:hover{border-color:rgba(255,255,255,.04)}
.lex-block-wrap.is-selected{background:var(--accent-soft);border-color:rgba(15,118,110,.28)}
.lex-block-wrap.flash{border-color:var(--accent);box-shadow:0 0 0 4px rgba(37,99,235,.12)}
.lex-block-wrap.drop-target{border-color:var(--accent-gold);background:var(--accent-gold-soft)}
.lex-drag-handle{cursor:grab}
.lex-drag-handle:active{cursor:grabbing}
.lex-block-wrap[data-block-type="quote"]{border-left:3px solid var(--accent-gold);padding-left:14px}
.lex-block-wrap[data-block-type="callout"]{background:rgba(37,99,235,.06);border-color:rgba(37,99,235,.18)}
.lex-children{display:flex;flex-direction:column;gap:10px}
.lex-depth-0{margin-left:0}
.lex-depth-1{margin-left:16px}
.lex-depth-2{margin-left:32px}
.lex-depth-3{margin-left:48px}
.lex-depth-4{margin-left:64px}
.lex-depth-5{margin-left:80px}
.lex-depth-6{margin-left:96px}
.lex-toggle-caret{width:28px;height:28px}
.lex-block-toolbar{display:flex;gap:6px;align-items:center;margin:0 0 6px 0;opacity:0;pointer-events:none;transition:opacity .12s ease}
.lex-block-wrap:hover .lex-block-toolbar,
.lex-block-wrap.is-selected .lex-block-toolbar,
.lex-block-wrap:focus-within .lex-block-toolbar{opacity:1;pointer-events:auto}
.lex-type-select{width:160px;padding:6px 8px;border-radius:999px}
.lex-saving-dot{width:8px;height:8px;border-radius:999px;background:var(--accent);opacity:.55}
.lex-editor{min-height:28px;outline:none;padding:8px 10px;border-radius:10px;background:transparent;border:1px solid transparent;line-height:1.7}
.lex-editor:focus{background:var(--bg-overlay);border-color:rgba(37,99,235,.32);box-shadow:0 0 0 2px rgba(37,99,235,.12)}
.lex-placeholder{color:var(--text-faint);padding:8px 10px}
.lex-h1{font-family:var(--font-display);font-size:1.75rem;letter-spacing:-.02em}
.lex-h2{font-family:var(--font-display);font-size:1.35rem}
.lex-h3{font-weight:700}
.lex-quote{border-left:3px solid var(--border-strong);padding-left:12px;color:var(--text)}
.lex-code{background:var(--bg-muted);border:1px solid var(--border);padding:10px 12px;border-radius:var(--radius-md);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;white-space:pre;overflow:auto}
.lex-ul,.lex-ol{padding-left:24px;margin:6px 0}
.lex-li{margin:4px 0}
.lex-link{color:var(--accent);text-decoration:underline}

/* Minimal menus (native <details>) */
.lex-menu{position:relative}
.lex-menu > summary{list-style:none}
.lex-menu > summary::-webkit-details-marker{display:none}
.lex-menu[open] > summary{background:var(--bg-hover)}
.lex-menu-pop{position:absolute;right:0;top:calc(100% + 6px);min-width:200px;background:var(--bg-overlay);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm);padding:6px;z-index:80}
.lex-menu-item{width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:0;background:transparent;cursor:pointer;color:var(--text);font-size:.9rem}
.lex-menu-item:hover{background:var(--bg-hover)}
.lex-menu-item:disabled{opacity:.45;cursor:not-allowed}
.lex-menu-item.danger{color:var(--danger)}
.lex-sync-badge{padding:2px 8px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:.7rem}
.lex-sync-badge.source{background:rgba(37,99,235,.12)}
.lex-divider{height:1px;background:var(--border);margin:8px 0}
.lex-media{display:flex;gap:12px;align-items:stretch;background:var(--bg-muted);border:1px dashed var(--border);border-radius:12px;padding:10px}
.lex-media-body{flex:1;min-width:0}
.lex-media-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.lex-media-img{max-width:100%;border-radius:10px;border:1px solid var(--border);box-shadow:var(--shadow-xs)}
.lex-media-placeholder{padding:12px;border:1px dashed var(--border);border-radius:10px}
.lex-media-file{padding:10px;border:1px solid var(--border);border-radius:10px;background:var(--bg-overlay)}
.lex-media-file-name{font-weight:600;margin-bottom:4px}
.lex-embed{width:220px;min-height:120px}
.lex-embed-input{width:100%}
.lex-embed-preview iframe{width:100%;height:140px;border:0;border-radius:10px;box-shadow:var(--shadow-xs)}
.lex-slash-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;z-index:170}
.lex-slash-menu{background:var(--bg-raised);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-soft);width:min(420px,90vw);padding:12px}
.lex-slash-input{width:100%;margin-bottom:8px}
.lex-slash-results{max-height:260px;overflow:auto}
.lex-slash-item{width:100%;text-align:left;padding:8px 10px;border-radius:10px;border:0;background:transparent;cursor:pointer}
.lex-slash-item:hover{background:var(--bg-hover)}
.breadcrumb{font-size:.85rem;color:var(--text-muted);margin-bottom:12px}
.breadcrumb a{text-decoration:none;color:var(--text-muted)}
.breadcrumb a:hover{color:var(--text)}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;box-shadow:var(--shadow-card)}
.stat-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-card)}
.stat-value{font-size:24px;font-weight:700}
.stat-label{color:var(--text-muted);font-size:var(--type-size-xs);text-transform:uppercase;letter-spacing:.08em;margin-top:6px}
.ws-create-card{max-width:400px}
.input{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:var(--bg-raised);color:var(--text);box-shadow:none;transition:border-color var(--duration-120) var(--easing-standard), box-shadow var(--duration-120) var(--easing-standard), background var(--duration-120) var(--easing-standard)}
.input:focus{border-color:color-mix(in oklab,var(--accent) 40%, var(--border));box-shadow:0 0 0 3px var(--color-focus-ring);background:var(--bg-raised)}
.btn{border:1px solid var(--border);background:var(--bg-raised);color:var(--text);padding:10px 12px;border-radius:12px;cursor:pointer;box-shadow:none;transition:background var(--duration-180) var(--easing-standard), border-color var(--duration-180) var(--easing-standard), color var(--duration-180) var(--easing-standard)}
.btn:hover{background:var(--bg-hover);border-color:var(--border-strong)}
.btn:active{background:var(--bg-muted);transform:none}
.btn-primary{background:var(--accent);color:#fff;border-color:color-mix(in oklab,var(--accent) 55%, var(--border));box-shadow:none}
.btn-primary:hover{background:var(--accent-hover);border-color:color-mix(in oklab,var(--accent-hover) 55%, var(--border))}
.btn-secondary{background:var(--bg-raised);color:var(--accent);border:1px solid color-mix(in oklab,var(--accent) 30%, var(--border));box-shadow:none}
.btn-secondary:hover{background:var(--bg-overlay);border-color:color-mix(in oklab,var(--accent) 40%, var(--border))}
.btn-outline{background:transparent;color:var(--text);border:1px dashed var(--border-muted)}
.btn-ghost{background:transparent;border-color:transparent;color:var(--text-muted);box-shadow:none}
.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}
.btn-ghost:active{background:var(--bg-muted);transform:none}
.btn-icon{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;padding:0}
.btn-sm{padding:6px 10px;font-size:.85rem}
.btn-xs{padding:4px 8px;font-size:.78rem}
.btn-block{display:block;width:100%}
.w-90{width:90px}
.w-120{width:120px}

/* Segmented controls (used for view tabs) */
.view-tabs{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:999px;background:var(--bg-overlay);overflow:hidden}
.view-tabs .btn{border:0;border-right:1px solid var(--border);border-radius:0;background:transparent;box-shadow:none}
.view-tabs .btn:last-child{border-right:0}
.view-tabs .btn:hover{background:var(--bg-hover)}
.view-tabs .btn.active{background:var(--accent-soft);color:var(--accent);font-weight:700}

/* Links that behave like "cards" */
.card-link{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px;text-decoration:none;color:inherit;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-raised);box-shadow:var(--shadow-card);transition:transform .08s ease,border-color .15s ease,box-shadow .15s ease,background .15s ease}
.card-link:hover{border-color:rgba(37,99,235,.28);transform:translateY(-1px);text-decoration:none;box-shadow:var(--shadow-lift)}
.link-block{display:block;text-decoration:none;color:inherit;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-raised);box-shadow:var(--shadow-card);transition:transform .08s ease,border-color .15s ease,box-shadow .15s ease,background .15s ease}
.link-block:hover{border-color:rgba(37,99,235,.28);transform:translateY(-1px);text-decoration:none;box-shadow:var(--shadow-lift)}

/* Data lists (used across routes: members, teamspaces, forms, approvals, backups, etc.) */
.list{border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:none;overflow:hidden}
.list-row{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);text-decoration:none;color:inherit}
.list-row:last-child{border-bottom:0}
.list-row:hover{background:var(--bg-overlay);text-decoration:none}
.list-main{min-width:0;flex:1}
.list-side{display:flex;align-items:center;justify-content:flex-end;gap:8px;flex:0 0 auto}
.list-row .mono{font-family:var(--type-font-mono);font-size:.9rem}

.mono{font-family:var(--type-font-mono)}
.input-sm{width:auto;padding:8px 10px;border-radius:12px;font-size:.85rem}

.db-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:12px}
.db-table thead{position:sticky;top:0;background:var(--bg-raised);z-index:2}
.db-table th,.db-table td{border-bottom:1px solid var(--border);padding:10px 12px;text-align:left;font-size:.875rem;white-space:nowrap}
.db-table th{color:var(--text-muted);font-weight:700;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em}
.db-table-wrap{max-height:560px;overflow:auto;border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:none}

/* Workspace hub */
.workspace-shell{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:16px}
.workspace-hero{padding:20px;border:1px solid var(--border);border-radius:18px;background:var(--bg-raised);box-shadow:none}
.workspace-hero h2{margin:0 0 8px;font-size:1.55rem;letter-spacing:-.02em}
.workspace-hero p{margin:0;color:var(--text-muted)}
.workspace-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.workspace-badge{padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:var(--bg-overlay);font-size:.78rem;color:var(--text-muted)}
.workspace-aside{display:flex;flex-direction:column;gap:12px}
.workspace-kpi{padding:14px;border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:var(--shadow-card)}
.workspace-kpi .value{font-size:1.35rem;font-weight:800;line-height:1.1}
.workspace-kpi .label{margin-top:4px}
.workspace-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.workspace-card{border:1px solid var(--border);border-radius:14px;background:var(--bg-raised);box-shadow:var(--shadow-card);padding:14px}
.workspace-card h4{margin:0 0 6px;font-size:1rem}
.workspace-meta{font-size:.82rem;color:var(--text-muted)}

.masjid-suite-frame-wrap{
  position:relative;
  overflow:hidden;
  border:1px solid var(--border);
  border-radius:16px;
  background:var(--bg-raised);
  box-shadow:none;
}
.masjid-suite-frame-wrap::before{
  content:"";
  display:none;
}
.masjid-suite-frame{
  display:block;
  width:100%;
  height:calc(100vh - 220px);
  min-height:720px;
  border:0;
  background:#fff;
}

.suite-page-hero,
.suite-section,
.feature-suite-card,
.masjid-suite-frame-wrap{
  animation:nizamElevateIn .35s var(--easing-decelerate) both;
}
.feature-suite-card:nth-child(2){animation-delay:.04s}
.feature-suite-card:nth-child(3){animation-delay:.08s}
.feature-suite-card:nth-child(4){animation-delay:.12s}
@keyframes nizamElevateIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

@media (max-width: 980px){
  .workspace-shell{grid-template-columns:1fr}
}
@media (max-width: 760px){
  .workspace-form-grid{grid-template-columns:1fr}
}
.db-table-wrap .db-table{margin:0}
.db-table .db-select-col{width:36px}
.db-table .db-spacer td{border:0;padding:0}
.db-cell{cursor:pointer}
.db-table tbody tr:nth-child(even) td{background:rgba(100,116,139,.06)}
[data-theme="dark"] .db-table tbody tr:nth-child(even) td{background:rgba(255,255,255,.02)}
.db-cell:hover{background:var(--bg-hover)}
.db-table td{max-width:520px;overflow:hidden;text-overflow:ellipsis}
.db-table th.col-w-80,.db-table td.col-w-80{width:80px;min-width:80px;max-width:80px}
.db-table th.col-w-100,.db-table td.col-w-100{width:100px;min-width:100px;max-width:100px}
.db-table th.col-w-120,.db-table td.col-w-120{width:120px;min-width:120px;max-width:120px}
.db-table th.col-w-140,.db-table td.col-w-140{width:140px;min-width:140px;max-width:140px}
.db-table th.col-w-160,.db-table td.col-w-160{width:160px;min-width:160px;max-width:160px}
.db-table th.col-w-180,.db-table td.col-w-180{width:180px;min-width:180px;max-width:180px}
.db-table th.col-w-200,.db-table td.col-w-200{width:200px;min-width:200px;max-width:200px}
.db-table th.col-w-240,.db-table td.col-w-240{width:240px;min-width:240px;max-width:240px}
.db-table th.col-w-280,.db-table td.col-w-280{width:280px;min-width:280px;max-width:280px}
.db-table th.col-w-320,.db-table td.col-w-320{width:320px;min-width:320px;max-width:320px}
.db-table th.col-w-400,.db-table td.col-w-400{width:400px;min-width:400px;max-width:400px}
.db-table th.col-w-520,.db-table td.col-w-520{width:520px;min-width:520px;max-width:520px}

/* Workflow visual editor */
.wf-canvas{position:relative;margin-top:10px;min-height:260px;border:1px dashed var(--border);border-radius:12px;background:rgba(255,255,255,.02);overflow:hidden}
.wf-canvas-lines{position:absolute;top:0;left:0;width:100%;height:100%}
.wf-line{stroke:var(--text-faint);stroke-width:1.5}
.wf-node{position:absolute;min-width:100px;padding:6px 10px;border:1px solid var(--border);border-radius:10px;background:var(--bg-elev);color:var(--text);cursor:grab;font-size:.85rem;box-shadow:var(--shadow-soft)}
.wf-node:active{cursor:grabbing}

.calendar-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.calendar-weekday{font-size:.75rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;text-align:center}
.calendar-cell{min-height:92px;border:1px solid var(--border);border-radius:12px;padding:8px;background:var(--bg-overlay)}
.calendar-cell.dim{opacity:.6}
.calendar-day{font-weight:600;font-size:.85rem;margin-bottom:6px}
.calendar-items{display:flex;flex-direction:column;gap:4px}
.calendar-item{font-size:.75rem;display:inline-block;padding:2px 6px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}
.calendar-item:hover{background:var(--bg-hover)}
.board-column.drag-over{outline:2px dashed var(--accent);outline-offset:4px}
.timeline-chart{display:flex;flex-direction:column;gap:12px;position:relative}
.timeline-row{display:grid;grid-template-columns:minmax(160px,1fr) 3fr;gap:12px;align-items:center}
.timeline-track{position:relative;height:22px;background:var(--bg-hover);border-radius:999px;overflow:hidden}
.timeline-bar{position:absolute;top:2px;height:18px;background:var(--accent);border-radius:999px}
.timeline-bar.critical{background:var(--danger)}
.timeline-milestone{position:absolute;top:50%;width:14px;height:14px;background:var(--accent-gold);transform:translate(-50%,-50%) rotate(45deg);border-radius:3px}
.timeline-milestone.critical{background:var(--danger)}
.timeline-bar-svg{width:100%;height:18px;display:block}
.timeline-bar-svg rect{fill:var(--accent)}
.timeline-deps{position:absolute;top:0;left:0;pointer-events:none;z-index:2}
.timeline-dep-line{stroke:rgba(99,102,241,.7);stroke-width:1.5;fill:none}
.timeline-dep-dot{fill:rgba(99,102,241,.9)}
.kanban-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;align-items:start}
.kanban-col{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px;min-height:140px}
.kanban-col h4{margin:0 0 8px;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}
.kanban-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:12px;padding:8px 10px;margin-bottom:8px;cursor:pointer}
.kanban-card:hover{background:var(--bg-hover)}
.kanban-card .meta{font-size:.72rem;color:var(--text-muted);margin-top:4px}
.kanban-card.dragging{opacity:.6}
.kanban-card.pending{border-color:rgba(99,102,241,.5);box-shadow:0 0 0 1px rgba(99,102,241,.2) inset}
.kanban-col.drag-over{outline:2px dashed var(--accent);outline-offset:4px}
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:999px;font-size:.7rem;border:1px solid var(--border);background:var(--bg-hover);color:var(--text-muted)}
.badge.good{background:rgba(16,185,129,.12);border-color:rgba(16,185,129,.35);color:rgb(6,95,70)}
.badge.warn{background:rgba(245,158,11,.14);border-color:rgba(245,158,11,.35);color:rgb(146,64,14)}
.badge.bad{background:rgba(239,68,68,.14);border-color:rgba(239,68,68,.35);color:rgb(127,29,29)}
.badge.info{background:rgba(37,99,235,.12);border-color:rgba(37,99,235,.25);color:rgb(30,64,175)}
.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--bg-elev);border:1px solid var(--border);font-size:.78rem}

.toast{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 14px;box-shadow:var(--shadow-soft);margin-top:10px;font-size:.875rem}
.toast.error{border-color:rgba(185,28,28,.4);color:var(--danger)}
.toast.success{border-color:rgba(6,118,71,.35);color:var(--accent)}
.toast.info{border-color:rgba(59,130,246,.3);color:var(--accent)}
#toast-container{position:fixed;bottom:18px;right:18px;display:flex;flex-direction:column;gap:10px;z-index:200}

#offline-banner{position:fixed;top:calc(var(--topbar-h) + 8px);left:50%;transform:translateX(-50%);background:var(--danger);color:#fff;padding:8px 14px;border-radius:999px;font-size:.82rem;box-shadow:var(--shadow-soft);z-index:180;opacity:0;pointer-events:none;transition:opacity .2s ease}
#offline-banner.show{opacity:1}

.notif-dropdown{position:fixed;right:18px;top:calc(var(--topbar-h) + 8px);width:320px;max-height:420px;overflow:auto;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:12px;z-index:150}
.notif-item{padding:10px;border-radius:var(--radius-md);cursor:pointer}
.notif-item:hover{background:var(--bg-hover)}
.notif-item.unread{background:var(--accent-soft)}

.command-palette-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:flex-start;justify-content:center;padding-top:80px;z-index:160}
.command-palette-overlay.open{display:flex}
.command-palette{width:min(720px,92vw);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);overflow:hidden}
.command-palette-input{width:100%;padding:14px 16px;border:0;border-bottom:1px solid var(--border);outline:none;background:transparent;color:var(--text)}
.command-palette-results{max-height:420px;overflow:auto}
.command-palette-item{display:flex;gap:10px;align-items:center;padding:10px 14px;cursor:pointer}
.command-palette-item:hover,.command-palette-item.selected{background:var(--bg-hover)}
.diff-meta{padding:10px 12px;border-bottom:1px solid var(--border);font-size:.85rem;color:var(--text-muted)}
.diff-view{max-height:520px;overflow:auto;padding:8px 0}
.diff-line{display:flex;gap:8px;padding:2px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.85rem;white-space:pre-wrap}
.diff-line.add{background:rgba(32,159,103,.12)}
.diff-line.del{background:rgba(198,69,69,.12)}
.diff-gutter{width:16px;color:var(--text-faint)}

@media (max-width: 1100px){
  .page-editor-shell{flex-direction:column}
  .page-comments-panel{width:100%;position:static;max-height:none}
}
@media (max-width: 900px){
  .hero{grid-template-columns:1fr}
  .grid-cols-3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 640px){
  .grid-cols-3{grid-template-columns:repeat(1,minmax(0,1fr))}
}

/* Modal (used for filter/sort builders) */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.42);display:none;align-items:flex-start;justify-content:center;padding:80px 16px;z-index:170}
.modal-overlay.open{display:flex}
.modal{width:min(760px,94vw);background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border)}
.modal-title{font-weight:700}
.modal-body{padding:14px 16px}
.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 16px;border-top:1px solid var(--border)}
.modal-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.modal-row .input{max-width:260px}
.tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid rgba(37,99,235,.16);border-radius:999px;background:rgba(37,99,235,.08);font-size:.85rem;color:var(--text)}
.tag button{border:0;background:transparent;cursor:pointer;color:var(--text-muted)}

/* Accessibility */
::focus-visible{box-shadow:0 0 0 2px var(--color-focus-ring), 0 0 0 6px rgba(37,99,235,.08)}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* Public page */
.public-shell{max-width:1100px;margin:0 auto;padding:40px 24px 60px}
.public-hero{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.public-brand{font-family:var(--font-display);font-size:1.6rem;color:var(--accent);text-decoration:none}
.public-cover{width:100%;height:260px;border-radius:var(--radius-lg);background:var(--bg-muted);border:1px solid var(--border);box-shadow:var(--shadow-sm);background-size:cover;background-position:center;margin:12px 0 18px}
.public-cover-img{width:100%;height:100%;object-fit:cover;display:block}
.public-title{font-family:var(--font-display);font-size:2.6rem;letter-spacing:-.02em;margin:6px 0 12px}
.public-content{font-size:1.05rem;line-height:1.85}
.public-block{margin:10px 0}
.public-block h1{font-family:var(--font-display);font-size:2.2rem;letter-spacing:-.02em;margin:0 0 8px}
.public-block h2{font-family:var(--font-display);font-size:1.7rem;margin:0 0 8px}
.public-block h3{font-weight:700;margin:0 0 6px}
.public-block p{margin:0 0 10px}
.public-block blockquote{margin:8px 0;padding-left:12px;border-left:3px solid var(--accent-gold);color:var(--text)}
.public-block pre{background:var(--bg-muted);border:1px solid var(--border);padding:12px;border-radius:var(--radius-md);overflow:auto}
.public-block hr{border:0;border-top:1px solid var(--border)}
.public-block ul,.public-block ol{padding-left:24px;margin:6px 0}
.public-block li{margin:4px 0}

/* Marketing site — Nizam theme (matches app) */
.mk-shell{
  min-height:100vh;
  color:var(--text);
  background:var(--bg-base);
  font-family:var(--font-sans);
  position:relative;
}
.mk-shell::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(ellipse 100% 70% at 50% -20%, rgba(47,150,150,.14), transparent 50%),
    radial-gradient(ellipse 60% 40% at 80% 50%, rgba(47,150,150,.06), transparent 45%);
  opacity:1;
}
.mk-shell::after{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(rgba(15,23,42,.02) 1px, transparent 1px), linear-gradient(90deg, rgba(15,23,42,.02) 1px, transparent 1px);
  background-size:64px 64px;
  opacity:.6;
}
.mk-topbar{
  max-width:1200px;
  margin:0 auto;
  padding:var(--space-3) var(--space-6);
  display:flex;
  align-items:center;
  gap:var(--space-6);
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(255,255,255,.82);
  border-bottom:1px solid var(--border);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
}
.mk-brand{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.5rem;
  color:var(--accent);
  text-decoration:none;
  letter-spacing:-.03em;
}
.mk-brand:hover{color:var(--accent-dark);text-decoration:none}
.mk-brand-cluster{display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-width:0;text-align:left}
.mk-brand-cluster .mk-brand{line-height:1.05}
.mk-brand-subtitle{
  font-family:var(--font-sans);
  font-size:.625rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--text-muted);
  margin:0;
  line-height:1.25;
  max-width:min(280px,70vw);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.mk-nav{display:flex;align-items:center;gap:var(--space-1);flex:1;min-width:0;padding-left:var(--space-8)}
.mk-nav-link{
  padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-md);
  color:var(--text-muted);
  text-decoration:none;
  font-weight:500;
  font-size:.9375rem;
  white-space:nowrap;
  transition:color .18s ease, background .18s ease;
}
.mk-nav-link:hover{color:var(--text);background:var(--bg-hover);text-decoration:none}
.mk-nav-link.active{color:var(--accent-dark);background:var(--accent-soft);font-weight:600}
.mk-top-actions .btn{
  border-radius:var(--radius-md);
  padding:var(--space-2) var(--space-5);
  font-weight:600;
  font-size:.9375rem;
}
.mk-top-actions .btn-primary{
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-dark) 100%);
  border-color:var(--accent-dark);
  box-shadow:0 2px 8px rgba(47,150,150,.25);
}
.mk-top-actions .btn-primary:hover{
  box-shadow:0 4px 14px rgba(47,150,150,.35);
}
.mk-main{
  max-width:720px;
  margin:0 auto;
  padding:var(--space-12) var(--space-6) var(--space-16);
  display:flex;
  flex-direction:column;
  gap:var(--space-12);
}
.mk-main.mk-main-wide{max-width:1100px;padding:0 var(--space-6) var(--space-20)}
.mk-main.mk-main-wide > *{max-width:100%}
.mk-kicker{
  display:inline-flex;
  align-items:center;
  padding:var(--space-2) var(--space-4);
  border-radius:var(--radius-full);
  background:var(--accent-soft);
  color:var(--accent-dark);
  font-size:.75rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  font-weight:700;
  margin-bottom:var(--space-5);
}
.mk-hero{
  padding:var(--space-10) 0;
  position:relative;
}
.mk-hero-single{max-width:42rem}
.mk-hero-content{position:relative}
.mk-hero h1{
  font-family:var(--font-display);
  font-size:clamp(2rem, 5vw, 2.75rem);
  line-height:1.15;
  letter-spacing:-.03em;
  margin:0 0 var(--space-4);
  color:var(--text);
}
.mk-hero-lead{
  font-size:var(--type-size-lg);
  line-height:1.6;
  color:var(--text-muted);
  margin:0 0 var(--space-6);
  max-width:38rem;
}
.mk-hero-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;margin-top:0}
.mk-hero-actions .btn{
  border-radius:var(--radius-md);
  padding:var(--space-3) var(--space-6);
  font-weight:600;
}
.mk-hero-actions .btn-primary{
  background:linear-gradient(180deg, var(--accent) 0%, var(--accent-dark) 100%);
  border-color:var(--accent-dark);
  box-shadow:0 4px 14px rgba(47,150,150,.28);
}
.mk-hero-actions .btn-primary:hover{
  box-shadow:0 6px 20px rgba(47,150,150,.38);
}
/* Premium hero — full-width section, larger type, glow */
.mk-hero-premium{
  padding:var(--space-24) 0;
  text-align:center;
  position:relative;
}
.mk-hero-premium .mk-hero-content{
  max-width:720px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.mk-hero-premium .mk-hero-content::before{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:140%;
  height:120%;
  background:radial-gradient(ellipse 50% 50%, rgba(47,150,150,.08) 0%, transparent 70%);
  pointer-events:none;
}
.mk-hero-premium .mk-kicker{margin-bottom:var(--space-5)}
.mk-hero-premium h1{
  font-family:var(--font-display);
  font-size:clamp(2.75rem, 7vw, 4rem);
  line-height:1.05;
  letter-spacing:-.045em;
  margin:0 0 var(--space-5);
  color:var(--text);
  font-weight:600;
}
.mk-hero-premium .mk-hero-lead{
  font-size:1.25rem;
  line-height:1.65;
  max-width:36rem;
  margin:0 auto var(--space-8);
  color:var(--text-muted);
}
.mk-hero-premium .mk-hero-actions{justify-content:center;gap:var(--space-4)}
.mk-hero-premium .mk-hero-actions .btn{padding:var(--space-4) var(--space-10);font-size:1.0625rem;border-radius:var(--radius-lg)}
.mk-trust-line{
  margin-top:var(--space-10);
  padding-top:var(--space-6);
  border-top:1px solid var(--border);
  font-size:.9375rem;
  color:var(--text-faint);
  letter-spacing:.02em;
}
/* Section bands */
.mk-section-band{
  padding:var(--space-20) 0;
  background:linear-gradient(180deg, var(--bg-muted) 0%, var(--bg-base) 100%);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.mk-section-band-inner{max-width:1100px;margin:0 auto;padding:0 var(--space-6)}
.mk-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:var(--space-6)}
.mk-section-head h2{
  margin:0;
  font-family:var(--font-display);
  font-size:clamp(1.5rem, 3vw, 1.75rem);
  letter-spacing:-.02em;
  color:var(--text);
}
.mk-features{
  padding:var(--space-16) 0;
}
.mk-features-title{
  font-family:var(--font-display);
  font-size:clamp(1.5rem, 3vw, 1.75rem);
  font-weight:600;
  margin:0 0 var(--space-8);
  color:var(--text);
  letter-spacing:-.02em;
}
.mk-section-title-center{text-align:center;margin-bottom:var(--space-6)}
.mk-features-list{
  list-style:none;
  padding:0;
  margin:0 0 var(--space-6);
  color:var(--text-muted);
  line-height:1.7;
  font-size:var(--type-size-md);
}
.mk-features-list li{margin:var(--space-2) 0}
.mk-features-list strong{color:var(--text);font-weight:600}
.mk-features-cta{margin-top:var(--space-8)}
/* Premium feature cards — 3-col grid, depth & hover */
.mk-feature-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-6);padding:var(--space-10) 0}
.mk-feature-card{
  background:var(--bg-raised);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-8);
  box-shadow:0 1px 3px rgba(15,23,42,.04), 0 6px 20px rgba(15,23,42,.04);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.mk-feature-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 32px rgba(15,23,42,.08), 0 2px 8px rgba(47,150,150,.06);
  border-color:rgba(47,150,150,.2);
}
.mk-feature-card-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:44px;height:44px;border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--accent-soft) 0%, rgba(47,150,150,.12) 100%);
  color:var(--accent-dark);
  font-family:var(--font-display);font-weight:700;font-size:1.25rem;
  margin-bottom:var(--space-5);
  box-shadow:0 2px 8px rgba(47,150,150,.1);
}
.mk-feature-card h3{font-family:var(--font-display);font-size:1.25rem;font-weight:600;margin:0 0 var(--space-3);color:var(--text);letter-spacing:-.01em}
.mk-feature-card p{margin:0;color:var(--text-muted);line-height:1.65;font-size:.9375rem}
/* Stats strip */
.mk-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-10);padding:var(--space-12) 0;text-align:center}
.mk-stat-num{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--accent-dark);letter-spacing:-.03em;margin-bottom:var(--space-2);line-height:1}
.mk-stat-label{font-size:.9375rem;color:var(--text-muted);font-weight:500;max-width:10em;margin:0 auto}
/* Product preview — mock app frame */
.mk-product-preview{
  margin:var(--space-16) 0;
  border-radius:var(--radius-2xl);
  overflow:hidden;
  box-shadow:0 24px 64px rgba(15,23,42,.12), 0 8px 24px rgba(15,23,42,.06);
  border:1px solid var(--border);
  background:var(--bg-raised);
}
.mk-product-preview-bar{
  height:40px;
  background:var(--bg-muted);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  padding:0 var(--space-4);
  gap:8px;
}
.mk-product-preview-bar span{
  width:12px;height:12px;border-radius:50%;
  background:var(--border-strong);
}
.mk-product-preview-bar span:first-child{background:#ff5f57}
.mk-product-preview-bar span:nth-child(2){background:#febc2e}
.mk-product-preview-bar span:nth-child(3){background:#28c840}
.mk-product-preview-body{
  display:flex;
  min-height:320px;
}
.mk-product-preview-side{
  width:220px;
  background:var(--bg-muted);
  border-right:1px solid var(--border);
  padding:var(--space-4);
}
.mk-product-preview-side .mk-preview-item{
  height:10px;
  border-radius:6px;
  background:var(--border);
  margin-bottom:var(--space-2);
  opacity:.7;
}
.mk-product-preview-side .mk-preview-item:nth-child(1){width:80%}
.mk-product-preview-side .mk-preview-item:nth-child(2){width:90%}
.mk-product-preview-side .mk-preview-item:nth-child(3){width:70%}
.mk-product-preview-side .mk-preview-item:nth-child(4){width:85%}
.mk-product-preview-side .mk-preview-item:nth-child(5){width:75%}
.mk-product-preview-side .mk-preview-item:nth-child(6){width:60%;background:var(--accent-soft);opacity:1}
.mk-product-preview-main{
  flex:1;
  padding:var(--space-8);
  background:var(--bg-base);
}
.mk-product-preview-main .mk-preview-block{
  height:14px;
  border-radius:8px;
  background:var(--border);
  margin-bottom:var(--space-3);
  opacity:.6;
}
.mk-product-preview-main .mk-preview-block:nth-child(1){width:40%}
.mk-product-preview-main .mk-preview-block:nth-child(2){width:70%}
.mk-product-preview-main .mk-preview-block:nth-child(3){width:55%}
.mk-product-preview-main .mk-preview-block:nth-child(4){width:30%}
.mk-product-preview-main .mk-preview-block:nth-child(5){width:65%}
.mk-product-preview-main .mk-preview-block:nth-child(6){width:45%}
.mk-product-preview-main .mk-preview-block:nth-child(7){width:80%}
.mk-product-preview-main .mk-preview-block:nth-child(8){width:25%}
.mk-product-preview-caption{
  padding:var(--space-4) var(--space-6);
  background:var(--bg-muted);
  border-top:1px solid var(--border);
  font-size:.875rem;
  color:var(--text-muted);
  text-align:center;
}
/* CTA block refinement */
.mk-cta-block{
  border-radius:var(--radius-2xl);
  padding:var(--space-12) var(--space-10);
  background:linear-gradient(135deg, rgba(47,150,150,.08) 0%, var(--bg-raised) 50%);
  border:1px solid rgba(47,150,150,.18);
  box-shadow:0 8px 32px rgba(47,150,150,.06);
}
.mk-cta-block h2{font-size:clamp(1.5rem, 3vw, 1.75rem);margin-bottom:var(--space-2)}
.mk-cta-block p{margin:0}
.mk-page-hero{
  padding:var(--space-12) 0;
}
.mk-page-hero h1{
  font-family:var(--font-display);
  font-size:clamp(1.75rem, 4vw, 2.25rem);
  margin:0 0 var(--space-2);
  color:var(--text);
}
.mk-page-hero p{
  font-size:var(--type-size-md);
  color:var(--text-muted);
  margin:0 0 var(--space-4);
  max-width:42rem;
}
.mk-page-hero-minimal .mk-hero-actions{margin-top:var(--space-4)}
/* Premium subpage hero — same impact as homepage hero */
.mk-page-hero-premium{
  padding:var(--space-24) 0;
  text-align:center;
  position:relative;
}
.mk-page-hero-premium .mk-hero-content{
  max-width:720px;
  margin:0 auto;
  position:relative;
  z-index:1;
}
.mk-page-hero-premium .mk-kicker{margin-bottom:var(--space-5)}
.mk-page-hero-premium h1{
  font-family:var(--font-display);
  font-size:clamp(2.75rem, 7vw, 4rem);
  line-height:1.05;
  letter-spacing:-.045em;
  margin:0 0 var(--space-5);
  color:var(--text);
  font-weight:600;
}
.mk-page-hero-premium .mk-hero-lead{
  font-size:1.25rem;
  line-height:1.65;
  max-width:36rem;
  margin:0 auto var(--space-8);
  color:var(--text-muted);
}
.mk-page-hero-premium .mk-hero-actions{justify-content:center;gap:var(--space-4)}
.mk-page-hero-premium .mk-hero-actions .btn{
  padding:var(--space-4) var(--space-10);
  font-size:1.0625rem;
  border-radius:var(--radius-lg);
}
.mk-page-hero-premium .mk-trust-line{margin-top:var(--space-10);padding-top:var(--space-6)}
.mk-page-hero-premium .mk-hero-content::before{
  content:"";
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:140%;
  height:120%;
  background:radial-gradient(ellipse 50% 50%, rgba(47,150,150,.08) 0%, transparent 70%);
  pointer-events:none;
}
.mk-page-hero-premium .mk-page-stats{margin-top:var(--space-6)}
.mk-page-stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
  padding:var(--space-8) 0;
  text-align:center;
  max-width:720px;
  margin:0 auto;
}
.mk-page-stats-item{
  font-size:.9375rem;
  color:var(--text-muted);
  font-weight:500;
}
.mk-page-stats-item strong{display:block;font-family:var(--font-display);font-size:1.35rem;color:var(--accent-dark);margin-bottom:var(--space-1);font-weight:600}
/* Key points strip — horizontal premium strip for subpages */
.mk-key-strip{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:var(--space-6);
  padding:var(--space-10) 0;
  margin:var(--space-8) 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.mk-key-strip-item{
  text-align:center;
  padding:var(--space-4);
}
.mk-key-strip-item .mk-key-strip-dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--accent);
  margin:0 auto var(--space-3);
  opacity:.9;
}
.mk-key-strip-item strong{display:block;font-family:var(--font-display);font-size:1.1rem;color:var(--text);margin-bottom:var(--space-1);font-weight:600}
.mk-key-strip-item span{font-size:.9375rem;color:var(--text-muted);line-height:1.5}
/* Prose cards — elevated content blocks */
.mk-prose-section{max-width:680px}
.mk-prose-section h2{font-family:var(--font-display);font-size:1.35rem;margin:var(--space-8) 0 var(--space-2);color:var(--text)}
.mk-prose-section p{margin:0 0 var(--space-4);color:var(--text-muted);line-height:1.75}
.mk-prose-section ul{margin:0 0 var(--space-4);padding-left:1.25rem;color:var(--text-muted);line-height:1.7}
.mk-prose-section li{margin:var(--space-1) 0}
.mk-prose-card{
  background:var(--bg-raised);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-8);
  margin-bottom:var(--space-6);
  box-shadow:0 2px 8px rgba(15,23,42,.04), 0 8px 24px rgba(15,23,42,.04);
}
.mk-prose-card:last-child{margin-bottom:0}
.mk-prose-card h2{font-family:var(--font-display);font-size:1.35rem;margin:0 0 var(--space-3);color:var(--text);letter-spacing:-.02em}
.mk-prose-card p{margin:0 0 var(--space-3);color:var(--text-muted);line-height:1.75}
.mk-prose-card p:last-child{margin-bottom:0}
.mk-prose-card ul{margin:0 0 var(--space-3);padding-left:1.25rem;color:var(--text-muted);line-height:1.7}
.mk-prose-card li{margin:var(--space-1) 0}
/* Pillar grid — 3 or 4 items with icon/num */
.mk-pillar-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-6);padding:var(--space-10) 0}
.mk-pillar{
  background:var(--bg-raised);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-8);
  text-align:center;
  box-shadow:0 2px 8px rgba(15,23,42,.04);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.mk-pillar:hover{transform:translateY(-3px);box-shadow:0 12px 32px rgba(15,23,42,.08);border-color:rgba(47,150,150,.18)}
.mk-pillar-icon{
  width:52px;height:52px;
  margin:0 auto var(--space-4);
  border-radius:var(--radius-xl);
  background:linear-gradient(135deg, var(--accent-soft) 0%, rgba(47,150,150,.12) 100%);
  color:var(--accent-dark);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:700;font-size:1.5rem;
  box-shadow:0 2px 8px rgba(47,150,150,.12);
}
.mk-pillar h3{font-family:var(--font-display);font-size:1.2rem;font-weight:600;margin:0 0 var(--space-2);color:var(--text)}
.mk-pillar p{margin:0;color:var(--text-muted);font-size:.9375rem;line-height:1.65}
/* Highlight box — accent left border */
.mk-highlight-box{
  background:linear-gradient(90deg, var(--accent-soft) 0%, var(--bg-raised) 12%);
  border:1px solid rgba(47,150,150,.2);
  border-left:4px solid var(--accent);
  border-radius:0 var(--radius-xl) var(--radius-xl) 0;
  padding:var(--space-6) var(--space-8);
  margin:var(--space-8) 0;
  box-shadow:0 2px 12px rgba(47,150,150,.06);
}
.mk-highlight-box h3{font-family:var(--font-display);font-size:1.15rem;margin:0 0 var(--space-2);color:var(--text)}
.mk-highlight-box p{margin:0;color:var(--text-muted);line-height:1.7;font-size:.9375rem}
/* Two-col content */
.mk-two-col-prose{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-8);padding:var(--space-8) 0}
.mk-two-col-prose .mk-prose-card{margin-bottom:0}
/* Subpage CTA */
.mk-subpage-cta{margin-top:var(--space-12);padding:var(--space-10) 0;text-align:center}
.mk-subpage-cta .mk-cta-block{display:inline-block;text-align:left;min-width:min(100%, 420px)}
.mk-footer{
  margin-top:auto;
  padding:var(--space-12) var(--space-6);
  border-top:1px solid var(--border);
  background:linear-gradient(180deg, var(--bg-muted) 0%, var(--bg-base) 100%);
}
.mk-footer-inner{
  max-width:1100px;
  margin:0 auto;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-12);
  flex-wrap:wrap;
  font-size:var(--type-size-sm);
  color:var(--text-muted);
}
.mk-footer-brand{
  font-family:var(--font-display);
  font-weight:700;
  font-size:1.25rem;
  color:var(--accent);
  display:block;
  margin-bottom:var(--space-1);
}
.mk-footer-tagline{margin:0;max-width:220px;line-height:1.5;color:var(--text-faint)}
.mk-footer-col{display:flex;flex-direction:column;gap:var(--space-2)}
.mk-footer-heading{font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);margin-bottom:var(--space-1)}
.mk-footer-col a{color:var(--text-muted);text-decoration:none}
.mk-footer-col a:hover{color:var(--accent)}
.mk-footer-signin{
  font-weight:600;
  color:var(--accent);
  text-decoration:none;
}
.mk-footer-signin:hover{color:var(--accent-dark);text-decoration:none}
.mk-footer-actions{margin-left:auto;text-align:right}
.mk-inline-metrics{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  margin-top:22px;
}
.mk-inline-metrics > div{
  padding:14px;
  border-radius:14px;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(15,23,42,.1);
  backdrop-filter:blur(8px);
}
.mk-inline-metrics strong{
  display:block;
  font-family:var(--mk-font-display);
  font-size:1.06rem;
  color:var(--mk-ink);
}
.mk-inline-metrics span{display:block;margin-top:3px;color:var(--mk-soft);font-size:.82rem}
.mk-signal-card{
  padding:18px;
  border-radius:16px;
  background:linear-gradient(160deg, rgba(255,255,255,.92), rgba(240,249,243,.86));
  border:1px solid rgba(20,83,45,.18);
}
.mk-signal-card + .mk-signal-card{margin-top:12px}
.mk-signal-card h3{
  margin:0 0 10px;
  font-family:var(--mk-font-display);
  font-size:1.04rem;
  color:var(--mk-ink);
}
.mk-signal-card ul{margin:0;padding-left:18px}
.mk-signal-card li{margin:6px 0;color:var(--mk-muted)}
.mk-signal-card p{margin:0;color:var(--mk-muted)}
.mk-signal-card a{font-weight:700;color:var(--mk-primary-strong)}
.mk-signal-card.accent{
  background:linear-gradient(155deg, rgba(20,83,45,.12), rgba(255,255,255,.88));
  border-color:rgba(20,83,45,.24);
}
.mk-section{margin-top:2px}
.mk-proof-strip,.mk-band,.mk-page-hero:not(.mk-page-hero-premium),.mk-prose,.mk-feature-grid article,.mk-resource-list a,.mk-two-col article,.mk-journey-grid article,.mk-timeline article,.mk-bullet-grid > div,.mk-bento-card,.mk-suite-card,.mk-quote-grid blockquote,.mk-faq details,.mk-cta-block{
  background:var(--mk-card);
  border:1px solid var(--mk-border);
  box-shadow:0 14px 38px rgba(15,23,42,.08);
}
.mk-proof-strip{
  padding:18px 20px;
  border-radius:18px;
  border-color:rgba(15,23,42,.1);
  background:linear-gradient(90deg, rgba(255,255,255,.95), rgba(237,247,241,.95));
}
.mk-proof-intro{display:flex;gap:8px;flex-wrap:wrap;color:var(--mk-muted);font-size:.9rem}
.mk-proof-intro strong{color:var(--mk-ink)}
.mk-proof-logos{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}
.mk-logo-pill{
  display:inline-flex;
  align-items:center;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(20,83,45,.08);
  border:1px solid rgba(20,83,45,.2);
  color:var(--mk-primary);
  font-size:.78rem;
  font-weight:700;
}
.mk-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:14px;margin-bottom:16px}
.mk-section-head h2{
  margin:0;
  font-family:var(--mk-font-display);
  font-size:1.58rem;
  letter-spacing:-.02em;
  color:var(--mk-ink);
}
.mk-section-head a{font-size:.9rem;font-weight:700;color:var(--mk-primary-strong)}
.mk-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mk-feature-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.mk-feature-grid article,.mk-page-hero:not(.mk-page-hero-premium),.mk-prose,.mk-resource-list a,.mk-two-col article,.mk-journey-grid article{border-radius:18px;padding:20px}
.mk-feature-grid h3,.mk-two-col h3,.mk-journey-grid h3,.mk-bento-card h3{
  margin:0 0 8px;
  font-family:var(--mk-font-display);
  font-size:1.03rem;
  color:var(--mk-ink);
}
.mk-feature-grid p,.mk-two-col p,.mk-journey-grid p,.mk-bento-card p{margin:0;color:var(--mk-muted);line-height:1.65}
.mk-bento-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:14px}
.mk-bento-card{border-radius:18px;padding:20px}
.mk-bento-card.xl{
  grid-row:span 2;
  background:linear-gradient(140deg, rgba(255,255,255,.95), rgba(236,248,241,.95));
  border-color:rgba(20,83,45,.2);
}
.mk-bento-card ul{margin:12px 0 0;padding-left:18px}
.mk-bento-card li{margin:6px 0;color:var(--mk-muted);font-size:.91rem}
.mk-suite-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.mk-suite-grid-full{grid-template-columns:repeat(3,minmax(0,1fr))}
.mk-suite-card{
  display:block;
  border-radius:18px;
  padding:20px;
  color:inherit;
  text-decoration:none;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  background:linear-gradient(165deg, rgba(255,255,255,.96), rgba(244,249,247,.94));
}
.mk-suite-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 42px rgba(15,23,42,.13);
  border-color:var(--mk-border-strong);
  text-decoration:none;
}
.mk-suite-card h3{
  margin:0 0 8px;
  font-family:var(--mk-font-display);
  font-size:1.08rem;
  color:var(--mk-ink);
}
.mk-suite-card p{margin:0 0 12px;color:var(--mk-muted);min-height:48px}
.mk-suite-card ul{margin:0;padding-left:18px}
.mk-suite-card li{font-size:.84rem;color:var(--mk-soft);margin:4px 0}
.mk-suite-card span{display:inline-block;margin-top:12px;font-size:.82rem;color:var(--mk-primary-strong);font-weight:700}
.mk-suite-card .mk-feature-card-num{margin-bottom:var(--space-4)}
.mk-page-hero{
  margin-bottom:2px;
  border-radius:22px;
  padding:26px 24px;
  background:linear-gradient(150deg, rgba(255,255,255,.97), rgba(240,248,244,.95));
  border-color:rgba(20,83,45,.18);
}
/* Premium subpage hero: no card — same open look as homepage */
.mk-page-hero.mk-page-hero-premium{
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  padding:var(--space-24) 0;
  margin-bottom:0;
}
.mk-page-hero .mk-kicker{margin-bottom:10px}
.mk-page-hero.mk-page-hero-premium .mk-kicker{margin-bottom:var(--space-5)}
.mk-timeline{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mk-timeline article{border-radius:15px;padding:18px}
.mk-timeline h3{margin:0 0 6px;font-size:1rem;color:var(--mk-ink)}
.mk-timeline p{margin:0;color:var(--mk-muted)}
.mk-bullet-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.mk-bullet-grid > div{
  border-radius:14px;
  padding:15px 14px;
  color:var(--mk-muted);
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(242,248,245,.95));
}
.mk-journey-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mk-step-num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  background:rgba(20,83,45,.12);
  color:var(--mk-primary-strong);
  font-family:var(--mk-font-display);
  font-weight:700;
  margin-bottom:8px;
}
.mk-two-col{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:14px}
.mk-two-col ul{margin:0;padding-left:20px}
.mk-two-col li{margin:6px 0;color:var(--mk-muted)}
.mk-chip-row{display:flex;gap:8px;flex-wrap:wrap}
.mk-chip-row span{
  display:inline-flex;
  align-items:center;
  padding:7px 11px;
  border-radius:999px;
  background:rgba(20,83,45,.08);
  border:1px solid rgba(20,83,45,.2);
  color:var(--mk-primary);
  font-size:.84rem;
  font-weight:700;
}
.mk-resource-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.mk-resource-list a:hover{
  text-decoration:none;
  box-shadow:0 18px 34px rgba(15,23,42,.11);
  border-color:var(--mk-border-strong);
}
.mk-resource-list h3{
  margin:0 0 8px;
  font-size:1.02rem;
  font-family:var(--mk-font-display);
  color:var(--mk-ink);
}
.mk-resource-list p{margin:0;color:var(--mk-muted)}
.mk-prose p{margin:0 0 12px;color:var(--mk-muted);line-height:1.7}
.mk-quote-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.mk-quote-grid blockquote{
  margin:0;
  border-radius:16px;
  padding:18px;
  background:linear-gradient(170deg, rgba(255,255,255,.95), rgba(242,248,245,.95));
}
.mk-quote-grid p{margin:0;color:var(--mk-muted);font-size:.95rem;line-height:1.66}
.mk-quote-grid cite{display:block;margin-top:12px;color:var(--mk-soft);font-style:normal;font-size:.82rem;font-weight:700}
.mk-faq{display:grid;gap:11px}
.mk-faq details{border-radius:14px;padding:14px 16px}
.mk-faq summary{cursor:pointer;font-weight:700;color:var(--mk-ink)}
.mk-faq p{margin:10px 0 0;color:var(--mk-muted)}
.mk-cta-block{
  margin-top:2px;
  border-radius:24px;
  padding:28px 24px;
  background:linear-gradient(130deg, rgba(20,83,45,.11), rgba(255,255,255,.96));
  border-color:rgba(20,83,45,.26);
}
.mk-cta-block h2{
  margin:0 0 8px;
  font-family:var(--mk-font-display);
  font-size:1.58rem;
  letter-spacing:-.02em;
  color:var(--mk-ink);
}
.mk-cta-block p{margin:0;color:var(--mk-muted)}
.mk-footer{
  max-width:1240px;
  margin:18px auto 0;
  padding:24px;
  border-top:1px solid var(--mk-page-line);
  display:flex;
  justify-content:space-between;
  gap:24px;
  flex-wrap:wrap;
}
.mk-footer-brand{
  font-family:var(--mk-font-display);
  font-size:1.16rem;
  font-weight:700;
  margin-bottom:4px;
  color:var(--mk-ink);
}
.mk-footer-links{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-left:auto}
.mk-footer-links a{color:var(--mk-muted);text-decoration:none;font-size:var(--type-size-sm)}
.mk-footer-links a:hover{color:var(--mk-ink)}
.mk-footer-links .mk-footer-signin{color:var(--accent);font-weight:600}
.mk-footer-links .mk-footer-signin:hover{color:var(--accent-dark)}
.mk-main > *{
  animation:mk-fade-up .48s ease both;
}
.mk-main > *:nth-child(2){animation-delay:.04s}
.mk-main > *:nth-child(3){animation-delay:.08s}
.mk-main > *:nth-child(4){animation-delay:.12s}
.mk-main > *:nth-child(5){animation-delay:.16s}
@keyframes mk-fade-up{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:translateY(0)}
}

/* Docs editor */
.docs-editor-layout{position:relative}
.doc-editor-title-wrap .doc-editor-title{font-size:2rem;line-height:1.3;border:none;background:transparent;width:100%;padding:0}
.doc-editor-title-wrap .doc-editor-title::placeholder{color:var(--text-faint)}
.doc-editor-body .doc-blocks+.doc-editor-textarea{margin-top:16px}
.doc-editor-textarea{min-height:200px;resize:vertical;font-size:1rem;line-height:1.6}
.doc-blocks-editor{min-height:200px;font-size:1rem;line-height:1.6}
.doc-block-content{min-height:1.5em;outline:none;padding:2px 0}
.doc-block-content:empty::before{content:attr(placeholder);color:var(--text-faint)}
.doc-block{margin:0 0 8px;padding:2px 0}
.doc-block-empty{padding:8px 0}
.doc-blocks-preview.hidden{display:none}
.doc-block-grip{opacity:.6}
.doc-block-grip-btn:hover .doc-block-grip{opacity:1}
.doc-panel{border-radius:var(--radius-lg);overflow:hidden}
.doc-panel-tabs{display:flex;flex-wrap:wrap;gap:2px;padding:8px 8px 0;background:var(--bg-muted);border-bottom:1px solid var(--border)}
.doc-panel-tab{padding:8px 12px;font-size:12px;font-weight:500;border:none;background:0;cursor:pointer;color:var(--text-muted);border-radius:var(--radius-sm)}
.doc-panel-tab:hover{color:var(--text);background:var(--bg-hover)}
.doc-panel-tab.active{color:var(--accent);background:var(--bg-raised)}
.doc-panel-content{padding:16px}
.doc-panel-pane{display:none}
.doc-panel-pane.active{display:block}
.doc-save-status-ok{color:var(--success)}
.doc-outline-list .doc-outline-link{text-decoration:none;color:inherit}
.doc-outline-list .doc-outline-link:hover{color:var(--accent)}
.doc-conflict-overlay{position:fixed;inset:0;background:rgba(15,23,42,.4);display:flex;align-items:center;justify-content:center;z-index:100}
.doc-conflict-overlay.hidden{display:none}

/* Docs Home — drive-like layout */
.docs-home-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px}
.docs-home-search-wrap{display:flex;gap:8px;flex:1;min-width:200px}
.docs-home-search{max-width:320px}
.docs-home-scope{width:auto;min-width:120px}
.docs-home-actions{display:flex;gap:8px;align-items:center}
.docs-home-sections{display:flex;flex-direction:column;gap:28px}
.docs-home-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin:0 0 12px}
.docs-home-table{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.docs-home-row{display:grid;grid-template-columns:32px 1fr 120px 160px 100px;gap:16px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border);color:inherit;transition:background .15s}
.docs-home-row-selectable{text-decoration:none}
.docs-home-row-selectable .docs-home-title{text-decoration:none;color:inherit}
.docs-home-row-selectable:hover{background:var(--bg-muted)}
.docs-home-check{display:flex;align-items:center}
.docs-home-bulk-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-muted);border-radius:var(--radius-sm);margin-bottom:16px}
.docs-home-bulk-count{font-size:13px;font-weight:500}
.docs-home-card-wrap{position:relative;display:inline-block}
.docs-home-card-cb{position:absolute;top:8px;left:8px;z-index:1}
.docs-home-row:last-child{border-bottom:none}
.docs-home-row:hover{background:var(--bg-muted)}
.docs-home-row.docs-home-header{background:var(--bg-muted);font-size:12px;font-weight:600;color:var(--text-muted);cursor:default}
.docs-home-row.docs-home-header:hover{background:var(--bg-muted)}
.docs-home-col{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.docs-home-title{font-weight:500}
.docs-home-empty{grid-column:1/-1;padding:24px;text-align:center}
.docs-home-spaces{display:flex;flex-wrap:wrap;gap:12px}
.docs-home-space-card{display:inline-flex;align-items:center;padding:12px 20px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;font-weight:500;transition:border-color .15s,box-shadow .15s}
.docs-home-space-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.docs-home-filter{width:auto;min-width:100px}
.docs-home-view-toggle{display:flex;gap:2px}
.docs-home-view-btn{font-size:12px}
.docs-home-view-btn.active{background:var(--bg-muted)}
.docs-home-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.docs-home-card{display:flex;flex-direction:column;padding:16px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:border-color .15s,box-shadow .15s}
.docs-home-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.docs-home-card-title{font-weight:500;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.docs-home-card-meta{font-size:12px;color:var(--text-muted);margin-bottom:8px}
/* Docs shell: Home | Templates | Trash tabs */
.docs-shell-tabs{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:var(--radius-full);background:var(--bg-overlay);overflow:hidden;margin-bottom:var(--space-6);padding:4px}
.docs-shell-tab{display:inline-block;padding:10px 20px;font-size:var(--type-size-sm);font-weight:500;text-decoration:none;color:var(--text-muted);border-radius:var(--radius-full);transition:background .15s ease,color .15s ease}
.docs-shell-tab:hover{color:var(--text);background:var(--bg-hover)}
.docs-shell-tab.active{background:var(--accent);color:#fff;border:none}
.docs-shell-content{margin-top:0}
.docs-home-section-card{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:var(--space-5) var(--space-6);margin-bottom:var(--space-6)}
.docs-home-section-card .docs-home-section-title{margin:0 0 var(--space-4);font-size:var(--type-size-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}
.docs-home-table-card{box-shadow:var(--shadow-xs)}
.docs-home-toolbar-actions{flex-wrap:wrap;gap:var(--space-3)}
.docs-trash-settings{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);box-shadow:var(--shadow-xs)}
.docs-home-table-trash .docs-home-row{grid-template-columns:1fr 160px 100px}
.hidden{display:none!important}
/* Docs (word processor) editor */
.docs-word-editor-wrap{display:flex;flex-direction:column;height:calc(100vh - 120px);min-height:400px;background:var(--bg-base)}
.docs-word-menubar{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-raised);flex-shrink:0}
.docs-word-menubar-item{padding:4px 10px;font-size:13px;color:var(--text);cursor:pointer;border-radius:var(--radius-xs)}
.docs-word-menubar-item:hover{background:var(--bg-muted)}
.docs-word-editor-actions{margin-left:auto;display:flex;align-items:center;gap:12px}
.docs-word-save-status{font-size:12px;color:var(--text-muted)}
.docs-word-toolbar{display:flex;align-items:center;gap:6px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-overlay);flex-shrink:0}
.docs-word-font{width:140px}.docs-word-size{width:64px}
.docs-word-toolbar-sep{width:1px;height:20px;background:var(--border);margin:0 4px}
.docs-word-toolbar .docs-word-word-count{font-size:12px;color:var(--text-muted);margin-left:8px}
.docs-word-ruler{height:24px;background:var(--bg-overlay);border-bottom:1px solid var(--border);flex-shrink:0}
.docs-word-ruler-inner{max-width:612px;margin:0 auto;height:100%;border-left:1px solid var(--border);border-right:1px solid var(--border)}
.docs-word-editor-body{display:flex;flex:1;overflow:hidden;position:relative}
.docs-word-panel{direction:ltr;position:absolute;top:0;bottom:0;width:280px;max-width:45vw;background:var(--bg-raised);border:1px solid var(--border);box-shadow:var(--shadow-card);z-index:40;display:flex;flex-direction:column;overflow:hidden;transition:transform .2s ease}
.docs-word-panel-left{left:0;transform:translateX(-100%)}
.docs-word-panel-left.docs-word-panel-open{transform:translateX(0)}
.docs-word-panel-right{right:0;transform:translateX(100%)}
.docs-word-panel-right.docs-word-panel-open{transform:translateX(0)}
.docs-word-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid var(--border);flex-shrink:0}
.docs-word-panel-tabs{display:flex;flex-wrap:wrap;gap:4px}
.docs-word-panel-tab{padding:4px 8px;font-size:12px;background:0;border:0;cursor:pointer;color:var(--text-muted)}
.docs-word-panel-tab:hover,.docs-word-panel-tab.active{color:var(--text)}
.docs-word-panel-tab-body{flex:1;overflow:auto;padding:12px;display:flex;flex-direction:column}
.docs-word-panel-tab-body.hidden{display:none}
.docs-word-canvas-wrap{flex:1;overflow:auto;padding:24px;display:flex;flex-direction:column;align-items:center}
.docs-word-doc-title-wrap{width:100%;max-width:612px;margin-bottom:8px}
.docs-word-doc-title-input{width:100%;font-size:18px;font-weight:600;border:none;background:transparent;padding:4px 0;outline:0;color:var(--text)}
.docs-word-canvas{min-width:612px;max-width:612px;min-height:792px;padding:72px;background:#fff;box-shadow:var(--shadow-lg);border:1px solid var(--border);border-radius:2px;font-family:Georgia,serif;font-size:12pt;line-height:1.5;color:#1a1a1a;outline:0}
.docs-word-version-row,.docs-word-comment{padding:8px 0;border-bottom:1px solid var(--border-muted)}
.docs-word-comment-add{padding:12px 0;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:8px}
.docs-word-dropdown{position:absolute;top:100%;left:0;margin-top:4px;min-width:220px;max-height:70vh;overflow:auto;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-modal);z-index:50;padding:4px 0}
.docs-word-dropdown hr{margin:4px 0;border:0;border-top:1px solid var(--border)}
.docs-word-dropdown-item{display:block;width:100%;padding:8px 14px;text-align:left;font-size:13px;background:0;border:0;cursor:pointer;color:var(--text)}
.docs-word-dropdown-item:hover{background:var(--bg-muted)}
.docs-word-menubar-item{position:relative}
.docs-word-mode-tabs{display:flex;margin-left:12px}
.docs-word-mode-btn{padding:4px 10px;font-size:12px;background:0;border:1px solid transparent;border-radius:var(--radius-xs);cursor:pointer;color:var(--text-muted)}
.docs-word-mode-btn:hover{color:var(--text)}
.docs-word-mode-btn.active{background:var(--bg-muted);color:var(--text)}
.docs-templates-category{margin-bottom:28px}
.docs-templates-category-title{font-size:13px;font-weight:600;color:var(--text-muted);margin:0 0 12px}

/* Database (spreadsheet) workbook editor */
.db-editor-wrap{display:flex;flex-direction:column;height:calc(100vh - 120px);min-height:400px;background:var(--bg-base)}
.db-editor-header{display:flex;align-items:center;gap:12px;padding:8px 12px;border-bottom:1px solid var(--border);background:var(--bg-raised);flex-shrink:0}
.db-editor-title-input{font-size:16px;font-weight:600;border:none;background:transparent;padding:4px 8px;border-radius:var(--radius-xs);flex:1;min-width:0;max-width:400px}
.db-editor-title-input:focus{outline:0;box-shadow:0 0 0 2px var(--color-focus-ring)}
.db-editor-breadcrumb{font-size:12px;color:var(--text-muted)}
.db-editor-header-actions{display:flex;align-items:center;gap:8px}
.db-editor-menubar{display:flex;align-items:center;gap:2px;padding:4px 8px;border-bottom:1px solid var(--border);background:var(--bg-overlay);flex-shrink:0}
.db-editor-menu-item{padding:6px 12px;font-size:13px;color:var(--text);cursor:pointer;border-radius:var(--radius-xs);border:none;background:0}
.db-editor-menu-item:hover{background:var(--bg-muted)}
.db-editor-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;border-bottom:1px solid var(--border);background:var(--bg-raised);flex-shrink:0}
.db-editor-toolbar .btn{padding:4px 8px;font-size:12px}
.db-editor-formula-bar{display:flex;align-items:stretch;gap:8px;padding:4px 12px;border-bottom:1px solid var(--border);background:var(--bg-overlay);flex-shrink:0}
.db-editor-name-box{width:100px;padding:6px 8px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg-raised)}
.db-editor-formula-input{flex:1;padding:6px 8px;font-size:13px;font-family:var(--type-font-mono);border:1px solid var(--border);border-radius:var(--radius-xs);background:var(--bg-raised)}
.db-editor-formula-input:focus{outline:0;border-color:var(--accent)}
.db-editor-grid-wrap{flex:1;overflow:auto;padding:16px}
.db-sheet-grid{border-collapse:collapse;font-size:13px;background:var(--bg-raised);box-shadow:var(--shadow-card)}
.db-sheet-grid th,.db-sheet-grid td{border:1px solid var(--border);padding:2px 6px;min-width:80px;height:24px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.db-sheet-grid th{background:var(--bg-muted);font-weight:600;font-size:11px;text-align:center;color:var(--text-muted);position:sticky;top:0;z-index:2}
.db-sheet-grid td{background:var(--surface);cursor:cell}
.db-sheet-grid td.selected{outline:2px solid var(--accent);outline-offset:-1px;z-index:1}
.db-sheet-grid td input.cell-edit{width:100%;min-width:60px;border:0;padding:2px 4px;font:inherit;background:var(--bg-overlay);outline:0}
.db-sheet-tabs{display:flex;align-items:center;gap:4px;padding:4px 12px;border-top:1px solid var(--border);background:var(--bg-raised);flex-shrink:0}
.db-sheet-tab{padding:6px 12px;font-size:12px;border:1px solid transparent;border-radius:var(--radius-xs);cursor:pointer;background:0;color:var(--text)}
.db-sheet-tab:hover{background:var(--bg-muted)}
.db-sheet-tab.active{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.db-sheet-tab-wrap{display:inline-flex;align-items:center;gap:2px;margin-right:2px}
.db-sheet-tab-wrap.active .db-sheet-tab{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.db-sheet-tab-delete{padding:0 4px;font-size:14px;line-height:1;color:var(--text-muted);cursor:pointer;border:none;background:0;border-radius:var(--radius-xs)}
.db-sheet-tab-delete:hover{color:var(--danger);background:var(--bg-muted)}
.db-sheet-tab-add{padding:4px 8px;font-size:14px;color:var(--text-muted);cursor:pointer;border:none;background:0;border-radius:var(--radius-xs)}
.db-sheet-tab-add:hover{background:var(--bg-muted);color:var(--text)}
.db-editor-status-bar{display:flex;align-items:center;gap:16px;padding:4px 12px;font-size:11px;color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-overlay);flex-shrink:0}

.dropdown-wrap{position:relative}
.dropdown-menu{position:absolute;top:100%;left:0;margin-top:4px;min-width:160px;background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-modal);z-index:40;padding:4px}
.dropdown-menu.hidden{display:none}
.dropdown-item{display:block;width:100%;padding:8px 12px;text-align:left;border:none;background:0;cursor:pointer;font-size:14px;border-radius:var(--radius-xs)}
.dropdown-item:hover{background:var(--bg-muted)}
.tag-default{background:var(--bg-muted);color:var(--text-muted)}

/* Professional dashboard overrides (ensure minimal visuals) */
body{background:var(--bg-base)}
::focus-visible{box-shadow:0 0 0 3px var(--color-focus-ring)}


@media (max-width: 880px){
  .app-sidebar{display:none}
  .app-topbar-search-trigger{display:none}
  .app-main{padding:16px}
  .mk-topbar{margin:10px 12px 0;padding:11px 12px}
  .mk-nav{display:none}
  .mk-main{padding:16px 14px 34px;gap:20px}
  .mk-hero{grid-template-columns:1fr;padding:22px}
  .mk-inline-metrics{grid-template-columns:1fr}
  .mk-feature-grid,.mk-feature-grid-3,.mk-bento-grid,.mk-suite-grid,.mk-suite-grid-full,.mk-resource-list,.mk-timeline,.mk-bullet-grid,.mk-journey-grid,.mk-two-col,.mk-quote-grid,.mk-feature-cards,.mk-stats,.mk-pillar-grid,.mk-two-col-prose,.mk-page-stats,.mk-key-strip{grid-template-columns:1fr}
  .mk-bento-card.xl{grid-row:auto}
  .mk-footer{padding:16px 14px 24px;margin-top:8px}
  .mk-hero-premium,.mk-page-hero-premium{padding:var(--space-12) 0}
  .mk-product-preview-side{width:120px}
  .mk-product-preview-body{min-height:240px}
  .mk-footer-inner{flex-direction:column;align-items:flex-start;gap:var(--space-8)}
  .mk-footer-actions{margin-left:0;margin-top:var(--space-4)}
}
