/* ── AUTH & PAYWALL ── */
.auth-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fi .2s ease}
.auth-box{background:var(--surface);border-radius:16px;padding:2rem;max-width:380px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3);text-align:center}
.auth-logo{font-size:40px;margin-bottom:.75rem;line-height:1}
.auth-logo img{width:58px;height:58px;display:block;margin:0 auto;border-radius:18px;box-shadow:0 10px 24px rgba(24,69,47,.16)}
.auth-title{font-family:'DM Serif Display',serif;font-size:24px;color:var(--text);margin-bottom:.5rem;letter-spacing:-.01em}
.auth-sub{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:1.5rem}
.auth-google-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:13px 20px;background:#fff;color:#3c4043;border:1.5px solid #dadce0;border-radius:10px;font-family:'Inter',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;box-shadow:0 1px 3px rgba(0,0,0,.08);margin-bottom:.75rem}
.auth-google-btn:hover{background:#f8f9fa;box-shadow:0 2px 6px rgba(0,0,0,.12)}
.auth-email-btn{width:100%;padding:12px 20px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s;margin-bottom:1rem}
.auth-email-btn:hover{background:#1e3d2a}
.auth-email-form{display:flex;flex-direction:column;gap:8px;margin-bottom:1rem}
.auth-email-input{width:100%;box-sizing:border-box;padding:12px 14px;border:1.5px solid var(--border);border-radius:10px;background:#fff;color:var(--text);font-family:'Inter',sans-serif;font-size:14px;outline:none}
.auth-email-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(45,90,61,.12)}
.auth-email-status{min-height:18px;font-size:12px;line-height:1.45;color:var(--text3);margin:-.4rem 0 .85rem}
.auth-email-status.ok{color:var(--accent)}
.auth-email-status.err{color:var(--danger)}
.auth-divider{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;color:var(--text3);font-size:12px}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-skip{font-size:12px;color:var(--text3);cursor:pointer;text-decoration:underline;background:none;border:none;font-family:'Inter',sans-serif}
.auth-skip:hover{color:var(--text2)}
.auth-free-note{font-size:11px;color:var(--text3);margin-top:.75rem;line-height:1.5}

/* Paywall modal */
.paywall-box .auth-title{color:var(--accent)}
.paywall-features{list-style:none;text-align:left;margin:0 0 1.25rem;background:var(--surface2);border-radius:10px;padding:.75rem 1rem}
.paywall-features li{font-size:12px;color:var(--text2);padding:.25rem 0;display:flex;align-items:center;gap:8px}
.paywall-features li::before{content:'\2713';color:var(--accent);font-weight:700;flex-shrink:0}
.paywall-price{font-family:'DM Serif Display',serif;font-size:32px;color:var(--accent);margin-bottom:.25rem}
.paywall-price span{font-size:15px;font-family:'Inter',sans-serif;color:var(--text3);font-weight:400}
.paywall-sub-btn{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-family:'DM Serif Display',serif;font-size:18px;cursor:pointer;margin-bottom:.75rem;box-shadow:0 2px 12px rgba(45,90,61,.3)}
.paywall-sub-btn:hover{background:#1e3d2a}
.paywall-plans{display:grid;gap:9px;margin:0 0 1rem}
.paywall-plan-btn{width:100%;border:1px solid var(--border);border-radius:12px;background:var(--surface);padding:12px 14px;text-align:left;cursor:pointer;font-family:'Inter',sans-serif;transition:all .14s;box-shadow:var(--shadow-sm)}
.paywall-plan-btn:hover{border-color:var(--accent);background:var(--accent-l);transform:translateY(-1px)}
.paywall-plan-btn.featured{border-color:rgba(194,154,74,.48);background:linear-gradient(135deg,var(--shen-gold-soft),var(--surface))}
.paywall-plan-top{display:flex;justify-content:space-between;gap:12px;align-items:baseline;font-weight:800;color:var(--text);font-size:14px}
.paywall-plan-price{font-family:'DM Serif Display',serif;font-size:22px;color:var(--accent);white-space:nowrap}
.paywall-plan-copy{display:block;font-size:12px;color:var(--text2);margin-top:3px;line-height:1.45}
.paywall-plan-save{display:inline-block;margin-top:6px;font-size:10px;font-family:'DM Mono',monospace;text-transform:uppercase;letter-spacing:.08em;color:var(--shen-bronze)}
.paywall-free-cases{font-size:12px;color:var(--text3);margin-top:.5rem}
.guest-signup-card{display:none;background:#fff;border:1px solid #d8c2a1;border-radius:12px;padding:1.25rem;margin:1rem 0 0;box-shadow:var(--shadow-sm)}
.guest-signup-card.show{display:block}
.guest-signup-kicker{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#8b4513;margin-bottom:.35rem}
.guest-signup-title{font-family:'DM Serif Display',serif;font-size:22px;line-height:1.2;color:var(--text);margin-bottom:.35rem}
.guest-signup-copy{font-size:13px;color:var(--text2);line-height:1.6;margin-bottom:1rem}
.guest-signup-actions{display:flex;gap:8px;flex-wrap:wrap}
.guest-signup-btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border:none;border-radius:var(--r);font-family:'Inter',sans-serif;font-size:13px;font-weight:700;cursor:pointer;background:var(--accent);color:#fff}
.guest-signup-btn.secondary{background:var(--surface2);color:var(--text2);border:1px solid var(--border)}

/* Lock indicators on gated tabs */
.tab-locked::after{content:' \01F512';font-size:10px;opacity:.6}
.locked-screen{position:absolute;inset:0;background:rgba(245,243,239,.92);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:5;border-radius:var(--rl);text-align:center;padding:2rem;gap:.75rem}
.locked-screen-icon{font-size:40px}
.locked-screen-title{font-family:'DM Serif Display',serif;font-size:20px;color:var(--text)}
.locked-screen-sub{font-size:13px;color:var(--text2);max-width:280px;line-height:1.6}
.locked-screen-btn{padding:11px 28px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;margin-top:.25rem}

/* ── ACCOUNT WIDGET ── */
.sb-account{border-top:1px solid rgba(255,255,255,.12);padding-top:.75rem;margin-top:auto}
.sb-account-user{display:flex;align-items:center;gap:10px;margin-bottom:.5rem;cursor:pointer;padding:6px 8px;border-radius:var(--r);transition:background .12s}
.sb-account-user:hover{background:rgba(255,255,255,.08)}
.sb-account-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.sb-account-avatar img{width:100%;height:100%;object-fit:cover}
.sb-account-info{flex:1;min-width:0}
.sb-account-name{font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-account-plan{font-size:10px;color:rgba(255,255,255,.5);margin-top:1px}
.sb-account-chevron{font-size:10px;color:rgba(255,255,255,.4)}
.sb-logout-btn{width:100%;padding:7px;background:transparent;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.2);border-radius:var(--r);font-size:11px;font-family:'Inter',sans-serif;cursor:pointer;transition:all .15s;text-align:center}
.sb-logout-btn:hover{background:rgba(255,255,255,.1);color:#fff}
.sb-signin-btn{width:100%;padding:8px;background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.25);border-radius:var(--r);font-size:12px;font-family:'Inter',sans-serif;font-weight:600;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;gap:7px}
.sb-signin-btn .ui-icon{width:15px;height:15px;vertical-align:0}
.sb-signin-btn:hover{background:rgba(255,255,255,.2)}

/* Account modal */
.account-modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:1rem;animation:fi .2s ease}
.account-box{background:var(--surface);border-radius:16px;padding:1.75rem;max-width:560px;width:100%;max-height:92vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.account-box-header{display:flex;align-items:center;gap:14px;margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}
.account-avatar-lg{width:52px;height:52px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:#fff;flex-shrink:0;overflow:hidden}
.account-avatar-lg img{width:100%;height:100%;object-fit:cover}
.account-name-lg{font-family:'DM Serif Display',serif;font-size:18px;color:var(--text);margin-bottom:2px}
.account-email{font-size:12px;color:var(--text3)}
.account-plan-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border-radius:99px;margin-top:4px}
.account-plan-badge.free{background:var(--surface2);color:var(--text2)}
.account-plan-badge.paid{background:var(--accent-l);color:var(--accent)}
.account-stats{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1.25rem}
.account-stat{background:var(--surface2);border-radius:var(--r);padding:.65rem .85rem;text-align:center}
.account-stat-n{font-family:'DM Serif Display',serif;font-size:22px;color:var(--text)}
.account-stat-l{font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.account-upgrade-btn{display:block;width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:var(--r);font-family:'Inter',sans-serif;font-size:14px;font-weight:600;cursor:pointer;text-align:center;margin-bottom:.75rem}
.account-manage-btn{display:block;width:100%;padding:10px;background:transparent;color:var(--accent);border:1px solid var(--accent);border-radius:var(--r);font-family:'Inter',sans-serif;font-size:13px;font-weight:500;cursor:pointer;text-align:center;margin-bottom:.75rem}
.account-logout-btn{display:block;width:100%;padding:10px;background:transparent;color:var(--danger);border:1px solid var(--danger);border-radius:var(--r);font-family:'Inter',sans-serif;font-size:13px;font-weight:500;cursor:pointer;text-align:center;margin-bottom:.75rem}
.account-close-btn{display:block;width:100%;padding:8px;background:transparent;color:var(--text3);border:none;font-family:'Inter',sans-serif;font-size:12px;cursor:pointer}

/* ── ACCOUNT PAGE ── */
.acc-hero{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--border)}
.acc-hero h1{font-family:'DM Serif Display',serif;font-size:28px;color:var(--text);line-height:1.15;margin-bottom:6px;letter-spacing:-.02em}
.acc-hero p{font-size:14px;color:var(--text2);margin:0}
.acc-user-section{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem;padding:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--rl)}
.acc-user-avatar{width:48px;height:48px;border-radius:50%;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;color:var(--text);flex-shrink:0;overflow:hidden}
.acc-user-avatar img{width:100%;height:100%;object-fit:cover}
.acc-user-info{flex:1;min-width:0}
.acc-user-name{font-weight:600;font-size:15px;color:var(--text);margin-bottom:1px}
.acc-user-email{font-size:12px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.acc-user-plan{font-size:11px;font-weight:600;color:var(--accent);margin-top:4px;display:inline-block}
.acc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding-bottom:2rem}
.acc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--rl);padding:1rem;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .15s}
.acc-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}
.acc-card-icon{width:38px;height:38px;border-radius:10px;background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.acc-card-info{flex:1;min-width:0}
.acc-card-title{font-size:14px;font-weight:600;color:var(--text);margin-bottom:1px}
.acc-card-sub{font-size:11px;color:var(--text2)}
.acc-card-arrow{font-size:14px;color:var(--text3);flex-shrink:0}
