/* ════════════════════════════════════════════════════
   The Sunshine Network – Creator Membership v3.0
   All colours driven by CSS custom properties set
   dynamically from the admin Design panel.
════════════════════════════════════════════════════ */
:root {
    --tsn-primary:           #f59e0b;
    --tsn-secondary:         #1f2937;
    --tsn-accent:            #000000;
    --tsn-page-bg:           #0f172a;
    --tsn-card-bg:           #1e293b;
    --tsn-card-header-bg:    #0f172a;
    --tsn-card-header-text:  #ffffff;
    --tsn-card-text:         #f1f5f9;
    --tsn-label-color:       #94a3b8;
    --tsn-heading-color:     #f1f5f9;
    --tsn-subheading-color:  #94a3b8;
    --tsn-muted:             #64748b;
    --tsn-link-color:        #f59e0b;
    --tsn-input-bg:          #0f172a;
    --tsn-input-border:      #334155;
    --tsn-input-text:        #f1f5f9;
    --tsn-placeholder:       #475569;
    --tsn-input-focus:       #f59e0b;
    --tsn-btn-bg:            #f59e0b;
    --tsn-btn-text:          #000000;
    --tsn-btn-hover-bg:      #d97706;
    --tsn-btn-outline:       #f59e0b;
    --tsn-step-active-bg:    #f59e0b;
    --tsn-step-active-text:  #000000;
    --tsn-section-title:     #f59e0b;
    --tsn-divider:           rgba(255,255,255,.06);
    --tsn-plan-card-bg:      #1e293b;
    --tsn-plan-price:        #f59e0b;
    --tsn-plan-feature:      #f1f5f9;
    --tsn-plan-check:        #f59e0b;
    --tsn-plan-badge-bg:     #f59e0b;
    --tsn-plan-badge-text:   #000000;
    --tsn-radius:            12px;
    --tsn-btn-radius:        8px;
    --tsn-input-radius:      8px;
    --tsn-font:              'Vazirmatn', sans-serif;
    --tsn-font-size:         15px;
    --tsn-heading-weight:    800;
    --tsn-sidebar-bg:        #1e293b;
    --tsn-sidebar-nav-hover: rgba(245,158,11,.12);
    --tsn-sidebar-nav-text:  #94a3b8;
    --tsn-success:           #10b981;
    --tsn-error:             #f87171;
    --tsn-warning:           #fbbf24;
    --tsn-info:              #60a5fa;
    --tsn-shadow:            0 8px 40px rgba(0,0,0,.5);
}

/* ── Global reset for plugin scope ─────────────── */
.tsn-wrapper *,
.tsn-account-wrap *,
.tsn-plans-wrap *,
.tsn-checkout-wrap * {
    box-sizing: border-box;
}

/* ── Page wrappers ──────────────────────────────── */
.tsn-wrapper {
    max-width: 580px;
    margin: 48px auto;
    padding: 0 16px;
    font-family: var(--tsn-font);
    font-size: var(--tsn-font-size);
    color: var(--tsn-card-text);
    background: var(--tsn-page-bg);
}
.tsn-plans-wrap    { max-width: 1120px; }
.tsn-checkout-wrap { max-width: 860px; }
.tsn-account-wrap  { max-width: 1000px; display: grid; grid-template-columns: 260px 1fr; gap: 20px; margin: 40px auto; padding: 0 16px; align-items: start; }

/* ── Card ───────────────────────────────────────── */
.tsn-card {
    background: var(--tsn-card-bg);
    border-radius: var(--tsn-radius);
    box-shadow: var(--tsn-shadow);
    overflow: hidden;
    border: 1px solid rgba(255,255,255,.06);
}
.tsn-card-header {
    background: linear-gradient(135deg, var(--tsn-card-header-bg), var(--tsn-secondary));
    padding: 30px 36px 22px;
    text-align: center;
    border-bottom: 2px solid var(--tsn-primary);
}
.tsn-header-icon { font-size: 2rem; margin-bottom: 8px; line-height: 1; }
.tsn-card-header h2 {
    color: var(--tsn-card-header-text);
    margin: 0 0 8px;
    font-size: 1.55rem;
    font-weight: var(--tsn-heading-weight);
    letter-spacing: -.2px;
}
.tsn-card-header p { color: var(--tsn-subheading-color); margin: 0; font-size: .92rem; }
.tsn-card-body { padding: 30px 36px; }

