/* AuraPost global stylesheet. Keep visual styling here, not in templates. */

/* Theme tokens inspired by the supplied AuraPost logo proposal. */
:root,
:root[data-theme="dark"] {
  color-scheme: dark;
  --primary: #6c47ff;
  --primary-rgb: 108, 71, 255;
  --accent: #00d4aa;
  --accent-rgb: 0, 212, 170;
  --danger: #ff4f8b;
  --danger-rgb: 255, 79, 139;
  --warn: #f59e0b;
  --warn-rgb: 245, 158, 11;
  --success: #00d4aa;
  --success-rgb: 0, 212, 170;
  --dark: #0f0f1a;
  --dark-rgb: 15, 15, 26;
  --dark-2: #0a0b16;
  --surface: #16162a;
  --surface-rgb: 22, 22, 42;
  --surface-2: #1e1e38;
  --surface-2-rgb: 30, 30, 56;
  --text: #f0f0ff;
  --text-soft: #d7d7f2;
  --text-muted: #8888aa;
  --text-muted-rgb: 136, 136, 170;
  --border: #2a2a48;
  --border-rgb: 42, 42, 72;
  --logo-text: #f0f0ff;
  --logo-bg-start: #14162b;
  --logo-bg-end: #0a0b16;
  --logo-gold-start: #ffe28a;
  --logo-gold-end: #f59e0b;
  --logo-violet-start: #a78bfa;
  --logo-violet-core: #7c3aed;
  --logo-violet-end: #00d4aa;
  --logo-purple: #6c47ff;
}

:root[data-theme="light"] {
  color-scheme: light;
  --primary: #6c47ff;
  --primary-rgb: 108, 71, 255;
  --accent: #008f78;
  --accent-rgb: 0, 143, 120;
  --danger: #e11d48;
  --danger-rgb: 225, 29, 72;
  --warn: #d97706;
  --warn-rgb: 217, 119, 6;
  --success: #008f78;
  --success-rgb: 0, 143, 120;
  --dark: #f8faff;
  --dark-rgb: 248, 250, 255;
  --dark-2: #eef2ff;
  --surface: #ffffff;
  --surface-rgb: 255, 255, 255;
  --surface-2: #f4f2ff;
  --surface-2-rgb: 244, 242, 255;
  --text: #14162b;
  --text-soft: #24284a;
  --text-muted: #626680;
  --text-muted-rgb: 98, 102, 128;
  --border: #daddef;
  --border-rgb: 218, 221, 239;
  --logo-text: #14162b;
}

body {
  background: var(--dark);
  color: var(--text);
}

/* Logo */
.ap-logo {
  display: block;
  flex-shrink: 0;
  height: 40px;
  width: auto;
  overflow: visible;
  color: var(--logo-text);
}

.home-nav .ap-logo,
.pricing-nav .ap-logo,
.checkout-shell nav .ap-logo,
.login-nav .ap-logo,
.signup-nav .ap-logo,
.auth-nav .ap-logo {
  height: 44px;
}

.footer-brand {
  display: inline-flex;
  align-items: center;
}

.footer-brand .ap-logo {
  height: 32px;
}

.ap-glow-anim {
  animation: ap-glow 2.4s ease-in-out infinite;
}

@keyframes ap-glow {
  0%, 100% { opacity: 1; }
  50% { opacity: .55; }
}

.utility-floating {
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 10px;
}

.theme-toggle {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(var(--border-rgb), .82);
  border-radius: 10px;
  background: rgba(var(--surface-rgb), .92);
  color: var(--text);
  cursor: pointer;
  box-shadow: 0 12px 28px rgba(0, 0, 0, .18);
  transition: border-color .18s, background .18s, color .18s;
}

.theme-toggle:hover {
  border-color: rgba(var(--primary-rgb), .55);
  color: var(--primary);
}

.theme-toggle svg {
  width: 18px;
  height: 18px;
}

.theme-toggle .theme-icon-sun,
:root[data-theme="light"] .theme-toggle .theme-icon-moon {
  display: none;
}

:root[data-theme="light"] .theme-toggle .theme-icon-sun {
  display: block;
}

.is-hidden {
  display: none !important;
}

.is-fading {
  opacity: 0;
}

.hover-opacity:hover { opacity: .85; }
.hover-primary-bg:hover { background: rgba(var(--primary-rgb), .12); }
.hover-primary-bg-soft:hover { background: rgba(var(--primary-rgb), .08); }
.text-danger-token { color: var(--danger); }
.text-muted-token { color: var(--text-muted); }
.text-primary-token { color: var(--primary); }
.text-accent-token { color: var(--accent); }
.tenant-status { color: var(--danger); }
.tenant-status-active { color: var(--accent); }
.tenant-status-trialing { color: var(--warn); }
.ob-progress-fill.progress-step-1 { width: 10%; }
.ob-progress-fill.progress-step-2 { width: 32%; }
.ob-progress-fill.progress-step-3 { width: 55%; }
.ob-progress-fill.progress-step-4 { width: 78%; }
.ob-progress-fill.progress-step-5 { width: 100%; }
.field-hint.is-valid { color: var(--accent); }
.edit-panel { display: none; margin-top: 12px; }
.edit-panel.is-open { display: block; }
#accountChevron.is-open { transform: rotate(180deg); }
.strength-seg.is-danger { background: var(--danger); }
.strength-seg.is-warn { background: var(--warn); }
.strength-seg.is-good { background: var(--accent); }
.password-strength-label.is-danger { color: var(--danger); }
.password-strength-label.is-warn { color: var(--warn); }
.password-strength-label.is-good { color: var(--accent); }
.shadow-primary-sm { box-shadow: 0 0 18px rgba(var(--primary-rgb), .42); }
.shadow-primary-md { box-shadow: 0 0 24px rgba(var(--primary-rgb), .28); }
.shadow-primary-lg { box-shadow: 0 0 30px rgba(var(--primary-rgb), .34); }
.sparkline-primary { stroke: var(--primary); }
.sparkline-accent { stroke: var(--accent); }
.icon-primary-stroke { color: var(--primary); }
.inline-toast { transition: opacity .5s; }
    @keyframes pulse-warn {
      0%, 100% { box-shadow: 0 0 0 0 rgba(var(--primary-rgb), .35); }
      50% { box-shadow: 0 0 0 8px rgba(var(--primary-rgb), 0); }
    }
    @keyframes pulse-green {
      0%, 100% { box-shadow: 0 0 0 0 rgba(var(--accent-rgb), .35); }
      50% { box-shadow: 0 0 0 8px rgba(var(--accent-rgb), 0); }
    }
    .pulse-warn { animation: pulse-warn 1.8s ease-in-out infinite; }
    .pulse-green { animation: pulse-green 1.8s ease-in-out infinite; }
    .bg-primary.text-white {
      color: #fff !important;
    }
    .sr-only {
      position: absolute;
      width: 1px;
      height: 1px;
      padding: 0;
      margin: -1px;
      overflow: hidden;
      clip: rect(0, 0, 0, 0);
      white-space: nowrap;
      border: 0;
    }

/*  */
.login-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }

  .login-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.login-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }

  .login-input {
    width: 100%;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 10px;
    background: rgba(var(--surface-2-rgb), .9);
    color: var(--text);
    font-size: 14px;
    outline: none;
    padding: 12px 14px;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }

  .login-input:focus {
    border-color: rgba(var(--primary-rgb), .78);
    background: rgba(var(--surface-2-rgb), 1);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14);
  }

  .login-input::placeholder {
    color: rgba(var(--text-muted-rgb), .72);
  }

  .login-divider {
    border: none;
    border-top: 1px solid rgba(var(--border-rgb), .7);
    margin: 0;
  }

/*  */
.auth-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }
  .auth-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.auth-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }
  .auth-input {
    width: 100%;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 10px;
    background: rgba(var(--surface-2-rgb), .9);
    color: var(--text);
    font-size: 14px;
    outline: none;
    padding: 12px 14px;
    transition: border-color .2s ease, box-shadow .2s ease;
  }
  .auth-input:focus {
    border-color: rgba(var(--primary-rgb), .78);
    background: rgba(var(--surface-2-rgb), 1);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14);
  }
  .auth-input::placeholder { color: rgba(var(--text-muted-rgb), .72); }

/*  */
.auth-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }
  .auth-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.auth-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }

/*  */
.auth-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }
  .auth-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.auth-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }
  .auth-input {
    width: 100%;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 10px;
    background: rgba(var(--surface-2-rgb), .9);
    color: var(--text);
    font-size: 14px;
    outline: none;
    padding: 12px 14px;
    transition: border-color .2s ease, box-shadow .2s ease;
  }
  .auth-input:focus {
    border-color: rgba(var(--primary-rgb), .78);
    background: rgba(var(--surface-2-rgb), 1);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14);
  }
  .auth-input::placeholder { color: rgba(var(--text-muted-rgb), .72); }
  .strength-seg {
    height: 3px;
    flex: 1;
    border-radius: 999px;
    background: rgba(var(--border-rgb), .95);
    transition: background .2s ease;
  }

/*  */
.auth-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }
  .auth-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.auth-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }

/*  */
.signup-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }

  .signup-nav {
    border-bottom: 1px solid rgba(var(--border-rgb), .72);
    background: rgba(var(--dark-rgb), .82);
    backdrop-filter: blur(18px);
  }
.step-connector {
    height: 2px;
    width: 72px;
    background: rgba(var(--border-rgb), .9);
  }

  .signup-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }

  .signup-input {
    width: 100%;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 10px;
    background: rgba(var(--surface-2-rgb), .9);
    color: var(--text);
    font-size: 14px;
    outline: none;
    padding: 12px 14px;
    transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
  }

  .signup-input:focus {
    border-color: rgba(var(--primary-rgb), .78);
    background: rgba(var(--surface-2-rgb), 1);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14);
  }

  .signup-input::placeholder {
    color: rgba(var(--text-muted-rgb), .72);
  }

  .signup-input.field-success {
    border-color: rgba(var(--accent-rgb), .66);
  }

  .signup-input.field-error {
    border-color: rgba(var(--danger-rgb), .72);
  }

  [data-password-primary],
  [data-password-confirm] {
    padding-right: 76px;
  }

  .plan-radio {
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }

  .plan-box {
    border: 1.5px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-2-rgb), .72);
    transition: border-color .2s ease, background .2s ease, transform .2s ease;
  }

  .plan-box:hover {
    border-color: rgba(var(--primary-rgb), .4);
    transform: translateY(-1px);
  }

  .plan-radio:checked + .plan-box {
    border-color: rgba(var(--primary-rgb), .9);
    background: rgba(var(--primary-rgb), .12);
  }

  .strength-seg {
    height: 3px;
    flex: 1;
    border-radius: 999px;
    background: rgba(var(--border-rgb), .95);
    transition: background .2s ease;
  }

  @media (max-width: 640px) {
    .step-connector {
      width: 36px;
    }
  }

/*  */
.checkout-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 52%, var(--dark) 100%);
  }
.checkout-card {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .9);
    box-shadow: 0 40px 90px rgba(0, 0, 0, .38);
  }

  .checkout-input {
    width: 100%;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 10px;
    background: rgba(var(--dark-rgb), .88);
    color: var(--text);
    font-size: 14px;
    outline: none;
    padding: 12px 14px;
  }

  .checkout-input:focus {
    border-color: rgba(var(--primary-rgb), .78);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .14);
  }

/*  */
.pricing-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 48%, var(--dark) 100%);
  }

  .pricing-nav {
    position: sticky;
    top: 0;
    z-index: 40;
    border-bottom: 1px solid rgba(var(--border-rgb), .88);
    background: rgba(var(--dark-rgb), .84);
    backdrop-filter: blur(18px);
  }
.billing-track {
    position: relative;
    height: 26px;
    width: 48px;
    border: 1px solid rgba(var(--border-rgb), .95);
    border-radius: 999px;
    background: var(--surface-2);
    transition: background .2s ease, border-color .2s ease;
  }

  .billing-track[aria-pressed="true"] {
    border-color: rgba(var(--primary-rgb), .75);
    background: var(--primary);
  }

  .billing-thumb {
    position: absolute;
    left: 3px;
    top: 3px;
    height: 18px;
    width: 18px;
    border-radius: 999px;
    background: white;
    transition: transform .2s ease;
  }

  .billing-track[aria-pressed="true"] .billing-thumb {
    transform: translateX(22px);
  }

  .pricing-card {
    transition: border-color .2s ease, transform .2s ease;
  }

  .pricing-card:hover {
    border-color: rgba(var(--accent-rgb), .35);
    transform: translateY(-3px);
  }

  .pricing-card.is-featured {
    background: linear-gradient(160deg, rgba(var(--primary-rgb), .18), rgba(var(--surface-rgb), .96));
    box-shadow: 0 32px 64px rgba(var(--primary-rgb), .14);
  }

  .pricing-card.is-featured:hover {
    transform: translateY(-6px);
  }

/*  */
.home-shell {
    min-height: 100vh;
    background: linear-gradient(180deg, var(--dark) 0%, var(--dark-2) 48%, var(--dark) 100%);
  }

  .home-nav {
    position: sticky;
    top: 0;
    z-index: 40;
    border-bottom: 1px solid rgba(var(--border-rgb), .88);
    background: rgba(var(--dark-rgb), .84);
    backdrop-filter: blur(18px);
  }
.hero-visual {
    border: 1px solid rgba(var(--border-rgb), .95);
    background: rgba(var(--surface-rgb), .86);
    box-shadow: 0 36px 110px rgba(0, 0, 0, .36);
  }

  .pipeline-row {
    display: grid;
    grid-template-columns: 44px 1fr auto;
    gap: 14px;
    align-items: center;
    border: 1px solid rgba(var(--border-rgb), .9);
    background: rgba(var(--surface-2-rgb), .72);
  }

  .pulse-live {
    animation: pulse-live 1.8s ease-in-out infinite;
  }

  .feature-card,
  .plan-preview-card {
    transition: border-color .2s ease, transform .2s ease;
  }

  .feature-card:hover,
  .plan-preview-card:hover {
    border-color: rgba(var(--accent-rgb), .35);
    transform: translateY(-2px);
  }

  @keyframes pulse-live {
    0%, 100% { box-shadow: 0 0 0 0 rgba(var(--accent-rgb), .34); }
    50% { box-shadow: 0 0 0 9px rgba(var(--accent-rgb), 0); }
  }

  @media (max-width: 760px) {
    .pipeline-row {
      grid-template-columns: 38px 1fr;
    }

    .pipeline-row .status-chip {
      grid-column: 2;
      justify-self: start;
    }
  }

/*  */

  /* ── Shell ── */
  .ob-shell {
    display: flex;
    height: 100vh;
    overflow: hidden;
    background: var(--dark);
  }

  /* ══════════════════════════════════
     LEFT PANEL
  ══════════════════════════════════ */
  .ob-left {
    width: 300px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border-right: 1px solid rgba(var(--border-rgb),.8);
    padding: 28px 24px;
    overflow-y: auto;
  }

  .ob-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 40px;
    text-decoration: none;
  }
  .ob-logo .ap-logo { height: 38px; }