/* ── Multi-step progress ────────────────────────── */
.tsn-steps { display: flex; align-items: center; justify-content: center; gap: 8px; margin-top: 14px; flex-wrap: wrap; }
.tsn-step { font-size: .78rem; padding: 4px 12px; border-radius: 20px; background: rgba(255,255,255,.08); color: var(--tsn-muted); transition: all .25s; }
.tsn-step.active { background: var(--tsn-step-active-bg); color: var(--tsn-step-active-text); font-weight: 700; }
.tsn-step-sep { color: var(--tsn-muted); font-size: .75rem; }

/* ── Section titles inside forms ───────────────── */
.tsn-section-title {
    color: var(--tsn-section-title);
    font-size: .95rem;
    font-weight: 700;
    margin: 0 0 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--tsn-divider);
    font-family: var(--tsn-font);
}

/* ── Layout helpers ─────────────────────────────── */
.tsn-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 14px; }
.tsn-col { min-width: 0; }
.tsn-field { margin-bottom: 14px; }

/* ── Labels ─────────────────────────────────────── */
.tsn-card-body label,
.tsn-account-main label {
    display: block;
    font-size: .76rem;
    font-weight: 600;
    color: var(--tsn-label-color);
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: .5px;
    font-family: var(--tsn-font);
}
.tsn-req     { color: var(--tsn-error); margin-left: 2px; }
.tsn-optional{ color: var(--tsn-muted); font-weight: 400; text-transform: none; letter-spacing: 0; font-size: .72rem; }

/* ── Inputs, selects, textareas ─────────────────── */
.tsn-card-body input[type="text"],
.tsn-card-body input[type="email"],
.tsn-card-body input[type="password"],
.tsn-card-body input[type="tel"],
.tsn-card-body input[type="url"],
.tsn-card-body input[type="number"],
.tsn-card-body select,
.tsn-card-body textarea,
.tsn-account-main input[type="text"],
.tsn-account-main input[type="email"],
.tsn-account-main input[type="password"],
.tsn-account-main input[type="tel"],
.tsn-account-main input[type="url"],
.tsn-account-main select,
.tsn-account-main textarea {
    width: 100%;
    padding: 10px 14px;
    background: var(--tsn-input-bg);
    border: 1.5px solid var(--tsn-input-border);
    border-radius: var(--tsn-input-radius);
    color: var(--tsn-input-text);
    font-size: var(--tsn-font-size);
    font-family: var(--tsn-font);
    transition: border-color .2s, box-shadow .2s;
    outline: none;
    -webkit-appearance: none;
}
.tsn-card-body input::placeholder,
.tsn-account-main input::placeholder,
.tsn-card-body textarea::placeholder { color: var(--tsn-placeholder); }
.tsn-card-body input:focus,
.tsn-card-body select:focus,
.tsn-card-body textarea:focus,
.tsn-account-main input:focus,
.tsn-account-main select:focus,
.tsn-account-main textarea:focus {
    border-color: var(--tsn-input-focus);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--tsn-input-focus) 20%, transparent);
}
.tsn-card-body select option,
.tsn-account-main select option { background: var(--tsn-card-bg); color: var(--tsn-card-text); }
.tsn-card-body textarea,
.tsn-account-main textarea { resize: vertical; min-height: 88px; }
.tsn-disabled { opacity: .45 !important; cursor: not-allowed !important; }
.tsn-hint { color: var(--tsn-muted); font-size: .75rem; margin-top: 4px; display: block; line-height: 1.4; }

/* Password toggle */
.tsn-pw-wrap { position: relative; }
.tsn-pw-wrap input { padding-right: 40px; }
.tsn-eye { position: absolute; right: 12px; top: 50%; transform: translateY(-50%); cursor: pointer; font-size: .88rem; color: var(--tsn-muted); user-select: none; line-height: 1; }
.tsn-eye:hover { color: var(--tsn-primary); }

/* Password strength */
.tsn-strength-bar { height: 3px; background: rgba(255,255,255,.08); border-radius: 2px; margin-top: 5px; overflow: hidden; }
#tsn-str-fill { height: 100%; width: 0; transition: width .3s, background .3s; border-radius: 2px; }

/* Icon-prefixed inputs */
.tsn-input-icon-wrap { position: relative; }
.tsn-input-icon { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); font-size: .82rem; color: var(--tsn-muted); pointer-events: none; }
.tsn-input-icon-wrap input { padding-left: 32px; }