/* Stepper */
  .ob-stepper { flex: 1; }
  .ob-step {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    position: relative;
    padding-bottom: 28px;
  }
  .ob-step:last-child { padding-bottom: 0; }

  /* Connecting line */
  .ob-step:not(:last-child)::before {
    content: '';
    position: absolute;
    left: 16px;
    top: 36px;
    bottom: 0;
    width: 2px;
    background: rgba(var(--border-rgb),.9);
  }
  .ob-step.is-done:not(:last-child)::before {
    background: rgba(var(--accent-rgb),.3);
  }
  .ob-step.is-active:not(:last-child)::before {
    background: linear-gradient(to bottom, rgba(var(--primary-rgb),.5), rgba(var(--border-rgb),.9));
  }

  .ob-step-circle {
    width: 34px; height: 34px;
    border-radius: 50%;
    display: grid; place-items: center;
    font-size: 12px; font-weight: 700;
    flex-shrink: 0;
    border: 2px solid rgba(var(--border-rgb),.95);
    color: var(--text-muted);
    background: var(--surface-2);
    transition: all .2s;
    position: relative; z-index: 1;
  }
  .ob-step.is-done .ob-step-circle {
    border-color: rgba(var(--accent-rgb),.6);
    background: rgba(var(--accent-rgb),.1);
    color: var(--accent);
  }
  .ob-step.is-active .ob-step-circle {
    border-color: var(--primary);
    background: var(--primary);
    color: #fff;
    box-shadow: 0 0 0 4px rgba(var(--primary-rgb),.2);
  }

  .ob-step-body { padding-top: 5px; min-width: 0; }
  .ob-step-label {
    font-size: 13px; font-weight: 600;
    color: var(--text-muted);
    transition: color .2s;
    line-height: 1.3;
  }
  .ob-step.is-done .ob-step-label { color: var(--accent); }
  .ob-step.is-active .ob-step-label { color: var(--text); }
  .ob-step-sub {
    font-size: 11px; color: rgba(var(--text-muted-rgb),.6);
    margin-top: 2px; line-height: 1.4;
  }
  .ob-step.is-active .ob-step-sub { color: var(--text-muted); }

  /* Bottom tip */
  .ob-tip {
    margin-top: 32px;
    padding: 14px 16px;
    background: rgba(var(--primary-rgb),.07);
    border: 1px solid rgba(var(--primary-rgb),.18);
    border-radius: 12px;
  }
  .ob-tip-label {
    font-size: 10px; font-weight: 700; letter-spacing: .06em;
    text-transform: uppercase; color: var(--primary); margin-bottom: 6px;
  }
  .ob-tip-text { font-size: 12px; color: var(--text-muted); line-height: 1.6; }

  /* Trial badge */
  .ob-trial-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 11px; font-weight: 700;
    background: rgba(var(--accent-rgb),.1);
    color: var(--accent);
    border: 1px solid rgba(var(--accent-rgb),.25);
    border-radius: 99px;
    padding: 4px 10px;
    margin-top: 20px;
    align-self: flex-start;
  }

  /* ══════════════════════════════════
     RIGHT PANEL
  ══════════════════════════════════ */
  .ob-right {
    flex: 1;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
  }

  .ob-right-inner {
    flex: 1;
    max-width: 700px;
    width: 100%;
    margin: 0 auto;
    padding: 48px 40px 60px;
  }

  /* Progress bar */
  .ob-progress-bar {
    height: 3px;
    background: rgba(var(--border-rgb),.6);
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: 40px;
  }
  .ob-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--primary), var(--accent));
    border-radius: 99px;
    transition: width .4s ease;
  }

  /* Step heading */
  .ob-step-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 11px; font-weight: 700; letter-spacing: .04em;
    color: var(--primary); background: rgba(var(--primary-rgb),.1);
    border: 1px solid rgba(var(--primary-rgb),.25);
    border-radius: 99px; padding: 4px 12px;
    margin-bottom: 14px;
  }
  .ob-heading {
    font-family: 'Plus Jakarta Sans', sans-serif;
    font-size: 26px; font-weight: 800;
    color: var(--text); line-height: 1.2;
    letter-spacing: -.4px; margin-bottom: 8px;
  }
  .ob-subheading {
    font-size: 14px; color: var(--text-muted);
    line-height: 1.6; margin-bottom: 32px;
  }

  /* Form elements */
  .ob-card {
    background: var(--surface);
    border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 14px;
    padding: 22px 24px;
    margin-bottom: 14px;
  }
  .ob-card-title {
    font-size: 13px; font-weight: 700; color: var(--text);
    margin-bottom: 16px;
  }
  .ob-card-divider { border: none; border-top: 1px solid rgba(var(--border-rgb),.5); margin: 16px 0; }

  .field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
  .field-row.single { grid-template-columns: 1fr; }
  .field-row.col-3 { grid-template-columns: 1fr 1fr 1fr; }
  .field-block { display: flex; flex-direction: column; }
  .field-label {
    font-size: 12px; font-weight: 600; color: var(--text-soft);
    margin-bottom: 6px;
  }
  .field-opt { font-weight: 400; color: var(--text-muted); font-size: 11px; margin-left: 4px; }
  .ob-input, .ob-select, .ob-textarea {
    background: rgba(var(--surface-2-rgb),.9);
    border: 1px solid rgba(var(--border-rgb),.95);
    border-radius: 9px;
    color: var(--text); font-size: 13px;
    padding: 10px 13px;
    outline: none;
    transition: border-color .2s, box-shadow .2s, background .2s;
    font-family: inherit;
    width: 100%; box-sizing: border-box;
  }
  .ob-input:focus, .ob-select:focus, .ob-textarea:focus {
    border-color: rgba(var(--primary-rgb),.7);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb),.12);
    background: rgba(var(--surface-2-rgb),1);
  }
  .ob-input::placeholder, .ob-textarea::placeholder { color: rgba(var(--text-muted-rgb),.55); }
  .ob-textarea { resize: vertical; min-height: 88px; }
  .ob-select { cursor: pointer; }
  .field-hint { font-size: 11px; color: var(--text-muted); margin-top: 5px; }

  /* Tone / choice chips */
  .chip-grid { display: flex; flex-wrap: wrap; gap: 8px; }
  .chip-radio { position: absolute; opacity: 0; pointer-events: none; }
  .chip-label {
    display: flex; align-items: center; gap: 6px;
    padding: 7px 14px; border-radius: 99px;
    font-size: 12px; font-weight: 600;
    border: 1.5px solid rgba(var(--border-rgb),.9);
    color: var(--text-muted); cursor: pointer;
    transition: all .15s; background: rgba(var(--surface-2-rgb),.6);
  }
  .chip-label:hover { border-color: rgba(var(--primary-rgb),.4); color: var(--text); }
  .chip-radio:checked + .chip-label {
    border-color: rgba(var(--primary-rgb),.8);
    background: rgba(var(--primary-rgb),.12);
    color: var(--primary);
  }

  /* Platform choice cards */
  .choice-grid { display: grid; gap: 12px; grid-template-columns: repeat(3, 1fr); }
  .choice-input { position: absolute; opacity: 0; pointer-events: none; }
  .choice-card {
    border: 1.5px solid rgba(var(--border-rgb),.9);
    background: rgba(var(--surface-2-rgb),.6);
    border-radius: 12px; padding: 20px 14px;
    text-align: center; cursor: pointer;
    transition: all .15s;
    display: flex; flex-direction: column; align-items: center; gap: 10px;
  }
  .choice-card:hover { border-color: rgba(var(--primary-rgb),.4); transform: translateY(-1px); }
  .choice-input:checked + .choice-card {
    border-color: rgba(var(--primary-rgb),.9);
    background: rgba(var(--primary-rgb),.1);
  }
  .choice-icon { font-size: 26px; line-height: 1; }
  .choice-name { font-size: 13px; font-weight: 700; color: var(--text); }
  .choice-sub { font-size: 11px; color: var(--text-muted); }

  /* Resource list */
  .resource-list { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; }
  .resource-row {
    display: flex; align-items: center; gap: 12px;
    background: rgba(var(--surface-2-rgb),.5);
    border: 1px solid rgba(var(--border-rgb),.7);
    border-radius: 10px; padding: 11px 14px;
  }
  .resource-icon {
    width: 32px; height: 32px; border-radius: 8px;
    display: grid; place-items: center; font-size: 16px; flex-shrink: 0;
  }
  .resource-body { flex: 1; min-width: 0; }
  .resource-name { font-size: 13px; font-weight: 600; color: var(--text); }
  .resource-sub {
    font-size: 11px; color: var(--text-muted); margin-top: 1px;
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  }

  /* Badges */
  .badge {
    display: inline-flex; align-items: center;
    padding: 2px 8px; border-radius: 6px;
    font-size: 10px; font-weight: 800;
    letter-spacing: .3px; text-transform: uppercase;
  }
  .badge-rss, .badge-keyword { background: rgba(var(--primary-rgb),.12); color: var(--primary); }
  .badge-url, .badge-manual { background: rgba(var(--accent-rgb),.1); color: var(--accent); }
  .badge-linkedin { background: rgba(10,102,194,.15); color: #5BA8D4; }
  .badge-instagram { background: rgba(225,48,108,.12); color: #E1306C; }
  .badge-facebook { background: rgba(66,103,178,.12); color: #7B9CE0; }

  /* Day/hour pickers */
  .picker-grid { display: flex; flex-wrap: wrap; gap: 8px; }
  .picker-btn {
    padding: 8px 14px; border-radius: 8px;
    font-size: 12px; font-weight: 700;
    border: 1.5px solid rgba(var(--border-rgb),.9);
    color: var(--text-muted); cursor: pointer;
    background: rgba(var(--surface-2-rgb),.6);
    transition: all .15s;
  }
  .picker-btn:hover { border-color: rgba(var(--primary-rgb),.4); color: var(--text); }
  .picker-btn.active {
    border-color: rgba(var(--primary-rgb),.8);
    background: rgba(var(--primary-rgb),.12);
    color: var(--primary);
  }
  .picker-btn.hour { padding: 6px 10px; font-size: 11px; border-radius: 7px; }

  /* Cron preview */
  .cron-preview {
    background: rgba(var(--dark-rgb),.8);
    border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 10px; padding: 12px 16px;
    display: flex; align-items: center; gap: 10px;
    font-size: 12px; color: var(--text-muted); margin-top: 14px;
  }
  .cron-value {
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px; color: var(--primary); font-weight: 600;
  }

  /* Review (step 5) */
  .review-card {
    background: var(--surface);
    border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 12px; padding: 18px 20px; margin-bottom: 12px;
  }
  .review-header {
    display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px;
  }
  .review-section-label {
    font-size: 10px; font-weight: 700; letter-spacing: .07em;
    text-transform: uppercase; color: var(--text-muted);
  }
  .review-edit { font-size: 12px; font-weight: 600; color: var(--primary); text-decoration: none; }
  .review-edit:hover { text-decoration: underline; }
  .review-grid { display: grid; grid-template-columns: 120px 1fr; gap: 8px; font-size: 13px; }
  .review-key { color: var(--text-muted); }
  .review-val { color: var(--text); font-weight: 500; }

  /* Approval mode cards */
  .mode-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
  .mode-input { position: absolute; opacity: 0; pointer-events: none; }
  .mode-card {
    display: block; position: relative;
    border: 2px solid rgba(var(--border-rgb), 1);
    background: var(--surface);
    border-radius: 12px; padding: 16px;
    cursor: pointer; transition: border-color .18s, background .18s, box-shadow .18s;
  }
  .mode-card:hover {
    border-color: rgba(var(--primary-rgb), .45);
    background: rgba(var(--surface-2-rgb), .65);
  }
  .mode-input:checked + .mode-card {
    border-color: var(--primary);
    background: rgba(var(--primary-rgb), .07);
    box-shadow: 0 0 0 3px rgba(var(--primary-rgb), .13);
  }
  .mode-card::before {
    content: '';
    position: absolute; top: 13px; right: 13px;
    width: 16px; height: 16px; border-radius: 50%;
    border: 2px solid rgba(var(--border-rgb), 1);
    background: var(--surface);
    transition: background .18s, border-color .18s;
  }
  .mode-input:checked + .mode-card::before {
    background: var(--primary);
    border-color: var(--primary);
    box-shadow: inset 0 0 0 3px var(--surface);
  }
  .mode-icon { font-size: 22px; margin-bottom: 8px; }
  .mode-name { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 3px; }
  .mode-desc { font-size: 11px; color: var(--text-muted); line-height: 1.5; }

  /* Warning */
  .ob-warn {
    background: rgba(var(--primary-rgb),.07);
    border: 1px solid rgba(var(--primary-rgb),.25);
    border-radius: 10px; padding: 12px 16px;
    font-size: 12px; color: var(--primary);
    display: flex; align-items: flex-start; gap: 8px;
  }

  /* Action bar */
  .ob-actions {
    display: flex; align-items: center; justify-content: space-between;
    padding-top: 24px;
    border-top: 1px solid rgba(var(--border-rgb),.5);
    margin-top: 8px; gap: 12px;
  }
  .ob-actions-right { display: flex; align-items: center; gap: 10px; }

  .ob-btn-back {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 18px; border-radius: 9px;
    font-size: 13px; font-weight: 600; color: var(--text-muted);
    border: 1px solid rgba(var(--border-rgb),.9);
    text-decoration: none; transition: all .15s;
    background: transparent;
  }
  .ob-btn-back:hover { color: var(--text); border-color: rgba(var(--primary-rgb),.3); }

  .ob-btn-skip {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 18px; border-radius: 9px;
    font-size: 13px; font-weight: 600; color: var(--text-muted);
    border: 1px solid rgba(var(--border-rgb),.9);
    background: transparent; cursor: pointer; transition: all .15s;
  }
  .ob-btn-skip:hover { color: var(--text); }

  .ob-btn-primary {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 22px; border-radius: 9px;
    font-size: 13px; font-weight: 700; color: #fff;
    background: var(--primary); border: none; cursor: pointer;
    box-shadow: 0 4px 20px rgba(var(--primary-rgb),.3);
    transition: opacity .15s, transform .1s;
  }
  .ob-btn-primary:hover { opacity: .9; transform: translateY(-1px); }

  .ob-btn-accent {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 11px 22px; border-radius: 9px;
    font-size: 13px; font-weight: 800; color: var(--dark);
    background: var(--accent); border: none; cursor: pointer;
    box-shadow: 0 4px 20px rgba(var(--accent-rgb),.25);
    transition: opacity .15s, transform .1s;
  }
  .ob-btn-accent:hover { opacity: .9; transform: translateY(-1px); }

  .ob-btn-secondary {
    display: inline-flex; align-items: center; gap: 8px;
    padding: 10px 18px; border-radius: 9px;
    font-size: 13px; font-weight: 600; color: var(--text);
    background: rgba(var(--primary-rgb),.12);
    border: 1px solid rgba(var(--primary-rgb),.3);
    cursor: pointer; transition: all .15s;
  }
  .ob-btn-secondary:hover { background: rgba(var(--primary-rgb),.2); }

  @media (max-width: 768px) {
    .ob-left { display: none; }
    .ob-right-inner { padding: 32px 20px 48px; }
    .field-row { grid-template-columns: 1fr; }
    .choice-grid { grid-template-columns: 1fr; }
    .mode-grid { grid-template-columns: 1fr; }
  }

/*  */
/* ── Shared layout (mirrors dashboard) ── */
  .dash-shell { display: flex; height: 100vh; overflow: hidden; }

  .sidebar {
    width: 260px; flex-shrink: 0; display: flex; flex-direction: column;
    background: var(--surface); border-right: 1px solid rgba(var(--border-rgb),.8);
    overflow-y: auto; overflow-x: hidden;
  }
  .sidebar-logo { display: flex; align-items: center; gap: 10px; padding: 20px 18px 18px; border-bottom: 1px solid rgba(var(--border-rgb),.6); }
.sidebar-nav { padding: 12px 10px; flex: 1; }
  .nav-section-label { font-size: 10px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); padding: 10px 10px 4px; }
  .nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 8px; font-size: 13.5px; font-weight: 500; color: var(--text-muted); text-decoration: none; transition: background .15s, color .15s; margin-bottom: 1px; cursor: pointer; }
  .nav-item:hover { background: rgba(var(--surface-2-rgb),.9); color: var(--text); }
  .nav-item.active { background: rgba(var(--primary-rgb),.14); color: var(--primary); font-weight: 600; }
  .nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }
  .nav-divider { border: none; border-top: 1px solid rgba(var(--border-rgb),.6); margin: 10px; }
  .nav-badge { margin-left: auto; font-size: 10px; font-weight: 700; background: rgba(var(--primary-rgb),.2); color: var(--primary); padding: 2px 6px; border-radius: 99px; }
  .nav-badge.warn { background: rgba(var(--primary-rgb),.15); color: var(--primary); }
  .sidebar-account { padding: 12px 10px; border-top: 1px solid rgba(var(--border-rgb),.6); position: relative; }
  .account-trigger { display: flex; align-items: center; gap: 10px; padding: 9px 10px; border-radius: 8px; cursor: pointer; transition: background .15s; width: 100%; }
  .account-trigger:hover { background: rgba(var(--surface-2-rgb),.9); }
  .avatar { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--accent)); display: grid; place-items: center; font-size: 12px; font-weight: 700; color: #fff; flex-shrink: 0; }
  .account-info { flex: 1; min-width: 0; }
  .account-email { font-size: 12px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .account-plan { display: inline-flex; align-items: center; gap: 4px; font-size: 10px; font-weight: 700; margin-top: 2px; padding: 1px 6px; border-radius: 99px; }
  .plan-starter { background: rgba(var(--primary-rgb),.18); color: var(--primary); }
  .plan-growth  { background: rgba(var(--accent-rgb),.15);  color: var(--accent); }
  .plan-agency  { background: rgba(var(--primary-rgb),.15);  color: var(--primary); }
  .account-dropdown { position: absolute; bottom: calc(100% + 4px); left: 10px; right: 10px; background: var(--surface-2); border: 1px solid rgba(var(--border-rgb),.95); border-radius: 10px; box-shadow: 0 -8px 32px rgba(0,0,0,.4); overflow: hidden; display: none; z-index: 100; }
  .account-dropdown.open { display: block; }
  .dropdown-header { padding: 14px 14px 10px; border-bottom: 1px solid rgba(var(--border-rgb),.6); }
  .dropdown-item { display: flex; align-items: center; gap: 10px; padding: 10px 14px; font-size: 13px; font-weight: 500; color: var(--text-muted); text-decoration: none; transition: background .12s, color .12s; cursor: pointer; }
  .dropdown-item:hover { background: rgba(var(--primary-rgb),.08); color: var(--text); }
  .dropdown-item.danger:hover { background: rgba(var(--danger-rgb),.08); color: var(--danger); }
  .dropdown-item svg { width: 15px; height: 15px; flex-shrink: 0; }

  /* ── Main ── */
  .main-content { flex: 1; overflow-y: auto; background: var(--dark); display: flex; flex-direction: column; }
  .main-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 28px 18px; border-bottom: 1px solid rgba(var(--border-rgb),.5); background: rgba(var(--dark-rgb),.9); position: sticky; top: 0; z-index: 20; backdrop-filter: blur(12px); }
  .main-body { padding: 32px clamp(24px, 3vw, 56px); flex: 1; width: 100%; max-width: 1280px; box-sizing: border-box; }

  /* ── Settings panel ── */
  .settings-panel { width: 100%; min-width: 0; }
  .panel-header { margin-bottom: 24px; }
  .panel-title { font-family: "Plus Jakarta Sans", sans-serif; font-size: 20px; font-weight: 800; color: var(--text); }
  .panel-desc { font-size: 13px; color: var(--text-muted); margin-top: 4px; line-height: 1.5; }

  /* ── Form card ── */
  .settings-card { width: 100%; box-sizing: border-box; background: var(--surface); border: 1px solid rgba(var(--border-rgb),.8); border-radius: 14px; padding: 24px; margin-bottom: 16px; }
  .card-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
  .card-desc { font-size: 12px; color: var(--text-muted); margin-bottom: 18px; }
  .card-divider { border: none; border-top: 1px solid rgba(var(--border-rgb),.5); margin: 18px 0; }

  /* ── Fields ── */
  .field-group { margin-bottom: 16px; }
  .field-label { display: block; font-size: 12px; font-weight: 600; color: var(--text-soft); margin-bottom: 6px; }
  .field-label .opt { font-weight: 400; color: var(--text-muted); margin-left: 4px; }
  .field-input {
    width: 100%; background: rgba(var(--surface-2-rgb),.9); border: 1px solid rgba(var(--border-rgb),.95);
    border-radius: 9px; color: var(--text); font-size: 13px; padding: 10px 12px;
    outline: none; transition: border-color .2s, box-shadow .2s; font-family: inherit;
    box-sizing: border-box;
  }
  .field-input:focus { border-color: rgba(var(--primary-rgb),.7); box-shadow: 0 0 0 3px rgba(var(--primary-rgb),.12); background: rgba(var(--surface-2-rgb),1); }
  .field-input::placeholder { color: rgba(var(--text-muted-rgb),.6); }
  select.field-input { cursor: pointer; }
  textarea.field-input { resize: vertical; min-height: 90px; }
  .field-hint { font-size: 11px; color: var(--text-muted); margin-top: 5px; }
  .field-grid-2 { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }

  /* ── Tone chips ── */
  .tone-grid { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 8px; }
  .tone-radio { position: absolute; opacity: 0; pointer-events: none; }
  .tone-chip {
    display: flex; align-items: center; gap: 6px;
    padding: 6px 12px; border-radius: 99px; font-size: 12px; font-weight: 600;
    border: 1.5px solid rgba(var(--border-rgb),.9); color: var(--text-muted); cursor: pointer;
    transition: all .15s; background: rgba(var(--surface-2-rgb),.6);
  }
  .tone-chip:hover { border-color: rgba(var(--primary-rgb),.4); color: var(--text); }
  .tone-radio:checked + .tone-chip { border-color: rgba(var(--primary-rgb),.8); background: rgba(var(--primary-rgb),.12); color: var(--primary); }

  /* ── Save bar ── */
  .save-bar { display: flex; align-items: center; justify-content: space-between; padding-top: 18px; border-top: 1px solid rgba(var(--border-rgb),.5); margin-top: 4px; }
  .btn-save { background: var(--primary); color: #fff; border: none; padding: 10px 20px; border-radius: 8px; font-size: 13px; font-weight: 700; cursor: pointer; transition: opacity .15s; box-shadow: 0 0 20px rgba(var(--primary-rgb),.28); }
  .btn-save:hover { opacity: .88; }
  .btn-secondary { background: transparent; color: var(--text-muted); border: 1px solid rgba(var(--border-rgb),.8); padding: 9px 16px; border-radius: 8px; font-size: 13px; font-weight: 600; cursor: pointer; text-decoration: none; display: inline-flex; align-items: center; gap: 6px; transition: color .15s, border-color .15s; }
  .btn-secondary:hover { color: var(--text); border-color: rgba(var(--primary-rgb),.3); }
  .btn-danger { background: rgba(var(--danger-rgb),.08); color: var(--danger); border: 1px solid rgba(var(--danger-rgb),.2); padding: 7px 14px; border-radius: 7px; font-size: 12px; font-weight: 600; cursor: pointer; transition: background .15s; }
  .btn-danger:hover { background: rgba(var(--danger-rgb),.16); }
  .saved-badge { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--accent); }

  /* ── Channel / Source rows ── */
  .resource-row { display: flex; align-items: center; gap: 12px; padding: 12px; background: rgba(var(--dark-rgb),.6); border: 1px solid rgba(var(--border-rgb),.6); border-radius: 10px; margin-bottom: 8px; }
  .resource-row:last-child { margin-bottom: 0; }
  .resource-icon { width: 34px; height: 34px; border-radius: 8px; display: grid; place-items: center; flex-shrink: 0; font-size: 13px; font-weight: 800; }
  .icon-linkedin  { background: rgba(10,139,224,.15); color: #0A8BE0; }
  .icon-instagram { background: rgba(225,48,108,.12); color: #E1306C; }
  .icon-facebook  { background: rgba(24,119,242,.12); color: #1877F2; }
  .icon-rss       { background: rgba(var(--primary-rgb),.12); color: var(--primary); }
  .icon-url       { background: rgba(var(--primary-rgb),.12); color: var(--primary); }
  .icon-keyword   { background: rgba(var(--accent-rgb),.1);   color: var(--accent); }
  .icon-manual    { background: rgba(var(--text-muted-rgb),.1); color: var(--text-muted); }
  .resource-info { flex: 1; min-width: 0; }
  .resource-name { font-size: 13px; font-weight: 600; color: var(--text); }
  .resource-meta { font-size: 11px; color: var(--text-muted); margin-top: 2px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .toggle-switch { position: relative; width: 34px; height: 20px; }
  .toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
  .toggle-track { position: absolute; inset: 0; border-radius: 99px; background: rgba(var(--border-rgb),.9); transition: background .2s; cursor: pointer; }
  .toggle-track::after { content: ''; position: absolute; left: 3px; top: 3px; width: 14px; height: 14px; border-radius: 50%; background: var(--text-muted); transition: transform .2s, background .2s; }
  .toggle-switch input:checked + .toggle-track { background: rgba(var(--accent-rgb),.25); }
  .toggle-switch input:checked + .toggle-track::after { transform: translateX(14px); background: var(--accent); }
  .resource-actions { display: flex; align-items: center; gap: 8px; }

  /* ── Success / error toast ── */
  .inline-toast { display: flex; align-items: center; gap: 8px; padding: 10px 14px; border-radius: 9px; font-size: 13px; font-weight: 500; margin-bottom: 16px; }
  .toast-success { background: rgba(var(--accent-rgb),.08); border: 1px solid rgba(var(--accent-rgb),.2); color: var(--accent); }
  .toast-error   { background: rgba(var(--danger-rgb),.08); border: 1px solid rgba(var(--danger-rgb),.2); color: var(--danger); }

  /* ── Add form ── */
  .add-form { background: rgba(var(--dark-rgb),.5); border: 1px dashed rgba(var(--primary-rgb),.25); border-radius: 10px; padding: 16px; margin-top: 12px; }
  .add-form-title { font-size: 12px; font-weight: 700; color: var(--primary); margin-bottom: 12px; text-transform: uppercase; letter-spacing: .04em; }

  /* ── Account info ── */
  .info-row { display: flex; align-items: center; justify-content: space-between; padding: 12px 0; border-bottom: 1px solid rgba(var(--border-rgb),.4); }
  .info-row:last-child { border-bottom: none; }
  .info-label { font-size: 12px; color: var(--text-muted); font-weight: 500; }
  .info-value { font-size: 13px; color: var(--text); font-weight: 600; }

  /* ── Danger zone ── */
  .danger-zone { border: 1px solid rgba(var(--danger-rgb),.2); border-radius: 14px; padding: 20px; background: rgba(var(--danger-rgb),.04); }
  .danger-title { font-size: 13px; font-weight: 700; color: var(--danger); margin-bottom: 4px; }
  .danger-desc { font-size: 12px; color: var(--text-muted); margin-bottom: 14px; line-height: 1.5; }

  @media (max-width: 900px) {
    .main-body { padding: 24px 18px; }
    .field-grid-2 { grid-template-columns: 1fr; }
  }

  /* Scrollbar */
  .main-content::-webkit-scrollbar { width: 4px; }
  .main-content::-webkit-scrollbar-track { background: transparent; }
  .main-content::-webkit-scrollbar-thumb { background: rgba(var(--border-rgb),.8); border-radius: 99px; }

/* templates/dashboard/index.html */
/* ── Layout ── */
  .dash-shell { display: flex; height: 100vh; overflow: hidden; }

  /* ── Sidebar ── */
  .sidebar {
    width: 260px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    background: var(--surface);
    border-right: 1px solid rgba(var(--border-rgb),.8);
    overflow-y: auto;
    overflow-x: hidden;
  }
  .sidebar-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 20px 18px 18px;
    border-bottom: 1px solid rgba(var(--border-rgb),.6);
  }
.sidebar-nav { padding: 12px 10px; flex: 1; }
  .nav-section-label {
    font-size: 10px; font-weight: 700; letter-spacing: .08em;
    text-transform: uppercase; color: var(--text-muted);
    padding: 10px 10px 4px;
  }
  .nav-item {
    display: flex; align-items: center; gap: 10px;
    padding: 9px 10px; border-radius: 8px;
    font-size: 13.5px; font-weight: 500; color: var(--text-muted);
    text-decoration: none; transition: background .15s, color .15s;
    margin-bottom: 1px;
    cursor: pointer;
  }
  .nav-item:hover { background: rgba(var(--surface-2-rgb),.9); color: var(--text); }
  .nav-item.active { background: rgba(var(--primary-rgb),.14); color: var(--primary); font-weight: 600; }
  .nav-item.active svg { color: var(--primary); }
  .nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }
  .nav-divider { border: none; border-top: 1px solid rgba(var(--border-rgb),.6); margin: 10px 10px; }
  .nav-badge {
    margin-left: auto; font-size: 10px; font-weight: 700;
    background: rgba(var(--primary-rgb),.2); color: var(--primary);
    padding: 2px 6px; border-radius: 99px;
  }
  .nav-badge.warn { background: rgba(var(--primary-rgb),.15); color: var(--primary); }

  /* ── Account block ── */
  .sidebar-account {
    padding: 12px 10px;
    border-top: 1px solid rgba(var(--border-rgb),.6);
    position: relative;
  }
  .account-trigger {
    display: flex; align-items: center; gap-10px; gap: 10px;
    padding: 9px 10px; border-radius: 8px; cursor: pointer;
    transition: background .15s;
    width: 100%;
  }
  .account-trigger:hover { background: rgba(var(--surface-2-rgb),.9); }
  .avatar {
    width: 32px; height: 32px; border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    display: grid; place-items: center;
    font-size: 12px; font-weight: 700; color: #fff;
    flex-shrink: 0;
  }
  .account-info { flex: 1; min-width: 0; }
  .account-email { font-size: 12px; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .account-plan {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 10px; font-weight: 700; margin-top: 2px;
    padding: 1px 6px; border-radius: 99px;
  }
  .plan-starter { background: rgba(var(--primary-rgb),.18); color: var(--primary); }
  .plan-growth  { background: rgba(var(--accent-rgb),.15);  color: var(--accent); }
  .plan-agency  { background: rgba(var(--primary-rgb),.15);  color: var(--primary); }
  .plan-trialing { background: rgba(var(--primary-rgb),.15); color: var(--primary); }

  /* ── Account dropdown ── */
  .account-dropdown {
    position: absolute; bottom: calc(100% + 4px); left: 10px; right: 10px;
    background: var(--surface-2); border: 1px solid rgba(var(--border-rgb),.95);
    border-radius: 10px; box-shadow: 0 -8px 32px rgba(0,0,0,.4);
    overflow: hidden; display: none; z-index: 100;
  }
  .account-dropdown.open { display: block; }
  .dropdown-header { padding: 14px 14px 10px; border-bottom: 1px solid rgba(var(--border-rgb),.6); }
  .dropdown-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; font-size: 13px; font-weight: 500; color: var(--text-muted);
    text-decoration: none; transition: background .12s, color .12s;
    cursor: pointer;
  }
  .dropdown-item:hover { background: rgba(var(--primary-rgb),.08); color: var(--text); }
  .dropdown-item.danger:hover { background: rgba(var(--danger-rgb),.08); color: var(--danger); }
  .dropdown-item svg { width: 15px; height: 15px; flex-shrink: 0; }

  /* ── Main content ── */
  .main-content { flex: 1; overflow-y: auto; background: var(--dark); display: flex; flex-direction: column; }
  .main-header {
    display: flex; align-items: center; justify-content: space-between;
    padding: 20px 28px 18px;
    border-bottom: 1px solid rgba(var(--border-rgb),.5);
    background: rgba(var(--dark-rgb),.9);
    position: sticky; top: 0; z-index: 20;
    backdrop-filter: blur(12px);
  }
  .main-body { padding: 24px 28px; flex: 1; }

  /* ── Trial banner ── */
  .trial-banner {
    background: linear-gradient(90deg, rgba(var(--primary-rgb),.1), rgba(var(--primary-rgb),.05));
    border: 1px solid rgba(var(--primary-rgb),.25);
    border-radius: 10px; padding: 10px 16px;
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 22px;
  }

  /* ── KPI Cards ── */
  .kpi-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin-bottom: 22px; }
  @media (max-width: 1280px) { .kpi-grid { grid-template-columns: repeat(3, 1fr); } }
  .kpi-card {
    background: var(--surface); border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 14px; padding: 18px 18px 16px; position: relative; overflow: hidden;
    transition: border-color .2s;
  }
  .kpi-card:hover { border-color: rgba(var(--primary-rgb),.3); }
  .kpi-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
    background: var(--kpi-accent, var(--primary)); opacity: .6;
  }
  .kpi-icon {
    width: 34px; height: 34px; border-radius: 8px;
    background: var(--kpi-bg, rgba(var(--primary-rgb),.12));
    display: grid; place-items: center;
    color: var(--kpi-accent, var(--primary)); margin-bottom: 12px;
  }
  .kpi-icon svg { width: 16px; height: 16px; }
  .kpi-value { font-family: "Plus Jakarta Sans", sans-serif; font-size: 28px; font-weight: 800; color: var(--text); line-height: 1; }
  .kpi-label { font-size: 12px; color: var(--text-muted); margin-top: 5px; font-weight: 500; }
  .kpi-trend { font-size: 11px; margin-top: 8px; display: flex; align-items: center; gap: 4px; }
  .kpi-sparkline { position: absolute; bottom: 0; right: 0; opacity: .35; }

  /* ── Charts row ── */
  .charts-row { display: grid; grid-template-columns: 1fr 320px; gap: 14px; margin-bottom: 22px; }
  @media (max-width: 1100px) { .charts-row { grid-template-columns: 1fr; } }
  .chart-card {
    background: var(--surface); border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 14px; padding: 20px 20px 16px;
  }
  .chart-title { font-size: 14px; font-weight: 700; color: var(--text); margin-bottom: 4px; }
  .chart-subtitle { font-size: 12px; color: var(--text-muted); margin-bottom: 18px; }
  .chart-legend { display: flex; gap: 16px; margin-top: 14px; }
  .legend-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-muted); }
  .legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

  /* ── Content row ── */
  .content-row { display: grid; grid-template-columns: 1fr 320px; gap: 14px; }
  @media (max-width: 1100px) { .content-row { grid-template-columns: 1fr; } }
  .panel {
    background: var(--surface); border: 1px solid rgba(var(--border-rgb),.8);
    border-radius: 14px; padding: 20px;
  }
  .panel-title { font-size: 15px; font-weight: 700; color: var(--text); margin-bottom: 16px; display: flex; align-items: center; justify-content: space-between; }

  /* ── Approval items ── */
  .approval-item {
    background: var(--dark); border: 1px solid rgba(var(--border-rgb),.7);
    border-radius: 10px; padding: 14px;
    margin-bottom: 10px; transition: border-color .15s;
  }
  .approval-item:hover { border-color: rgba(var(--primary-rgb),.3); }
  .approval-item:last-child { margin-bottom: 0; }
  .item-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 8px; }
  .platform-badge {
    font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 99px;
    text-transform: uppercase;
  }
  .badge-linkedin  { background: rgba(0,119,181,.2); color: #0A8BE0; }
  .badge-instagram { background: rgba(225,48,108,.15); color: #E1306C; }
  .badge-facebook  { background: rgba(24,119,242,.15); color: #1877F2; }
  .badge-unknown   { background: rgba(var(--text-muted-rgb),.15); color: var(--text-muted); }
  .status-badge {
    font-size: 10px; font-weight: 600; padding: 2px 7px; border-radius: 99px;
  }
  .s-pending  { background: rgba(var(--primary-rgb),.15); color: var(--primary); }
  .s-draft    { background: rgba(var(--primary-rgb),.15);  color: var(--primary); }
  .s-approved { background: rgba(var(--accent-rgb),.12);   color: var(--accent); }
  .s-rejected { background: rgba(var(--danger-rgb),.12);  color: var(--danger); }
  .s-failed   { background: rgba(var(--danger-rgb),.12);  color: var(--danger); }
  .item-content { font-size: 13px; color: var(--text-soft); line-height: 1.5; margin-bottom: 12px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
  .item-actions { display: flex; gap: 8px; flex-wrap: wrap; }
  .btn-approve { background: rgba(var(--accent-rgb),.12); color: var(--accent); border: 1px solid rgba(var(--accent-rgb),.25); padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: background .15s; }
  .btn-approve:hover { background: rgba(var(--accent-rgb),.22); }
  .btn-reject  { background: rgba(var(--danger-rgb),.08); color: var(--danger); border: 1px solid rgba(var(--danger-rgb),.2); padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: background .15s; }
  .btn-reject:hover  { background: rgba(var(--danger-rgb),.16); }
  .btn-edit    { background: rgba(var(--border-rgb),.5); color: var(--text-muted); border: 1px solid rgba(var(--border-rgb),.9); padding: 5px 12px; border-radius: 6px; font-size: 12px; font-weight: 600; cursor: pointer; transition: background .15s; }
  .btn-edit:hover    { background: rgba(var(--border-rgb),.9); color: var(--text); }

  /* ── Calendar ── */
  .cal-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
  .cal-month { font-size: 13px; font-weight: 700; color: var(--text); }
  .cal-nav { width: 26px; height: 26px; border-radius: 6px; border: 1px solid rgba(var(--border-rgb),.8); background: transparent; color: var(--text-muted); cursor: pointer; display: grid; place-items: center; transition: color .15s, background .15s; }
  .cal-nav:hover { background: rgba(var(--border-rgb),.8); color: var(--text); }
  .cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 3px; text-align: center; }
  .cal-day-label { font-size: 10px; font-weight: 600; color: var(--text-muted); padding: 4px 0; text-transform: uppercase; }
  .cal-day {
    aspect-ratio: 1; border-radius: 6px; display: grid; place-items: center;
    font-size: 12px; color: var(--text-muted); position: relative; cursor: default;
    transition: background .15s;
  }
  .cal-day.today { background: rgba(var(--primary-rgb),.2); color: var(--primary); font-weight: 700; }
  .cal-day.has-post::after {
    content: ''; position: absolute; bottom: 2px; left: 50%; transform: translateX(-50%);
    width: 4px; height: 4px; border-radius: 50%; background: var(--accent);
  }
  .cal-day.other-month { opacity: .3; }
  .cal-day:not(.other-month):hover { background: rgba(var(--border-rgb),.6); color: var(--text); }

  /* ── Channel status bar ── */
  .channel-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; border-bottom: 1px solid rgba(var(--border-rgb),.4); }
  .channel-row:last-child { border-bottom: none; }
  .channel-name { font-size: 13px; font-weight: 600; color: var(--text); }
  .channel-sub  { font-size: 11px; color: var(--text-muted); margin-top: 1px; }
  .status-dot   { width: 7px; height: 7px; border-radius: 50%; display: inline-block; margin-right: 5px; }
  .dot-green   { background: var(--accent); box-shadow: 0 0 6px rgba(var(--accent-rgb),.5); }
  .dot-orange  { background: var(--primary); box-shadow: 0 0 6px rgba(var(--primary-rgb),.5); }
  .dot-red     { background: var(--danger); }
  .dot-grey    { background: var(--text-muted); }

  /* ── Scrollbar ── */
  .main-content::-webkit-scrollbar { width: 4px; }
  .main-content::-webkit-scrollbar-track { background: transparent; }
  .main-content::-webkit-scrollbar-thumb { background: rgba(var(--border-rgb),.8); border-radius: 99px; }

  /* ── Mobile sidebar ── */
  @media (max-width: 768px) {
    .sidebar { position: fixed; left: -260px; top: 0; height: 100%; z-index: 50; transition: left .25s; }
    .sidebar.open { left: 0; }
    .main-content { margin-left: 0 !important; }
    .kpi-grid { grid-template-columns: repeat(2, 1fr); }
    .charts-row, .content-row { grid-template-columns: 1fr; }
    .mobile-menu-btn { display: flex !important; }
  }
  .mobile-menu-btn { display: none; }

/* Inline styles moved from templates */
.u-style-001 { display:flex;align-items:center;gap:12px; }
.u-style-002 { background:transparent;border:1px solid rgba(var(--border-rgb),.8);border-radius:7px;padding:6px;color:var(--text-muted);cursor:pointer; }
.u-style-003 { width:18px;height:18px; }
.u-style-004 { font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);font-family:'JetBrains Mono',monospace; }
.u-style-005 { font-family:'Plus Jakarta Sans',sans-serif;font-size:20px;font-weight:800;color:var(--text);line-height:1.2; }
.u-style-006 { display:flex;align-items:center;gap:10px; }
.u-style-007 { display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(var(--accent-rgb),.08);border:1px solid rgba(var(--accent-rgb),.2);border-radius:8px;font-size:12px;font-weight:600;color:var(--accent); }
.u-style-008 { display:flex;align-items:center;gap-6px;gap:6px;background:var(--primary);color:#fff;padding:8px 14px;border-radius:8px;font-size:13px;font-weight:700;text-decoration:none;box-shadow:0 0 20px rgba(var(--primary-rgb),.3);transition:opacity .15s; }
.u-style-009 { width:14px;height:14px; }
.u-style-010 { width:16px;height:16px;color:var(--primary);flex-shrink:0; }
.u-style-011 { font-size:13px;color:var(--primary);font-weight:600; }
.u-style-012 { font-size:12px;font-weight:700;color:var(--primary);border:1px solid rgba(var(--primary-rgb),.35);padding:4px 10px;border-radius:6px;text-decoration:none;transition:background .15s; }
.u-style-013 { --kpi-accent:var(--primary);--kpi-bg:rgba(var(--primary-rgb),.12); }
.u-style-014 { color:var(--primary); }
.u-style-015 { width:12px;height:12px; }
.u-style-016 { --kpi-accent:var(--accent);--kpi-bg:rgba(var(--accent-rgb),.1); }
.u-style-017 { color:var(--accent); }
.u-style-018 { --kpi-accent:var(--primary);--kpi-bg:rgba(var(--primary-rgb),.08); }
.u-style-019 { color:var(--text-muted); }
.u-style-020 { --kpi-accent:var(--primary);--kpi-bg:rgba(var(--primary-rgb),.1); }
.u-style-021 { display:flex;align-items:center;gap:8px; }
.u-style-022 { background:var(--primary);flex-shrink:0; }
.u-style-023 { --kpi-accent:var(--danger);--kpi-bg:rgba(var(--danger-rgb),.1); }
.u-style-024 { position:relative;height:180px; }
.u-style-025 { background:var(--primary); }
.u-style-026 { background:var(--accent); }
.u-style-027 { position:relative;height:160px;display:flex;align-items:center;justify-content:center; }
.u-style-028 { flex-direction:column;gap:8px;margin-top:16px; }
.u-style-029 { justify-content:space-between; }
.u-style-030 { display:flex;align-items:center;gap:6px; }
.u-style-031 { background:#0A8BE0; }
.u-style-032 { font-weight:700;color:var(--text); }
.u-style-033 { background:#E1306C; }
.u-style-034 { background:#1877F2; }
.u-style-035 { background:rgba(var(--primary-rgb),.15);color:var(--primary);font-size:11px;font-weight:700;padding:2px 8px;border-radius:99px; }
.u-style-036 { font-size:11px;color:var(--text-muted);margin-left:auto; }
.u-style-037 { font-size:12px;color:var(--danger);margin-bottom:10px; }
.u-style-038 { display:inline; }
.u-style-039 { display:none;margin-top:12px; }
.u-style-040 { width:100%;background:rgba(var(--surface-2-rgb),.9);border:1px solid rgba(var(--primary-rgb),.4);border-radius:8px;color:var(--text);font-size:13px;padding:10px;resize:vertical;min-height:100px;outline:none;font-family:inherit; }
.u-style-041 { display:flex;gap:8px;margin-top:8px; }
.u-style-042 { border:1px dashed rgba(var(--border-rgb),.7);border-radius:10px;padding:40px;text-align:center; }
.u-style-043 { width:36px;height:36px;color:var(--border);margin:0 auto 12px; }
.u-style-044 { color:var(--text-muted);font-size:14px;font-weight:500; }
.u-style-045 { color:var(--text-muted);font-size:12px;margin-top:4px; }
.u-style-046 { display:flex;flex-direction:column;gap:14px; }
.u-style-047 { margin-bottom:12px; }
.u-style-048 { margin-bottom:8px; }
.u-style-049 { font-size:12px;font-weight:600;color:var(--text-muted);display:flex;align-items:center; }
.u-style-050 { display:block;text-align:center;margin-top:12px;padding:8px;border:1px solid rgba(var(--primary-rgb),.3);border-radius:8px;font-size:12px;font-weight:700;color:var(--primary);text-decoration:none;transition:background .15s; }
.u-style-051 { font-family:'Plus Jakarta Sans',sans-serif;font-size:16px;font-weight:800;color:var(--text); }
.u-style-052 { opacity:.45;pointer-events:none; }
.u-style-053 { background:rgba(var(--text-muted-rgb),.12);color:var(--text-muted); }
.u-style-054 { font-size:12px;font-weight:700;color:var(--text); }
.u-style-055 { display:flex;align-items:center;gap:6px;margin-top:5px; }
.u-style-056 { font-size:10px;color:var(--text-muted); }
.u-style-057 { width:100%;text-align:left;border:none;background:none; }
.u-style-058 { width:14px;height:14px;color:var(--text-muted);flex-shrink:0;transition:transform .2s; }
.u-style-059 { width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0; }
.u-style-060 { margin-bottom:20px; }
.u-style-061 { position:relative; }
.u-style-062 { background:rgba(var(--primary-rgb),.1); }
.u-style-063 { font-size:11px;color:var(--accent);font-weight:700; }
.u-style-064 { display:flex;flex-wrap:wrap;gap:8px;margin-top:4px; }
.u-style-065 { display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:rgba(var(--primary-rgb),.1);border:1px solid rgba(var(--primary-rgb),.25);border-radius:99px;font-size:12px;font-weight:600;color:var(--accent); }
.u-style-066 { font-size:13px;color:var(--text-muted);margin-top:4px; }
.u-style-067 { display:flex;flex-direction:column;gap:8px;margin-top:4px; }
.u-style-068 { display:flex;align-items:center;gap:10px;font-size:13px; }
.u-style-069 { color:var(--text);font-weight:500; }
.u-style-070 { color:var(--text-muted);font-size:11px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px; }
.u-style-071 { display:grid;grid-template-columns:130px 1fr;gap:8px;font-size:13px; }
.u-style-072 { color:var(--text);font-weight:500;font-family:'JetBrains Mono',monospace;font-size:12px; }
.u-style-073 { font-weight:400;color:var(--text-muted);font-size:12px;margin-left:6px; }
.u-style-074 { width:15px;height:15px;flex-shrink:0; }
.u-style-075 { font-size:12px;color:var(--text-muted); }
.u-style-076 { padding:5px 10px;font-size:11px; }
.u-style-077 { text-align:center;padding:28px;border:1px dashed rgba(var(--border-rgb),.6);border-radius:10px;color:var(--text-muted);font-size:13px; }
.u-style-078 { display:flex;justify-content:flex-end;margin-top:4px; }
.u-style-079 { font-family:'JetBrains Mono',monospace;font-size:13px; }
.u-style-080 { display:flex;flex-direction:column;gap:10px; }
.u-style-081 { display:flex;align-items:flex-start;gap:12px;padding:14px;border-radius:10px;border:1.5px solid rgba(var(--border-rgb),.8);cursor:pointer;background:rgba(var(--surface-2-rgb),.4);transition:border-color .15s; }
.u-style-082 { margin-top:2px;accent-color:var(--primary); }
.u-style-083 { font-size:13px;font-weight:600;color:var(--text); }
.u-style-084 { font-size:12px;color:var(--text-muted);margin-top:2px; }
.u-style-085 { margin-top:14px; }
.u-style-086 { text-decoration:none;display:inline-block; }
.u-style-087 { text-decoration:none; }