/* Checkbox */
.tsn-checkbox-field { margin-bottom: 14px; }
.tsn-checkbox-label { display: flex; align-items: center; gap: 8px; font-weight: 500 !important; text-transform: none !important; letter-spacing: 0 !important; color: var(--tsn-card-text) !important; font-size: .88rem !important; cursor: pointer; }
.tsn-checkbox-label input[type="checkbox"] { width: auto !important; margin: 0 !important; flex-shrink: 0; }
.tsn-checkbox-label a { color: var(--tsn-link-color); }

/* File upload doc boxes */
.tsn-doc-box { background: rgba(255,255,255,.03); border: 1.5px dashed var(--tsn-input-border); border-radius: var(--tsn-radius); padding: 14px; display: flex; gap: 12px; align-items: flex-start; }
.tsn-doc-box label { text-transform: none !important; letter-spacing: 0 !important; font-size: .88rem !important; font-weight: 600 !important; color: var(--tsn-card-text) !important; margin-bottom: 4px; }
.tsn-doc-icon { font-size: 1.7rem; flex-shrink: 0; line-height: 1; }
.tsn-doc-box input[type="file"] { margin-top: 7px; color: var(--tsn-muted); font-size: .82rem; }
.tsn-agreement-box { background: rgba(245,158,11,.04); border-color: rgba(245,158,11,.25); border-style: solid; }
.tsn-agreement-list { list-style: none; padding: 0; margin: 7px 0 0; }
.tsn-agreement-list li { font-size: .83rem; color: var(--tsn-muted); padding: 2px 0; }

/* ── Buttons ─────────────────────────────────────── */
.tsn-btn {
    display: inline-block;
    padding: 10px 22px;
    border-radius: var(--tsn-btn-radius);
    border: none;
    cursor: pointer;
    font-size: .92rem;
    font-weight: 700;
    text-align: center;
    text-decoration: none !important;
    transition: background .2s, opacity .2s, transform .1s, box-shadow .2s;
    letter-spacing: .2px;
    font-family: var(--tsn-font);
    line-height: 1.4;
}
.tsn-btn:active { transform: scale(.98); }
.tsn-btn-primary { background: var(--tsn-btn-bg); color: var(--tsn-btn-text) !important; box-shadow: 0 4px 14px rgba(0,0,0,.25); }
.tsn-btn-primary:hover { background: var(--tsn-btn-hover-bg); box-shadow: 0 6px 18px rgba(0,0,0,.35); }
.tsn-btn-outline { background: transparent; border: 2px solid var(--tsn-btn-outline); color: var(--tsn-btn-outline) !important; }
.tsn-btn-outline:hover { background: var(--tsn-btn-bg); color: var(--tsn-btn-text) !important; border-color: var(--tsn-btn-bg); }
.tsn-btn-full { display: block; width: 100%; text-align: center; }
.tsn-btn:disabled { opacity: .45; cursor: not-allowed; }
.tsn-pay-btn { padding: 13px; font-size: 1.05rem; }

/* Step navigation */
.tsn-step-nav { display: flex; justify-content: space-between; align-items: center; margin-top: 18px; padding-top: 14px; border-top: 1px solid var(--tsn-divider); gap: 10px; }

/* ── Notices ─────────────────────────────────────── */
.tsn-notice { padding: 11px 14px; border-radius: 8px; font-size: .88rem; margin-bottom: 14px; line-height: 1.5; }
.tsn-success { background: rgba(16,185,129,.1);  color: #6ee7b7; border: 1px solid rgba(16,185,129,.3); }
.tsn-error   { background: rgba(248,113,113,.1); color: #fca5a5; border: 1px solid rgba(248,113,113,.3); }
.tsn-warning { background: rgba(251,191,36,.1);  color: #fde68a; border: 1px solid rgba(251,191,36,.3); }
.tsn-info    { background: rgba(96,165,250,.1);  color: #93c5fd; border: 1px solid rgba(96,165,250,.3); }
.tsn-notice a { color: var(--tsn-link-color); }

/* Misc text helpers */
.tsn-alt-link { text-align: center; margin-top: 18px; color: var(--tsn-muted); font-size: .88rem; }
.tsn-alt-link a, .tsn-link-muted { color: var(--tsn-link-color); text-decoration: none; font-weight: 600; }
.tsn-divider-el { text-align: center; position: relative; margin: 18px 0; color: var(--tsn-muted); font-size: .82rem; }
.tsn-divider-el::before { content:''; position:absolute; left:0; top:50%; height:1px; width:100%; background: var(--tsn-divider); z-index:0; }
.tsn-divider-el span { background: var(--tsn-card-bg); position:relative; z-index:1; padding: 0 12px; }
.tsn-login-row { display: flex; justify-content: space-between; align-items: center; }
.tsn-divider { text-align:center; position:relative; margin:18px 0; color:var(--tsn-muted); font-size:.82rem; }
.tsn-divider::before { content:''; position:absolute; left:0; top:50%; height:1px; width:100%; background:var(--tsn-divider); z-index:0; }
.tsn-divider span { background:var(--tsn-card-bg); position:relative; z-index:1; padding:0 12px; }

/* Headings inside card body */
.tsn-card-body h3,
.tsn-account-main h3 { color: var(--tsn-heading-color); font-weight: var(--tsn-heading-weight); font-family: var(--tsn-font); }

/* ════════════════════════════════════════════════════
   MEMBERSHIP PLANS PAGE
════════════════════════════════════════════════════ */
.tsn-plans-header { text-align: center; margin-bottom: 34px; }
.tsn-plans-header h2 { font-size: 2rem; margin: 0 0 10px; color: var(--tsn-heading-color); font-weight: var(--tsn-heading-weight); font-family: var(--tsn-font); }
.tsn-plans-header p  { color: var(--tsn-subheading-color); font-size: 1.05rem; margin: 0; }

.tsn-plans-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 22px; align-items: start; }

.tsn-plan-card {
    background: var(--tsn-plan-card-bg);
    border-radius: var(--tsn-radius);
    box-shadow: var(--tsn-shadow);
    border: 1.5px solid rgba(255,255,255,.06);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    transition: transform .2s, box-shadow .2s;
}
.tsn-plan-card:hover { transform: translateY(-4px); box-shadow: 0 18px 50px rgba(0,0,0,.55); }
.tsn-featured { border-color: var(--tsn-primary); box-shadow: 0 0 0 2px var(--tsn-primary), var(--tsn-shadow); transform: scale(1.03); }
.tsn-featured:hover { transform: scale(1.03) translateY(-4px); }

.tsn-plan-badge { position:absolute; top:-1px; right:18px; background:var(--tsn-plan-badge-bg); color:var(--tsn-plan-badge-text); font-size:.72rem; font-weight:800; padding:4px 13px; border-radius:0 0 8px 8px; letter-spacing:.3px; }
.tsn-plan-img-wrap { overflow:hidden; max-height:180px; }
.tsn-plan-img-wrap img { width:100%; object-fit:cover; display:block; }
.tsn-plan-body { padding:22px; flex:1; display:flex; flex-direction:column; }
.tsn-plan-body h3 { font-size:1.15rem; margin:0 0 5px; color:var(--tsn-heading-color); font-family:var(--tsn-font); font-weight:var(--tsn-heading-weight); }
.tsn-plan-desc { color:var(--tsn-muted); font-size:.83rem; margin:0 0 14px; }

.tsn-plan-price { display:flex; align-items:flex-start; margin-bottom:14px; gap:2px; }
.tsn-price-currency { font-size:1.1rem; font-weight:700; color:var(--tsn-plan-price); margin-top:6px; }
.tsn-price-amount   { font-size:2.7rem; font-weight:900; color:var(--tsn-plan-price); line-height:1; }
.tsn-price-period   { color:var(--tsn-muted); font-size:.88rem; align-self:flex-end; margin-bottom:4px; }

.tsn-plan-features { list-style:none; padding:0; margin:0 0 18px; flex:1; }
.tsn-plan-features li { display:flex; gap:8px; align-items:flex-start; padding:5px 0; font-size:.85rem; color:var(--tsn-plan-feature); border-bottom:1px solid var(--tsn-divider); }
.tsn-check { color:var(--tsn-plan-check); font-weight:700; flex-shrink:0; }

/* ════════════════════════════════════════════════════
   CHECKOUT PAGE
════════════════════════════════════════════════════ */
.tsn-checkout-grid { display:grid; grid-template-columns:1fr 1.2fr; gap:26px; }
.tsn-order-summary h3, .tsn-payment-wrap h3 { color:var(--tsn-heading-color); font-size:1.05rem; margin-bottom:12px; font-family:var(--tsn-font); }
.tsn-checkout-plan-img { width:100%; border-radius:var(--tsn-radius); margin-bottom:12px; }
.tsn-summary-card { background:var(--tsn-card-bg); border-radius:var(--tsn-radius); border:1.5px solid var(--tsn-primary); padding:18px; }
.tsn-summary-card h4 { margin:0 0 5px; color:var(--tsn-heading-color); font-family:var(--tsn-font); }
.tsn-summary-card p  { color:var(--tsn-muted); font-size:.83rem; margin:0 0 8px; }
.tsn-summary-price   { font-size:1.75rem; font-weight:800; color:var(--tsn-plan-price); margin:7px 0; }
.tsn-summary-price span { font-size:.88rem; font-weight:400; color:var(--tsn-muted); }
.tsn-summary-features { list-style:none; padding:0; margin:9px 0; }
.tsn-summary-features li { font-size:.83rem; color:var(--tsn-plan-feature); padding:2px 0; }
.tsn-summary-total { display:flex; justify-content:space-between; padding-top:9px; border-top:1px solid var(--tsn-divider); font-size:.92rem; color:var(--tsn-card-text); }
.tsn-summary-total strong { color:var(--tsn-plan-price); }
.tsn-secure-note { text-align:center; color:var(--tsn-muted); font-size:.76rem; margin-top:11px; }
.tsn-payment-wrap { background:var(--tsn-card-bg); border-radius:var(--tsn-radius); padding:22px; border:1px solid rgba(255,255,255,.06); }
.tsn-buyer-info { background:rgba(255,255,255,.04); border-radius:8px; padding:9px 13px; margin-bottom:16px; font-size:.88rem; display:flex; flex-direction:column; gap:2px; color:var(--tsn-card-text); }
.tsn-buyer-info span { color:var(--tsn-muted); font-size:.8rem; }
.tsn-stripe-el { background:var(--tsn-input-bg); border:1.5px solid var(--tsn-input-border); border-radius:var(--tsn-input-radius); padding:11px 13px; transition:border-color .2s; }
.tsn-stripe-el.StripeElement--focus { border-color:var(--tsn-input-focus); }
.tsn-card-err { color:var(--tsn-error); font-size:.83rem; margin-top:5px; }
.tsn-pay-note { text-align:center; color:var(--tsn-muted); font-size:.75rem; margin-top:9px; }

/* ════════════════════════════════════════════════════
   ACCOUNT DASHBOARD
════════════════════════════════════════════════════ */
.tsn-account-wrap > aside,
.tsn-account-wrap > main { background:var(--tsn-sidebar-bg); border-radius:var(--tsn-radius); box-shadow:var(--tsn-shadow); }
.tsn-account-wrap > main { background:var(--tsn-card-bg); }

.tsn-sidebar { padding:26px 18px; text-align:center; }
.tsn-avatar { margin:0 auto 11px; }
.tsn-avatar img { width:70px; height:70px; border-radius:50%; border:2px solid var(--tsn-primary); }
.tsn-avatar-initials { width:70px; height:70px; border-radius:50%; background:var(--tsn-primary); color:var(--tsn-btn-text); display:flex; align-items:center; justify-content:center; font-size:1.5rem; font-weight:800; margin:0 auto; font-family:var(--tsn-font); }
.tsn-sidebar-name  { font-size:.95rem; margin:0 0 3px; color:var(--tsn-heading-color); font-weight:700; font-family:var(--tsn-font); }
.tsn-sidebar-email { color:var(--tsn-muted); font-size:.76rem; word-break:break-all; margin:0 0 5px; }
.tsn-sidebar-type  { color:var(--tsn-primary); font-size:.76rem; margin:0 0 12px; }

/* Verification badge */
.tsn-ver-badge { display:inline-block; padding:5px 12px; border-radius:20px; font-size:.75rem; font-weight:700; margin-bottom:8px; }
.tsn-status-full    { background:rgba(16,185,129,.15); color:#6ee7b7; border:1px solid rgba(16,185,129,.3); }
.tsn-status-partial { background:rgba(251,191,36,.15);  color:#fde68a; border:1px solid rgba(251,191,36,.3); }
.tsn-status-none    { background:rgba(248,113,113,.12); color:#fca5a5; border:1px solid rgba(248,113,113,.3); }

.tsn-mem-badge    { background:var(--tsn-primary); color:var(--tsn-btn-text); border-radius:20px; padding:4px 11px; font-size:.74rem; font-weight:700; display:inline-block; margin-bottom:7px; }
.tsn-no-mem-badge { background:rgba(255,255,255,.06); color:var(--tsn-muted); border-radius:20px; padding:4px 11px; font-size:.74rem; display:inline-block; margin-bottom:7px; }

.tsn-sidenav { text-align:left; margin-top:18px; border-top:1px solid var(--tsn-divider); padding-top:12px; }
.tsn-nav { display:flex; align-items:center; gap:7px; padding:8px 11px; border-radius:8px; color:var(--tsn-sidebar-nav-text); text-decoration:none; font-size:.85rem; font-weight:500; transition:background .15s, color .15s; margin-bottom:2px; font-family:var(--tsn-font); }
.tsn-nav:hover, .tsn-nav.active { background:var(--tsn-sidebar-nav-hover); color:var(--tsn-primary); }
.tsn-logout-link:hover { background:rgba(248,113,113,.1); color:var(--tsn-error); }

.tsn-account-main { padding:26px; }
.tsn-account-main h3 { font-size:1.05rem; margin:0 0 18px; color:var(--tsn-heading-color); padding-bottom:10px; border-bottom:1px solid var(--tsn-divider); font-weight:var(--tsn-heading-weight); font-family:var(--tsn-font); }
.tsn-tab-panel { display:none; } .tsn-tab-panel.active { display:block; }

/* Membership card inside account */
.tsn-mem-card { background:rgba(255,255,255,.04); border-radius:var(--tsn-radius); overflow:hidden; border:1px solid rgba(255,255,255,.06); }
.tsn-mem-img  { width:100%; max-height:150px; object-fit:cover; display:block; }
.tsn-mem-info { padding:18px; }
.tsn-mem-info h4 { margin:0 0 11px; color:var(--tsn-primary); font-size:1.05rem; font-family:var(--tsn-font); }
.tsn-mem-rows { margin-bottom:11px; }
.tsn-mem-row  { display:flex; justify-content:space-between; padding:5px 0; font-size:.85rem; border-bottom:1px solid var(--tsn-divider); color:var(--tsn-muted); }
.tsn-mem-row strong { color:var(--tsn-card-text); }
.tsn-mem-features { border-top:1px solid var(--tsn-divider); padding-top:9px; }
.tsn-mem-feature  { font-size:.83rem; color:var(--tsn-muted); padding:2px 0; }
.tsn-status-active { color:var(--tsn-success) !important; }
.tsn-no-plan { text-align:center; padding:36px 16px; }
.tsn-no-plan h4 { margin:9px 0 7px; color:var(--tsn-heading-color); font-family:var(--tsn-font); }
.tsn-no-plan p  { color:var(--tsn-muted); margin-bottom:18px; font-size:.88rem; }
.tsn-no-plan .tsn-btn { display:inline-block; width:auto; }

/* ════════════════════════════════════════════════════
   VERIFICATION STATUS PAGE
════════════════════════════════════════════════════ */
.tsn-ver-timeline { display:flex; flex-direction:column; gap:0; margin:20px 0; }
.tsn-ver-step { display:flex; align-items:flex-start; gap:14px; padding:14px; background:rgba(255,255,255,.03); border-radius:10px; border:1px solid var(--tsn-divider); }
.tsn-ver-step.tsn-ver-done  { background:rgba(16,185,129,.06); border-color:rgba(16,185,129,.2); }
.tsn-ver-step.tsn-ver-pending{ background:rgba(255,255,255,.025); }
.tsn-ver-icon { font-size:1.4rem; flex-shrink:0; line-height:1; }
.tsn-ver-info strong { display:block; color:var(--tsn-heading-color); font-size:.9rem; font-family:var(--tsn-font); }
.tsn-ver-info span   { color:var(--tsn-muted); font-size:.8rem; }
.tsn-ver-connector   { width:2px; height:14px; background:var(--tsn-divider); margin-left:23px; }

.tsn-doc-status-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-top:12px; }
.tsn-doc-status-item { background:rgba(255,255,255,.03); border-radius:10px; padding:14px; text-align:center; border:1px solid var(--tsn-divider); }
.tsn-doc-status-item strong { display:block; color:var(--tsn-heading-color); font-size:.85rem; margin:7px 0 3px; font-family:var(--tsn-font); }
.tsn-doc-status-item span   { font-size:.78rem; color:var(--tsn-muted); }
.tsn-doc-status-icon { font-size:1.6rem; display:block; }
.tsn-doc-ok      { border-color:rgba(16,185,129,.25); background:rgba(16,185,129,.05); }
.tsn-doc-missing { border-color:rgba(248,113,113,.2); }

/* ════════════════════════════════════════════════════
   STATUS BADGES (global)
════════════════════════════════════════════════════ */
.tsn-badge-active, .tsn-badge-completed { color:var(--tsn-success); font-weight:600; }
.tsn-badge-pending  { color:var(--tsn-warning); font-weight:600; }
.tsn-badge-suspended, .tsn-badge-inactive { color:var(--tsn-error); font-weight:600; }
.tsn-badge-expired  { color:var(--tsn-muted); font-weight:600; }

/* ════════════════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    .tsn-wrapper { padding: 0 12px; margin: 28px auto; }
    .tsn-card-body   { padding: 20px 18px; }
    .tsn-card-header { padding: 22px 18px 16px; }
    .tsn-row { grid-template-columns: 1fr; }
    .tsn-checkout-grid { grid-template-columns: 1fr; }
    .tsn-account-wrap  { grid-template-columns: 1fr; }
    .tsn-plans-grid    { grid-template-columns: 1fr; }
    .tsn-featured      { transform: none; }
    .tsn-featured:hover{ transform: translateY(-4px); }
    .tsn-login-row     { flex-direction: column; align-items: flex-start; gap: 7px; }
    .tsn-step-nav      { flex-direction: column; }
    .tsn-step-nav > button { width: 100%; }
    .tsn-doc-status-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
    .tsn-account-wrap, .tsn-plans-wrap, .tsn-checkout-wrap { padding: 0 8px; }
    .tsn-steps { gap: 4px; }
}

/* ════════════════════════════════════════════════════
   VIEWER PAGES — fully brand-matched to creator forms
════════════════════════════════════════════════════ */

/* Panel hide/show — JS toggles .active */
.tsn-viewer-panel          { display: none; }
.tsn-viewer-panel.active   { display: block; }

/* ── Tab switcher in card header ─────────────────── */
.tsn-viewer-tabs {
    display: flex;
    gap: 8px;
    justify-content: center;
    margin-top: 16px;
    flex-wrap: wrap;
}
.tsn-viewer-tab-btn {
    padding: 7px 22px;
    border-radius: 20px;
    border: 1.5px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.07);
    color: var(--tsn-subheading-color);
    font-size: .82rem;
    font-weight: 600;
    cursor: pointer;
    transition: all .2s;
    font-family: var(--tsn-font);
}
.tsn-viewer-tab-btn:hover {
    background: rgba(255,255,255,.12);
    color: var(--tsn-card-header-text);
}
.tsn-viewer-tab-btn.active {
    background: var(--tsn-step-active-bg);
    color: var(--tsn-step-active-text);
    border-color: var(--tsn-step-active-bg);
    font-weight: 700;
}

/* ── What-you-get perks list ─────────────────────── */
.tsn-viewer-perks {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin: 20px 0 4px;
    padding: 14px 16px;
    background: rgba(255,255,255,.03);
    border: 1px solid var(--tsn-divider);
    border-radius: var(--tsn-radius);
}
.tsn-viewer-perk {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    font-size: .82rem;
    color: var(--tsn-muted);
    line-height: 1.4;
}
.tsn-viewer-perk span { color: var(--tsn-card-text); }

/* ── Guest divider ───────────────────────────────── */
.tsn-guest-divider {
    text-align: center;
    position: relative;
    margin: 18px 0;
    color: var(--tsn-muted);
    font-size: .82rem;
}
.tsn-guest-divider::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    height: 1px; width: 100%;
    background: var(--tsn-divider);
    z-index: 0;
}
.tsn-guest-divider span {
    background: var(--tsn-card-bg);
    position: relative;
    z-index: 1;
    padding: 0 12px;
}

/* ── Guest note ──────────────────────────────────── */
.tsn-guest-note {
    text-align: center;
    color: var(--tsn-muted);
    font-size: .75rem;
    margin: 7px 0 0;
    line-height: 1.5;
}
.tsn-guest-note a { color: var(--tsn-link-color); }

/* ── Footer creator links ────────────────────────── */
.tsn-viewer-footer-links {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 22px;
    padding-top: 16px;
    border-top: 1px solid var(--tsn-divider);
    font-size: .8rem;
    color: var(--tsn-muted);
}
.tsn-viewer-footer-links a {
    color: var(--tsn-link-color);
    text-decoration: none;
    font-weight: 600;
}
.tsn-viewer-footer-links a:hover { text-decoration: underline; }

/* ── Viewer Account Dashboard ────────────────────── */
.tsn-viewer-welcome-banner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: linear-gradient(135deg, rgba(var(--tsn-primary), .12), rgba(255,255,255,.03));
    background: linear-gradient(135deg, color-mix(in srgb, var(--tsn-primary) 12%, transparent), rgba(255,255,255,.02));
    border: 1px solid color-mix(in srgb, var(--tsn-primary) 25%, transparent);
    border-radius: var(--tsn-radius);
    padding: 18px 20px;
    margin-bottom: 22px;
    gap: 16px;
}
/* Fallback for browsers without color-mix */
@supports not (color: color-mix(in srgb, red 50%, blue)) {
    .tsn-viewer-welcome-banner {
        background: rgba(245,158,11,.08);
        border-color: rgba(245,158,11,.2);
    }
}
.tsn-viewer-welcome-text h3 {
    margin: 0 0 4px;
    color: var(--tsn-heading-color);
    font-family: var(--tsn-font);
    font-size: 1rem;
    font-weight: var(--tsn-heading-weight);
}
.tsn-viewer-welcome-text p  { margin: 0; color: var(--tsn-muted); font-size: .82rem; }
.tsn-viewer-welcome-action  { flex-shrink: 0; }

/* Viewer avatar uses primary colour */
.tsn-viewer-avatar { background: var(--tsn-primary) !important; color: var(--tsn-btn-text) !important; }

/* ── Viewer Gate overlay ─────────────────────────── */
.tsn-viewer-gate {
    border: 2px dashed color-mix(in srgb, var(--tsn-primary) 30%, transparent);
    border-radius: var(--tsn-radius);
    background: rgba(255,255,255,.02);
    padding: 48px 20px;
    text-align: center;
    margin: 20px 0;
}
@supports not (color: color-mix(in srgb, red 50%, blue)) {
    .tsn-viewer-gate { border-color: rgba(245,158,11,.3); }
}
.tsn-viewer-gate-inner .tsn-gate-icon { font-size: 2.5rem; margin-bottom: 12px; }
.tsn-viewer-gate-inner h3 {
    color: var(--tsn-heading-color);
    margin: 0 0 8px;
    font-family: var(--tsn-font);
    font-weight: var(--tsn-heading-weight);
}
.tsn-viewer-gate-inner p { color: var(--tsn-muted); margin: 0 0 22px; font-size: .9rem; }
.tsn-gate-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; }
.tsn-gate-btns .tsn-btn { padding: 10px 22px; }

/* ── Admin: toggle switch ────────────────────────── */
.tsn-toggle-label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
}
.tsn-toggle-switch {
    position: relative;
    flex-shrink: 0;
    width: 46px; height: 26px;
    background: #d1d5db;
    border-radius: 13px;
    transition: background .22s;
    margin-top: 1px;
}
.tsn-toggle-label input:checked ~ .tsn-toggle-switch { background: #059669; }
.tsn-toggle-switch::after {
    content: '';
    position: absolute;
    top: 3px; left: 3px;
    width: 20px; height: 20px;
    background: #fff;
    border-radius: 50%;
    transition: transform .22s;
    box-shadow: 0 1px 4px rgba(0,0,0,.25);
}
.tsn-toggle-label input:checked ~ .tsn-toggle-switch::after { transform: translateX(20px); }
.tsn-toggle-label input { display: none; }
.tsn-toggle-text          { font-size: .9rem; color: #374151; line-height: 1.5; }
.tsn-toggle-text small    { color: #6b7280; font-size: .8rem; display: block; margin-top: 2px; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 600px) {
    .tsn-viewer-perks           { grid-template-columns: 1fr; }
    .tsn-viewer-welcome-banner  { flex-direction: column; text-align: center; }
    .tsn-viewer-welcome-action  { width: 100%; }
    .tsn-viewer-welcome-action .tsn-btn { width: 100%; display: block; }
    .tsn-gate-btns              { flex-direction: column; }
    .tsn-gate-btns .tsn-btn     { width: 100%; }
    .tsn-viewer-tabs            { gap: 6px; }
    .tsn-viewer-tab-btn         { padding: 6px 16px; font-size: .78rem; }
}
