/* ============================================
   TIA TRADEMARK — V10 Patriotic Theme
   Navy Blue + Red + White  |  Tia™ Brand Colors
   Primary: Navy (#1B3F8B)  |  Accent: Red (#C8102E)
   ============================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700;800&display=swap');

:root {
  --bg-body: #F0F4FA;
  --bg-surface: rgba(255,255,255,0.98);
  --bg-card: rgba(255,255,255,0.95);
  --bg-card-hover: #ffffff;
  --bg-input: #EEF2F9;
  --bg-overlay: rgba(13,27,64,0.5);
  --accent: #C8102E;
  --accent-light: #E8253F;
  --accent-dim: rgba(200,16,46,0.07);
  --accent-glow: rgba(200,16,46,0.22);
  --accent-blue: #1B3F8B;
  --brand-navy: #1B3F8B;
  --brand-blue: #1B3F8B;
  --brand-blue-light: #2A5AC7;
  --text-primary: #0D1B40;
  --text-secondary: #3A5080;
  --text-muted: #7A90B8;
  --success: #16a34a; --success-dim: rgba(22,163,74,0.08);
  --warning: #d97706; --warning-dim: rgba(217,119,6,0.08);
  --danger: #C8102E; --danger-dim: rgba(200,16,46,0.08);
  --info: #1B3F8B; --info-dim: rgba(27,63,139,0.08);
  --border: rgba(27,63,139,0.12);
  --border-accent: rgba(200,16,46,0.25);
  --radius-xs: 6px; --radius-sm: 8px; --radius: 14px; --radius-lg: 20px; --radius-xl: 28px;
  --font-display: 'Outfit', sans-serif;
  --font-body: 'Inter', sans-serif;
  --shadow-sm: 0 2px 8px rgba(13,27,64,0.07);
  --shadow-md: 0 4px 20px rgba(13,27,64,0.10);
  --shadow-lg: 0 8px 40px rgba(13,27,64,0.14);
  --shadow-glow: 0 0 30px var(--accent-glow);
  --ease: cubic-bezier(0.4,0,0.2,1);
  --duration: 0.3s;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--font-body);background:var(--bg-body);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}
a{color:var(--accent);text-decoration:none;transition:color var(--duration)}
a:hover{color:var(--accent-light)}
img{max-width:100%;display:block}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:inherit;color:var(--text-primary)}

/* ── Header ── */
.app-header{background:linear-gradient(135deg,#ffffff 0%,#F8FAFF 100%);color:var(--brand-navy);padding:18px 28px;display:flex;align-items:center;justify-content:space-between;border-bottom:4px solid var(--brand-navy);box-shadow:0 2px 12px rgba(13,27,64,0.10);position:relative}
.app-header::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand-navy) 0%,var(--accent) 50%,var(--brand-navy) 100%)}
.app-header__logo{display:flex;align-items:center;gap:16px}
.app-header__icon-img{width:auto;height:125px;border-radius:0;object-fit:contain;background:transparent;padding:0}
.app-header h1{font-family:var(--font-display);font-size:2.4rem;font-weight:800;letter-spacing:-0.5px;color:var(--brand-navy)}
.app-header__trademark{color:var(--accent)}
.app-header__sub{color:var(--text-secondary);font-size:0.9rem}
.app-header__controls{display:flex;align-items:center;gap:8px}
.lang-btn{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);padding:6px 12px;border-radius:var(--radius-sm);font-size:0.82rem;transition:all var(--duration)}
.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:600}
.lang-btn:hover{background:var(--accent);color:#fff}

/* ── 3-Column Layout ── */
.main-row{display:flex;height:calc(100vh - 70px);overflow:hidden}
.col-debbie{width:360px;min-width:360px;background:var(--bg-surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 20px;overflow-y:auto;backdrop-filter:blur(20px)}
.col-wizard{flex:1;overflow-y:auto;padding:28px 32px}
.col-tracker{width:280px;min-width:280px;background:var(--bg-surface);border-left:1px solid var(--border);padding:24px 20px;overflow-y:auto;backdrop-filter:blur(20px)}

/* ── Debbie Panel ── */
.debbie-portrait{text-align:center;margin-bottom:20px}
.debbie-avatar{width:280px;height:280px;border-radius:50%;object-fit:cover;object-position:center 15%;border:5px solid #fff;box-shadow:0 12px 32px rgba(13,27,64,0.14),0 0 0 3px var(--brand-navy);margin:0 auto 16px;transition:all 0.4s var(--ease);display:block}
.debbie-avatar.speaking{animation:speakingPulse 1.5s ease-in-out infinite;box-shadow:0 12px 32px rgba(13,27,64,0.14),0 0 0 3px var(--success)}
@keyframes speakingPulse{0%,100%{box-shadow:0 12px 32px rgba(13,27,64,0.14),0 0 0 3px var(--success),0 0 20px rgba(22,163,74,0.1)}50%{box-shadow:0 12px 32px rgba(13,27,64,0.14),0 0 0 6px var(--success),0 0 40px rgba(22,163,74,0.15);transform:scale(1.02)}}
.debbie-name{font-family:var(--font-display);font-weight:900;font-size:1.5rem;color:var(--text-primary)}
.debbie-role{font-size:0.85rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
.voice-toggle{display:flex;justify-content:center;gap:8px;margin:12px 0}
.voice-toggle button{background:var(--bg-input);border:1px solid var(--border);padding:6px 14px;border-radius:var(--radius-sm);font-size:0.78rem;color:var(--text-secondary);transition:all var(--duration)}
.voice-toggle button:hover{border-color:var(--accent);color:var(--accent)}
.debbie-coach-bubble{background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius);padding:14px 16px;font-size:0.88rem;line-height:1.6;margin-bottom:16px;position:relative}
.debbie-coach-bubble::before{content:'';position:absolute;top:-8px;left:24px;width:16px;height:16px;background:var(--accent-dim);border-left:1px solid var(--border-accent);border-top:1px solid var(--border-accent);transform:rotate(45deg)}

/* ── Debbie Chat ── */
.debbie-chat{flex:1;display:flex;flex-direction:column;border-top:1px solid var(--border);padding-top:12px;margin-top:8px;min-height:0}
.debbie-chat__messages{flex:1;overflow-y:auto;font-size:0.84rem;display:flex;flex-direction:column;gap:8px}
.chat-msg{padding:8px 12px;border-radius:var(--radius-sm);max-width:95%;line-height:1.5;word-wrap:break-word}
.chat-msg.ai{background:var(--accent-dim);align-self:flex-start;border:1px solid var(--border-accent)}
.chat-msg.user{background:var(--info-dim);align-self:flex-end;border:1px solid rgba(59,130,246,0.2)}
.debbie-chat__input-area{display:flex;gap:6px;margin-top:8px}
.debbie-chat__input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);font-size:0.82rem;color:var(--text-primary)}
.debbie-chat__input:focus{outline:none;border-color:var(--accent)}
.debbie-chat__send{background:var(--accent);color:#fff;border:none;padding:8px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:0.82rem}

/* ── Tracker Panel ── */
.tracker-section{margin-bottom:24px}
.tracker-section h3{font-family:var(--font-display);font-weight:700;font-size:0.95rem;margin-bottom:12px;color:var(--text-primary)}
.xp-bar-container{margin-bottom:16px}
.level-indicator{font-size:0.82rem;font-weight:600;color:var(--accent)}
.xp-bar{height:8px;background:var(--bg-input);border-radius:4px;overflow:hidden;margin:6px 0}
.xp-bar__fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:4px;transition:width 0.6s var(--ease)}
.xp-label{font-size:0.75rem;color:var(--text-muted)}
.achievement-strip{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}
.achievement-badge{font-size:1.2rem;opacity:0.3;transition:all var(--duration)}
.achievement-badge.earned{opacity:1;animation:badgePop 0.5s var(--ease)}
@keyframes badgePop{0%{transform:scale(0.5)}50%{transform:scale(1.3)}100%{transform:scale(1)}}

/* Fee tracker */
.fee-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;backdrop-filter:blur(20px)}
.fee-row{display:flex;justify-content:space-between;padding:6px 0;font-size:0.85rem;border-bottom:1px solid var(--border)}
.fee-row:last-child{border-bottom:none}
.fee-row.total{font-weight:700;color:var(--accent);font-size:0.95rem;border-top:2px solid var(--border);margin-top:4px;padding-top:8px}
.fee-row span:last-child{font-weight:600}

/* Protection type indicator */
.protection-indicator{background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;text-align:center}
.protection-indicator__type{font-family:var(--font-display);font-weight:700;font-size:1rem}
.protection-indicator__desc{font-size:0.78rem;color:var(--text-secondary)}

/* ── Protection Explainer ── */
.protection-explainer{animation:fadeSlideIn 0.5s var(--ease)}
.protection-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}
.protection-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;text-align:center;transition:all var(--duration);position:relative;overflow:hidden;backdrop-filter:blur(20px)}
.protection-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.protection-card.tm::before{background:linear-gradient(90deg,var(--accent),var(--accent-light))}
.protection-card.cr::before{background:linear-gradient(90deg,var(--accent-light),var(--accent))}
.protection-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.protection-card__icon{font-size:2.8rem;margin-bottom:12px}
.protection-card.tm .protection-card__icon{color:var(--accent)}
.protection-card.cr .protection-card__icon{color:var(--accent-light)}
.protection-card__title{font-family:var(--font-display);font-weight:700;font-size:1.3rem;margin-bottom:8px}
.protection-card__desc{font-size:0.88rem;color:var(--text-secondary);line-height:1.5;margin-bottom:16px}
.protection-card__details{list-style:none;text-align:left;font-size:0.85rem;line-height:2}
.protection-card__details li{border-bottom:1px solid var(--border);padding:4px 0}
.protection-card__details li:last-child{border-bottom:none}
.protection-card__example{margin-top:14px;font-size:0.78rem;color:var(--text-muted);font-style:italic}

/* ── Disclaimer ── */
.disclaimer{background:rgba(212,175,55,0.06);border:1px solid rgba(212,175,55,0.15);border-radius:var(--radius-sm);padding:12px 16px;font-size:0.82rem;color:var(--text-secondary);margin-bottom:20px}

/* ── Progress Bar ── */
.progress-bar{display:flex;justify-content:center;gap:0;margin-bottom:28px;position:relative;padding:0 20px}
.progress-bar::before{content:'';position:absolute;top:18px;left:60px;right:60px;height:2px;background:var(--border)}
.progress-step{display:flex;flex-direction:column;align-items:center;gap:6px;position:relative;z-index:1;flex:1;cursor:pointer}
.progress-step__dot{width:36px;height:36px;border-radius:50%;background:var(--bg-surface);border:2px solid var(--border);display:grid;place-items:center;font-family:var(--font-display);font-weight:700;font-size:0.85rem;color:var(--text-muted);transition:all var(--duration)}
.progress-step.active .progress-step__dot{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 12px var(--accent-glow)}
.progress-step.completed .progress-step__dot{background:var(--success);border-color:var(--success);color:#fff}
.progress-step__label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;font-weight:500}
.progress-step.active .progress-step__label{color:var(--accent);font-weight:600}

/* ── Wizard Cards ── */
.wizard-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px 40px;backdrop-filter:blur(20px);box-shadow:var(--shadow-sm)}
.step-panel{display:none}
.step-panel.active{display:block;animation:fadeSlideIn 0.4s var(--ease)}
@keyframes fadeSlideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.wizard-card__title{font-family:var(--font-display);font-weight:700;font-size:1.5rem;margin-bottom:10px}
.wizard-card__desc{color:var(--text-secondary);font-size:0.92rem;margin-bottom:28px;line-height:1.6}
.wizard-nav{display:flex;justify-content:space-between;margin-top:36px;padding-top:24px;border-top:1px solid var(--border);gap:12px}

/* ── Section Divider ── */
.form-section-divider{border:none;border-top:1px solid var(--border);margin:28px 0}

/* ── Tia Step Guide ── */
.tia-step-guide{background:linear-gradient(135deg,rgba(184,150,46,0.07),rgba(184,150,46,0.02));border:1px solid var(--border-accent);border-left:4px solid var(--accent);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:28px;display:flex;align-items:flex-start;gap:14px;line-height:1.65}
.tia-step-guide__icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}
.tia-step-guide__content{flex:1}
.tia-step-guide__title{font-weight:700;font-size:0.88rem;color:var(--accent);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.3px}
.tia-step-guide__text{font-size:0.88rem;color:var(--text-secondary);line-height:1.7}
.tia-step-guide__text strong{color:var(--text-primary)}

/* ── Forms ── */
.form-group{margin-bottom:24px}
.form-label{display:block;font-weight:600;font-size:0.88rem;margin-bottom:8px;color:var(--text-primary)}
.form-input,.form-select,.form-textarea{width:100%;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:0.9rem;transition:border-color var(--duration);line-height:1.5}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}
.form-textarea{min-height:90px;resize:vertical}
.form-hint{font-size:0.8rem;color:var(--text-muted);margin-top:6px;line-height:1.5}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.btn-row{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:0.88rem;border:none;transition:all var(--duration)}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#fff;box-shadow:0 2px 10px var(--accent-glow);font-weight:700}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 16px var(--accent-glow)}
.btn-primary:disabled{opacity:0.5;cursor:not-allowed;transform:none}
.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-success{background:var(--success);color:#fff}
.btn-danger{background:transparent;color:var(--danger);border:1px solid var(--danger-dim);font-size:0.82rem;padding:6px 14px}
.btn-ai{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#fff;box-shadow:0 2px 10px rgba(124,58,237,0.3);white-space:nowrap;padding:12px 24px;font-size:0.92rem}
.btn-ai:hover{transform:translateY(-1px)}

/* ── Choice Cards ── */
.choice-group{display:flex;flex-direction:column;gap:8px}
.choice-card{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration)}
.choice-card:hover{border-color:var(--accent);background:var(--accent-dim)}
.choice-card.selected{border-color:var(--accent);background:var(--accent-dim)}
.choice-card input{display:none}
.choice-card__radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border);position:relative;flex-shrink:0;transition:all var(--duration)}
.choice-card.selected .choice-card__radio{border-color:var(--accent)}
.choice-card.selected .choice-card__radio::after{content:'';position:absolute;inset:3px;border-radius:50%;background:var(--accent)}
.choice-card__title{font-weight:600;font-size:0.9rem}
.choice-card__desc{font-size:0.78rem;color:var(--text-secondary)}

/* ── Upload Zone ── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:48px 24px;text-align:center;cursor:pointer;transition:all var(--duration)}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-dim)}
.upload-zone__icon{font-size:2.5rem;margin-bottom:12px}
.upload-zone__text{color:var(--text-secondary);font-size:0.9rem}
.upload-zone input{display:none}

/* ── Design Preview ── */
.design-preview{display:none;text-align:center;padding:20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-input)}
.design-preview.visible{display:block}
.design-preview img{max-height:200px;margin:0 auto 12px;border-radius:var(--radius-sm)}
.design-preview__name{font-size:0.82rem;color:var(--text-secondary)}

/* ── AI Result Card ── */
.ai-result-card{background:linear-gradient(135deg,rgba(124,58,237,0.08),rgba(167,139,250,0.08));border:1px solid rgba(124,58,237,0.2);border-radius:var(--radius);padding:20px;margin-top:16px}
.ai-result-card__label{font-weight:700;font-size:0.82rem;color:#7c3aed;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.ai-result-card__text{font-size:0.88rem;line-height:1.6}
.ai-result-card__advice{margin-top:12px;font-size:0.82rem;color:var(--text-secondary);padding:8px 12px;background:var(--bg-input);border-radius:var(--radius-sm)}

/* ── Class Grid ── */
.class-grid{display:flex;flex-wrap:wrap;gap:8px}
.class-chip{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:0.82rem;cursor:pointer;transition:all var(--duration)}
.class-chip:hover{border-color:var(--accent)}
.class-chip.selected{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}
.class-chip.recommended{border-color:var(--border-accent)}
.class-chip__number{font-weight:700;color:var(--accent);font-size:0.78rem}

/* ── Search Results ── */
.search-results{display:flex;flex-direction:column;gap:8px}
.search-result{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px}
.search-result__mark{font-weight:700;font-size:0.95rem}
.search-result__meta{font-size:0.78rem;color:var(--text-secondary);margin-top:4px}
.risk-badge{display:inline-block;padding:3px 10px;border-radius:var(--radius-xs);font-size:0.72rem;font-weight:700;text-transform:uppercase}
.risk-badge.low{background:var(--success-dim);color:var(--success)}
.risk-badge.medium{background:var(--warning-dim);color:var(--warning)}
.risk-badge.high{background:var(--danger-dim);color:var(--danger)}

/* ── Export Section ── */
.export-section{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}
.export-section h3{font-family:var(--font-display);font-weight:700;margin-bottom:12px;font-size:1rem}

/* ── Fee Summary (Step 4) ── */
.fee-summary{background:var(--accent-dim);border:1px solid var(--border-accent);border-radius:var(--radius);padding:20px;margin-top:24px}
.fee-summary__title{font-family:var(--font-display);font-weight:700;margin-bottom:12px;font-size:1rem}

/* ── Spinner / Loading ── */
.spinner{width:24px;height:24px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:none;place-items:center;z-index:1000}
.loading-overlay.visible{display:grid}
.loading-card{background:var(--bg-surface);border-radius:var(--radius);padding:40px;text-align:center;box-shadow:var(--shadow-lg)}

/* ── Settings Modal ── */
.settings-modal-overlay{position:fixed;inset:0;background:var(--bg-overlay);display:none;place-items:center;z-index:999}
.settings-modal-overlay.visible{display:grid}
.settings-modal{background:var(--bg-surface);border-radius:var(--radius-lg);padding:32px;width:90%;max-width:460px;box-shadow:var(--shadow-lg)}
.settings-modal__title{font-family:var(--font-display);font-weight:700;font-size:1.2rem;margin-bottom:20px}
.settings-toggle{position:fixed;bottom:20px;right:20px;width:48px;height:48px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border);box-shadow:var(--shadow-md);font-size:1.2rem;z-index:50;display:grid;place-items:center}

/* ── Gamification Toasts ── */
.xp-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--bg-surface);border:1px solid var(--border-accent);border-radius:var(--radius);padding:12px 24px;font-weight:600;font-size:0.88rem;box-shadow:var(--shadow-lg);z-index:999;opacity:0;transition:all 0.4s var(--ease)}
.xp-toast.visible{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── Confetti ── */
.confetti-piece{position:fixed;width:8px;height:8px;border-radius:2px;z-index:1000;animation:confettiFall 2s ease-out forwards;pointer-events:none}
@keyframes confettiFall{0%{opacity:1;transform:translateY(0) rotate(0)}100%{opacity:0;transform:translateY(100vh) rotate(720deg)}}

/* ── Typing Dots ── */
.typing-dots{display:inline-flex;gap:4px;align-items:center}
.typing-dots span{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:typingBounce 1.2s ease-in-out infinite}
.typing-dots span:nth-child(2){animation-delay:0.2s}
.typing-dots span:nth-child(3){animation-delay:0.4s}
@keyframes typingBounce{0%,80%,100%{transform:scale(0.6);opacity:0.4}40%{transform:scale(1);opacity:1}}

/* ── Responsive ── */
@media(max-width:1024px){
  .main-row{flex-direction:column;height:auto}
  .col-debbie{width:100%;min-width:auto;flex-direction:row;align-items:center;gap:16px;padding:16px;border-right:none;border-bottom:1px solid var(--border)}
  .debbie-portrait{margin-bottom:0;display:flex;align-items:center;gap:12px}
  .debbie-avatar{width:72px;height:72px;margin:0}
  .debbie-name{font-size:1rem}
  .debbie-coach-bubble{margin-bottom:0;flex:1}
  .debbie-coach-bubble::before{display:none}
  .debbie-chat{display:none}
  .col-tracker{width:100%;min-width:auto;border-left:none;border-top:1px solid var(--border);padding:16px}
  .col-wizard{padding:20px 16px}
}
@media(max-width:640px){
  .protection-cards{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .app-header{flex-direction:column;text-align:center;gap:8px}
}

/* ── Print ── */
@media print {
  /* Hide non-essential UI */
  .col-debbie, .col-tracker, .settings-toggle, .app-header__controls,
  .progress-bar, .wizard-nav, .landing-page, .tab-nav,
  .btn, button, #protectionExplainer, .chat-sidebar,
  nav, footer, .confetti-container { display: none !important; }

  /* Layout reset */
  body { background: white !important; color: #111 !important; font-size: 11pt; }
  .main-row { display: block !important; }
  .col-wizard { width: 100% !important; max-width: 100% !important; padding: 0 !important;
    overflow: visible !important; height: auto !important; }

  /* Show only Step 5 (filing package) */
  .step-panel { display: none !important; }
  .step-panel[data-step="5"] { display: block !important; }

  /* Full-width wizard card */
  .wizard-card { box-shadow: none !important; border: none !important;
    margin: 0 !important; padding: 16px !important; break-inside: avoid; }

  /* Export items — prevent cutoff */
  .export-item { display: flex; justify-content: space-between; gap: 12px;
    padding: 6px 0; border-bottom: 1px solid #eee; page-break-inside: avoid; }
  .export-item span { word-wrap: break-word; overflow-wrap: break-word;
    white-space: normal !important; max-width: none !important; }
  .export-item span:last-child { text-align: right; flex-shrink: 0; max-width: 60%; }

  /* Mark description — full text, no truncation */
  .form-textarea, textarea { white-space: pre-wrap !important;
    word-wrap: break-word !important; overflow: visible !important;
    height: auto !important; min-height: 0 !important; border: none !important; }

  /* Typography */
  h2, h3, h4 { color: #111 !important; page-break-after: avoid; }
  a { color: #2563eb !important; text-decoration: underline; }
  .risk-badge { border: 1px solid currentColor; }

  /* Page setup */
  @page { margin: 0.75in; size: letter; }

  /* Show print header */
  .wizard-card__title::before {
    content: "Trademarker AI — Filing Package";
    display: block; font-size: 9pt; color: #666;
    margin-bottom: 8px; border-bottom: 1px solid #ccc; padding-bottom: 4px;
  }
}

/* ── Enjoyability Polish ── */

/* Pulsing CTA button */
#startFilingBtn{animation:ctaPulse 2s ease-in-out infinite;font-size:1.05rem;padding:14px 28px}
@keyframes ctaPulse{0%,100%{box-shadow:0 2px 10px var(--accent-glow)}50%{box-shadow:0 4px 24px var(--accent-glow),0 0 40px rgba(27,63,139,0.2);transform:translateY(-1px)}}

/* Landing page entrance */
#protectionExplainer img{animation:floatIn 0.8s var(--ease) both}
#protectionExplainer .protection-card.tm{animation:fadeSlideIn 0.6s var(--ease) 0.2s both}
#protectionExplainer .protection-card.cr{animation:fadeSlideIn 0.6s var(--ease) 0.4s both}

/* Protection card interactive hover */
.protection-card{cursor:pointer}
.protection-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,0.08);border-color:var(--brand-blue)}
.protection-card:active{transform:translateY(-1px)}

/* Smooth header logo hover */
.app-header__icon-img:hover{transform:scale(1.05);transition:transform 0.3s var(--ease)}

/* Upload zone interactive delight */
.upload-zone:hover .upload-zone__icon{transform:scale(1.15);transition:transform 0.3s var(--ease)}

/* Float-in animation */
@keyframes floatIn{from{opacity:0;transform:translateY(-20px) scale(0.9)}to{opacity:1;transform:translateY(0) scale(1)}}

/* Step dots hover */
.progress-step:hover .progress-step__dot{transform:scale(1.15);transition:transform 0.2s var(--ease)}

/* Voice button active states */
.voice-toggle button:active{transform:scale(0.95)}

/* ═══ LANDING PAGE — SPLIT LAYOUT ═══ */
.landing-layout {
  display: grid;
  grid-template-columns: 340px 1fr;
  min-height: calc(100vh - 70px);
  overflow-y: auto;
  overflow-x: hidden;
}
/* Conversion sections span full width below the fold */
.landing-layout > .how-it-works,
.landing-layout > .testimonials-section,
.landing-layout > .social-proof-bar,
.landing-layout > .comparison-section,
.landing-layout > .faq-section,
.landing-layout > .trust-badges {
  grid-column: 1 / -1;
  padding-left: 48px;
  padding-right: 48px;
}
.landing-debbie {
  background: linear-gradient(180deg, #EEF2F9, #E2EAF7);
  border-right: 1px solid var(--border);
  padding: 32px 24px;
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  position: sticky;
  top: 0;
  height: calc(100vh - 70px);
}
.landing-debbie__portrait { text-align: center; margin-bottom: 20px; }
.landing-debbie__avatar {
  width: 220px;
  height: 220px;
  border-radius: 50%;
  object-fit: cover;
  object-position: center 15%;
  border: 5px solid #fff;
  box-shadow: 0 12px 32px rgba(13,27,64,0.14), 0 0 0 4px var(--brand-navy);
  margin: 0 auto 14px;
  display: block;
  animation: floatIn 0.8s var(--ease) both;
}
.landing-debbie__name {
  font-family: var(--font-display);
  font-weight: 900;
  font-size: 1.4rem;
  color: var(--text-primary);
}
.landing-debbie__role {
  font-size: 0.82rem;
  color: var(--accent);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.landing-debbie__bubble {
  background: var(--accent-dim);
  border: 1px solid var(--border-accent);
  border-radius: var(--radius);
  padding: 16px 18px;
  font-size: 0.92rem;
  line-height: 1.7;
  margin: 16px 0;
  position: relative;
  min-height: 80px;
  color: var(--text-primary);
}
.landing-debbie__bubble::before {
  content: '';
  position: absolute;
  top: -8px;
  left: 24px;
  width: 16px;
  height: 16px;
  background: var(--accent-dim);
  border-left: 1px solid var(--border-accent);
  border-top: 1px solid var(--border-accent);
  transform: rotate(45deg);
}
.landing-debbie__cursor {
  display: inline-block;
  width: 2px;
  height: 1em;
  background: var(--accent);
  margin-left: 2px;
  animation: cursorBlink 1s steps(2) infinite;
  vertical-align: text-bottom;
}
@keyframes cursorBlink { 0% { opacity: 1; } 50% { opacity: 0; } }

/* Landing Chat */
.landing-debbie__chat {
  flex: 1;
  display: flex;
  flex-direction: column;
  border-top: 1px solid var(--border);
  padding-top: 12px;
  margin-top: 8px;
  min-height: 0;
}
.landing-chat__messages {
  flex: 1;
  overflow-y: auto;
  font-size: 0.84rem;
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 200px;
}
.landing-chat__input-area {
  display: flex;
  gap: 6px;
  margin-top: 8px;
}
.landing-chat__input {
  flex: 1;
  padding: 10px 14px;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  background: var(--bg-input);
  font-size: 0.85rem;
  color: var(--text-primary);
}
.landing-chat__input:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px var(--accent-dim); }
.landing-chat__send {
  background: var(--accent);
  color: #fff;
  border: none;
  padding: 10px 16px;
  border-radius: var(--radius-sm);
  font-weight: 700;
  font-size: 0.9rem;
  transition: all var(--duration);
}
.landing-chat__send:hover { transform: translateY(-1px); box-shadow: 0 4px 12px var(--accent-glow); }

/* Landing Content */
.landing-content {
  padding: 48px 40px;
  overflow-y: auto;
  max-height: none;
}
.landing-hero-text { margin-bottom: 32px; }
.landing-headline {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.4rem;
  line-height: 1.15;
  color: var(--text-primary);
  letter-spacing: -0.5px;
}
.landing-headline--accent {
  background: linear-gradient(135deg, var(--brand-navy), var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.landing-subline {
  font-size: 1.05rem;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-top: 12px;
  max-width: 560px;
}
.landing-choice-section { margin-top: 24px; }

/* ═══ SOCIAL PROOF BAR ═══ */
.social-proof-bar {
  display: flex;
  justify-content: center;
  gap: 40px;
  padding: 28px 32px;
  margin: 0;
  background: linear-gradient(135deg, rgba(27,63,139,0.07), rgba(27,63,139,0.02));
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}
.social-proof__stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  min-width: 100px;
}
.social-proof__number {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--accent);
}
.social-proof__label {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 500;
}

/* ═══ COMPARISON TABLE ═══ */
.comparison-section {
  margin: 0;
  padding-top: 36px;
  padding-bottom: 36px;
}
.comparison-section__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--text-primary);
  margin-bottom: 16px;
  text-align: center;
}
.comparison-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.88rem;
  border-radius: var(--radius-sm);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.comparison-table th,
.comparison-table td {
  padding: 12px 14px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}
.comparison-table th {
  background: var(--bg-input);
  font-weight: 600;
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--text-secondary);
}
.comparison-table td:first-child {
  text-align: left;
  font-weight: 500;
  color: var(--text-primary);
}
.comparison-table__highlight {
  background: linear-gradient(135deg, rgba(27,63,139,0.07), rgba(27,63,139,0.02));
  color: var(--brand-navy) !important;
  font-weight: 700 !important;
}
.comparison-table tbody tr:hover {
  background: rgba(27,63,139,0.03);
}

/* ═══ FAQ SECTION ═══ */
.faq-section {
  margin: 0;
  padding-top: 36px;
  padding-bottom: 36px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}
.faq-section__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.2rem;
  color: var(--text-primary);
  margin-bottom: 16px;
  text-align: center;
}
.faq-item {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
  overflow: hidden;
  background: var(--bg-surface);
  transition: all var(--duration);
}
.faq-item:hover {
  border-color: var(--border-accent);
}
.faq-item summary {
  padding: 14px 18px;
  font-weight: 600;
  font-size: 0.92rem;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-primary);
}
.faq-item summary::before {
  content: '▸';
  color: var(--accent);
  font-weight: 700;
  transition: transform var(--duration);
}
.faq-item[open] summary::before {
  transform: rotate(90deg);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item p {
  padding: 0 18px 14px;
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--text-secondary);
}

/* ═══ TRUST BADGES ═══ */
.trust-badges {
  display: flex;
  justify-content: center;
  gap: 20px;
  padding: 24px;
  margin: 0;
  flex-wrap: wrap;
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
}
.trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.78rem;
  color: var(--text-muted);
  font-weight: 500;
  padding: 6px 12px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: 20px;
}

/* ═══ ATTORNEY REFERRAL CARD ═══ */
.attorney-card {
  display: flex;
  gap: 20px;
  margin-top: 28px;
  padding: 24px;
  background: linear-gradient(135deg, rgba(27,63,139,0.07), rgba(27,63,139,0.03));
  border: 1px solid rgba(27,63,139,0.15);
  border-radius: var(--radius);
  animation: fadeSlideIn 0.5s var(--ease);
}
.attorney-card__icon {
  font-size: 3rem;
  flex-shrink: 0;
  line-height: 1;
}
.attorney-card__content { flex: 1; }
.attorney-card__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--accent);
  margin-bottom: 8px;
}
.attorney-card__desc {
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 12px;
}
.attorney-card__benefits {
  list-style: none;
  font-size: 0.85rem;
  line-height: 1.8;
  margin-bottom: 16px;
  color: var(--text-primary);
}
.attorney-card__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}
.attorney-card__note {
  font-size: 0.75rem;
  color: var(--text-muted);
  line-height: 1.5;
}

/* ═══ AI ALTERNATIVES (Step 3 Conflict Resolution) ═══ */
.alt-name-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.alt-name-chip {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--duration);
  flex: 1;
  min-width: 200px;
}
.alt-name-chip:hover {
  border-color: var(--accent);
  background: var(--accent-dim);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}
.alt-name-chip__name {
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--text-primary);
}
.alt-name-chip__reason {
  font-size: 0.78rem;
  color: var(--text-secondary);
  line-height: 1.4;
}
.alt-name-chip__risk {
  flex-shrink: 0;
}
.alt-name-chip.verified {
  border-color: var(--success);
  border-left: 3px solid var(--success);
  background: linear-gradient(135deg, #f0fdf4, #fff);
}

.alt-logo-suggestions {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.alt-logo-suggestion {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 16px;
  background: rgba(124,58,237,0.06);
  border: 1px solid rgba(124,58,237,0.15);
  border-radius: var(--radius-sm);
  font-size: 0.88rem;
  line-height: 1.5;
}
.alt-logo-suggestion__icon { font-size: 1.2rem; flex-shrink: 0; }

/* Logo Redesign Carousel */
.logo-redesign-area {
  margin-top: 16px;
}
.logo-redesign-scroll {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding-bottom: 8px;
}
.logo-redesign-scroll::-webkit-scrollbar { height: 4px; }
.logo-redesign-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }
.logo-redesign-card {
  flex-shrink: 0;
  width: 200px;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-card);
  border: 2px solid var(--border);
  transition: all var(--duration);
  cursor: pointer;
}
.logo-redesign-card:hover {
  border-color: var(--accent);
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
}
.logo-redesign-card img {
  width: 100%;
  height: 160px;
  object-fit: contain;
  background: #f8f9fa;
  padding: 12px;
}
.logo-redesign-card__info {
  padding: 10px 12px;
}
.logo-redesign-card__label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.logo-redesign-card__btn {
  display: block;
  width: 100%;
  padding: 8px;
  background: var(--accent-dim);
  border: none;
  border-radius: var(--radius-xs);
  color: var(--accent);
  font-weight: 600;
  font-size: 0.78rem;
  cursor: pointer;
  transition: all var(--duration);
  font-family: var(--font-body);
}
.logo-redesign-card__btn:hover {
  background: var(--accent);
  color: #fff;
}

/* ═══ RESPONSIVE — Landing ═══ */
@media(max-width:900px) {
  .landing-layout {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .landing-debbie {
    position: relative;
    height: auto;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    padding: 16px 20px;
    border-right: none;
    border-bottom: 1px solid var(--border);
  }
  .landing-debbie__portrait {
    margin-bottom: 0;
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
  }
  .landing-debbie__avatar { width: 64px; height: 64px; margin: 0; border-width: 3px; }
  .landing-debbie__name { font-size: 0.9rem; display: inline; }
  .landing-debbie__role { display: none; }
  .landing-debbie__bubble { flex: 1; min-height: auto; padding: 10px 14px; font-size: 0.82rem; margin: 0; }
  .landing-debbie__bubble::before { display: none; }
  .landing-debbie__chat { display: none; }
  .landing-content { padding: 24px 16px; max-height: none; }
  .landing-headline { font-size: 1.6rem; }
  .landing-subline { font-size: 0.9rem; }
  .attorney-card { flex-direction: column; }
}

/* ═══ MOBILE DEBBIE FAB ═══ */
.debbie-fab {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--brand-navy), var(--brand-blue-light));
  border: none;
  box-shadow: 0 4px 20px var(--accent-glow);
  z-index: 999;
  cursor: pointer;
  overflow: hidden;
  transition: transform var(--duration);
}
.debbie-fab:hover { transform: scale(1.1); }
.debbie-fab img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 15%;
}
@media(max-width:1024px) {
  .debbie-fab { display: block; }
}

/* ═══ Wizard Tabs ═══ */
.wizard-tabs {
  display: flex; gap: 0; margin-bottom: 16px;
  border-bottom: 2px solid var(--border);
}
.wizard-tab {
  background: none; border: none; padding: 10px 20px; cursor: pointer;
  font-family: var(--font-display); font-weight: 600; font-size: 0.92rem;
  color: var(--text-muted); border-bottom: 3px solid transparent;
  margin-bottom: -2px; transition: all 0.2s var(--ease);
}
.wizard-tab:hover { color: var(--text-primary); }
.wizard-tab.active {
  color: var(--accent); border-bottom-color: var(--accent);
}

/* ═══ Logo Studio ═══ */
.logo-studio {
  background: var(--bg-card); border-radius: var(--radius);
  padding: 28px; border: 1px solid var(--border);
}
.logo-studio__workspace {
  display: grid; grid-template-columns: 200px 1fr; gap: 24px;
  margin-top: 20px;
}
.logo-studio__current h4,
.logo-studio__results h4,
.logo-studio__history h4 {
  font-family: var(--font-display); font-weight: 700; font-size: 0.92rem;
  margin-bottom: 10px;
}
.logo-studio__preview {
  width: 200px; height: 200px;
  background: var(--bg-input); border: 2px dashed var(--border);
  border-radius: var(--radius-sm); display: flex; align-items: center;
  justify-content: center; overflow: hidden;
}
.logo-studio__preview img {
  width: 100%; height: 100%; object-fit: contain;
}
.logo-studio__empty {
  padding: 20px; text-align: center; font-size: 0.82rem;
  color: var(--text-muted);
}
.logo-studio__prompt-row {
  display: flex; gap: 10px; align-items: flex-start;
}
.logo-studio__prompt-row textarea { flex: 1; }
.logo-studio__prompt-row .btn { min-width: 110px; align-self: stretch; }
.logo-studio__quick-prompts {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px;
}
.studio-chip {
  background: var(--accent-dim); border: 1px solid rgba(37,99,235,0.2);
  color: var(--accent); padding: 5px 12px; border-radius: 99px;
  font-size: 0.78rem; font-weight: 600; cursor: pointer;
  transition: all 0.15s var(--ease);
}
.studio-chip:hover {
  background: var(--accent); color: #fff;
}

/* Studio Results Grid */
.logo-studio__grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
}
.studio-variant-card {
  background: var(--bg-input); border-radius: var(--radius-sm);
  border: 2px solid var(--border); overflow: hidden;
  transition: all 0.2s var(--ease); cursor: pointer;
}
.studio-variant-card:hover {
  border-color: var(--accent); box-shadow: 0 4px 16px rgba(37,99,235,0.15);
  transform: translateY(-2px);
}
.studio-variant-card img {
  width: 100%; aspect-ratio: 1; object-fit: contain; background: #fff;
}
.studio-variant-card__actions {
  padding: 8px 10px; display: flex; gap: 6px;
}
.studio-variant-card__actions .btn { flex: 1; font-size: 0.78rem; padding: 6px 8px; }

/* Studio History */
.logo-studio__history-scroll {
  display: flex; gap: 10px; overflow-x: auto; padding-bottom: 8px;
  scroll-snap-type: x mandatory;
}
.history-thumb {
  width: 80px; height: 80px; flex-shrink: 0;
  border-radius: var(--radius-sm); border: 2px solid var(--border);
  overflow: hidden; cursor: pointer; scroll-snap-align: start;
  transition: all 0.15s var(--ease);
}
.history-thumb:hover { border-color: var(--accent); }
.history-thumb.active { border-color: var(--accent); box-shadow: 0 0 0 2px var(--accent-dim); }
.history-thumb img { width: 100%; height: 100%; object-fit: contain; background: #fff; }

/* ═══ Agent Progress Overlay ═══ */
.agent-progress {
  margin-bottom: 16px;
}
.agent-progress__card {
  display: flex; align-items: center; gap: 16px;
  background: linear-gradient(135deg, rgba(27,63,139,0.06), rgba(27,63,139,0.02));
  border: 1px solid var(--border-accent); border-radius: var(--radius);
  padding: 16px 20px;
  animation: agentPulse 2s ease-in-out infinite;
}
@keyframes agentPulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(200,16,46,0.1); }
  50% { box-shadow: 0 0 0 8px rgba(200,16,46,0.05); }
}
.agent-progress__avatar {
  width: 48px; height: 48px; border-radius: 50%;
  object-fit: cover; object-position: center 15%;
  border: 2px solid var(--accent);
}
.agent-progress__info { flex: 1; }
.agent-progress__title {
  font-family: var(--font-display); font-weight: 700; font-size: 0.95rem;
  color: var(--accent);
}
.agent-progress__step {
  font-size: 0.85rem; color: var(--text-secondary); margin-top: 2px;
}
.agent-progress__bar {
  height: 6px; background: var(--border); border-radius: 99px;
  margin-top: 8px; overflow: hidden;
}
.agent-progress__fill {
  height: 100%; background: linear-gradient(90deg, var(--accent), var(--accent-light));
  border-radius: 99px; transition: width 0.6s var(--ease);
}

/* ═══ Alternatives ═══ */
.alt-name-grid {
  display: flex; flex-direction: column; gap: 8px;
}
.alt-name-chip {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 16px; background: var(--bg-input);
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  cursor: pointer; transition: all 0.2s var(--ease);
}
.alt-name-chip:hover {
  border-color: var(--accent); background: var(--accent-dim);
  transform: translateX(4px);
}
.alt-name-chip__name {
  font-family: var(--font-display); font-weight: 700;
  font-size: 1rem; color: var(--text-primary);
}
.alt-name-chip__reason {
  font-size: 0.82rem; color: var(--text-secondary); margin-top: 2px;
}
.risk-badge.low { background: var(--success-dim); color: var(--success); }
.risk-badge.medium { background: var(--warning-dim); color: var(--warning); }
.risk-badge.high { background: var(--danger-dim); color: var(--danger); }

.alt-logo-suggestions { display: flex; flex-direction: column; gap: 8px; }
.alt-logo-suggestion {
  display: flex; gap: 10px; align-items: flex-start;
  padding: 10px 14px; background: var(--bg-input);
  border-radius: var(--radius-sm); font-size: 0.88rem;
}
.alt-logo-suggestion__icon { font-size: 1.2rem; flex-shrink: 0; }

/* Logo Redesign Carousel */
.logo-redesign-scroll {
  display: flex; gap: 12px; overflow-x: auto; padding-bottom: 8px;
}
.logo-redesign-card {
  flex-shrink: 0; width: 200px; background: var(--bg-input);
  border-radius: var(--radius-sm); border: 2px solid var(--border);
  overflow: hidden; transition: all 0.2s var(--ease);
}
.logo-redesign-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.logo-redesign-card img { width: 100%; aspect-ratio: 1; object-fit: contain; background: #fff; }
.logo-redesign-card__info { padding: 8px 10px; }
.logo-redesign-card__label { font-weight: 600; font-size: 0.82rem; }
.logo-redesign-card__btn {
  margin-top: 6px; width: 100%; padding: 6px; border: none; border-radius: 6px;
  background: var(--accent); color: #fff; font-size: 0.78rem; font-weight: 600;
  cursor: pointer; transition: background 0.15s;
}
.logo-redesign-card__btn:hover { background: var(--brand-blue-light); }

/* ═══ Export / Package Styles ═══ */
.export-section {
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px;
  margin-bottom: 16px;
}

/* ═══ PREMIUM REPORT STYLES ═══ */
.export-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 24px;
  background: linear-gradient(135deg, #EEF2F9, #E2EAF7);
  border: 1px solid var(--border);
  border-left: 5px solid var(--brand-navy);
  border-radius: var(--radius-sm);
  margin-bottom: 0;
}
.export-header__brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.export-header__brand-logo {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--brand-navy);
  box-shadow: 0 2px 8px rgba(27,63,139,0.18);
}
.export-header__accent-bar {
  height: 4px;
  background: linear-gradient(90deg, var(--brand-navy), var(--accent), var(--brand-navy));
  border-radius: 0 0 4px 4px;
  margin-bottom: 20px;
}
.export-header__logo {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.3rem;
  color: var(--brand-navy);
}
.export-header__sub {
  font-size: 0.78rem;
  color: var(--text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.export-header__meta { text-align: right; }
.export-header__mark-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--text-primary);
}
.export-header__id {
  font-size: 0.75rem;
  color: var(--text-muted);
}
.export-header__logo-img {
  max-height: 56px;
  max-width: 100px;
  border-radius: 6px;
  border: 1px solid var(--border);
  margin-left: 16px;
}

/* Executive Summary */
.export-exec-summary {
  padding: 18px 22px;
  background: linear-gradient(135deg, rgba(27,63,139,0.06), rgba(27,63,139,0.02));
  border: 1px solid var(--border-accent);
  border-radius: var(--radius-sm);
  margin-bottom: 20px;
}
.export-exec-summary p {
  font-size: 0.92rem;
  line-height: 1.7;
  color: var(--text-primary);
  margin: 8px 0 0;
}

/* Section containers */
.export-section {
  margin-bottom: 20px;
  padding: 16px 20px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
}
.export-section__heading {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--text-primary);
  margin-bottom: 14px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--accent-dim);
}
.export-section__sublabel {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-secondary);
  margin: 8px 0 6px;
}

/* Export items */
.export-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(13,27,64,0.06);
  font-size: 0.9rem;
  gap: 16px;
}
.export-item span:first-child { color: var(--text-secondary); font-weight: 500; }
.export-item span:last-child { text-align: right; flex-shrink: 0; max-width: 60%; color: var(--text-primary); }
.export-item:last-child { border-bottom: none; }
.export-item__long {
  max-width: 55% !important;
  word-wrap: break-word;
  overflow-wrap: break-word;
  white-space: normal;
}
.export-item--total {
  font-weight: 700;
  font-size: 1.05rem;
  border-top: 2px solid var(--accent);
  border-bottom: none;
  padding-top: 12px;
  margin-top: 4px;
}
.export-item--total span { color: var(--accent) !important; }

/* Readiness bar */
.export-readiness-bar {
  height: 8px;
  background: var(--bg-input);
  border-radius: 4px;
  overflow: hidden;
  margin-bottom: 12px;
}
.export-readiness-bar__fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s var(--ease);
}
.export-checklist {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 16px;
}
.export-checklist__item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85rem;
  color: var(--text-primary);
}
.export-checklist__icon { flex-shrink: 0; }
.export-checklist__missing { color: var(--text-muted); font-style: italic; }

/* Enriched class blocks */
.export-class-block {
  padding: 12px 0;
  border-bottom: 1px solid rgba(13,27,64,0.06);
}
.export-class-block:last-child { border-bottom: none; }
.export-class-block__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 6px;
}
.export-class-block__nice-desc {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-style: italic;
  margin-top: 2px;
}
.export-class-block__fee {
  font-weight: 700;
  color: var(--text-primary);
  flex-shrink: 0;
}
.export-class-block__goods {
  font-size: 0.88rem;
  color: var(--text-primary);
  line-height: 1.5;
  word-wrap: break-word;
}
.export-class-block__terms {
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.5;
  margin-top: 4px;
  padding-top: 4px;
  border-top: 1px dashed rgba(13,27,64,0.08);
}
.export-class-block__label {
  font-weight: 600;
  font-size: 0.78rem;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  margin-right: 4px;
}

/* Risk meter */
.export-risk-meter {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
}
.export-risk-meter__label {
  font-size: 0.85rem;
  color: var(--text-secondary);
  font-weight: 500;
  flex-shrink: 0;
}
.export-risk-meter__bar {
  flex: 1;
  height: 8px;
  background: var(--bg-input);
  border-radius: 4px;
  overflow: hidden;
}
.export-risk-meter__fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s var(--ease);
}
.export-risk-meter__badge {
  font-weight: 700;
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

/* Conflict rows */
.export-conflicts { margin-top: 8px; }
.export-conflict-row {
  padding: 10px 0;
  border-bottom: 1px solid rgba(13,27,64,0.05);
}
.export-conflict-row:last-child { border-bottom: none; }
.export-conflict-row__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.export-conflict-row__details {
  font-size: 0.82rem;
  color: var(--text-secondary);
  margin-top: 3px;
}
.export-conflict-row__reasoning {
  font-size: 0.8rem;
  color: var(--text-muted);
  font-style: italic;
  margin-top: 4px;
}
.export-conflict-row__link {
  margin-top: 4px;
}
.export-conflict-row__link a {
  font-size: 0.8rem;
  color: var(--accent);
  font-weight: 500;
}

/* AI Analysis block */
.export-ai-analysis {
  font-size: 0.85rem;
  color: var(--text-secondary);
  padding: 12px 14px;
  background: var(--accent-dim);
  border-radius: var(--radius-sm);
  margin-top: 10px;
  line-height: 1.6;
  word-wrap: break-word;
  white-space: pre-line;
}

/* Fee note */
.export-fee-note {
  font-size: 0.78rem;
  color: var(--text-muted);
  font-style: italic;
  margin-top: 8px;
  line-height: 1.5;
}

/* Deadlines box */
.export-deadlines {
  padding: 16px 20px;
  background: rgba(27,63,139,0.04);
  border: 1px solid rgba(27,63,139,0.15);
  border-radius: var(--radius-sm);
  margin-bottom: 20px;
}
.export-deadlines ul {
  margin: 6px 0 0 16px;
  line-height: 1.9;
  font-size: 0.88rem;
  color: var(--text-primary);
}

/* Filing instructions */
.export-instructions-block { margin-bottom: 12px; }
.export-instructions__title {
  font-family: var(--font-display);
  font-weight: 700;
  color: var(--accent);
  margin-bottom: 8px;
  font-size: 1rem;
}
.export-instructions__list {
  padding-left: 20px;
  line-height: 2;
  font-size: 0.9rem;
  color: var(--text-secondary);
}
.export-instructions__list a { color: var(--accent); }
.export-pro-tips {
  margin-top: 20px;
  padding: 16px;
  background: rgba(27,63,139,0.04);
  border: 1px solid rgba(27,63,139,0.12);
  border-radius: var(--radius-sm);
  font-size: 0.85rem;
  color: var(--text-secondary);
}
.export-pro-tips ul {
  margin-top: 8px;
  padding-left: 16px;
  line-height: 1.8;
}

/* Footer */
.export-footer {
  margin-top: 24px;
  padding: 18px;
  background: var(--accent-dim);
  border-radius: var(--radius-sm);
  text-align: center;
  font-size: 0.82rem;
  color: var(--text-muted);
  line-height: 1.6;
}
.export-footer__divider {
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--accent), transparent);
  border-radius: 2px;
  margin-bottom: 16px;
}
.export-footer__brand-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-bottom: 8px;
}
.export-footer__logo-img {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--accent);
}
.export-footer__brand {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
  color: var(--accent);
  margin-bottom: 0;
}
.export-footer__url {
  font-size: 0.75rem;
  color: var(--text-muted);
  letter-spacing: 0.3px;
}
.export-footer__disclaimer {
  font-size: 0.73rem;
  margin-top: 8px;
  font-style: italic;
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  line-height: 1.5;
}

/* Process Timeline */
.process-timeline {
  display: flex;
  gap: 0;
  margin: 16px 0;
  position: relative;
}
.timeline-step {
  flex: 1;
  text-align: center;
  padding: 12px 8px;
  position: relative;
  font-size: 0.78rem;
  color: var(--text-secondary);
}
.timeline-step::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--accent-dim);
  z-index: 0;
}
.timeline-step:first-child::before { left: 50%; }
.timeline-step:last-child::before { right: 50%; }
.timeline-step__dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 700;
  margin: 0 auto 6px;
  position: relative;
  z-index: 1;
}
.timeline-step__label { font-weight: 600; }
.timeline-step__time { font-size: 0.7rem; color: var(--text-muted); }

/* Paywall overlay — kept for potential future premium gate */
.paywall-overlay {
  position: relative;
  border: 2px solid var(--accent);
  border-radius: var(--radius);
  overflow: hidden;
  padding: 32px;
  text-align: center;
  background: linear-gradient(135deg, rgba(27,63,139,0.05), #F0F4FA);
}

/* ═══ Free Download CTA ═══ */
.download-cta {
  position: relative;
  border: 2px solid var(--brand-navy);
  border-radius: var(--radius);
  overflow: hidden;
  padding: 32px;
  text-align: center;
  background: linear-gradient(135deg, rgba(27,63,139,0.05), #F0F4FA);
}
.download-cta__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, var(--brand-navy), var(--brand-blue-light));
  color: white;
  padding: 6px 16px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 0.85rem;
  margin-bottom: 8px;
}
.download-cta__counter {
  font-size: 0.82rem;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.download-cta__count {
  font-weight: 800;
  color: var(--accent);
  font-size: 0.9rem;
}
.download-cta__features {
  list-style: none;
  padding: 0;
  margin: 16px 0;
  text-align: left;
  display: inline-block;
}
.download-cta__features li {
  padding: 4px 0;
  font-size: 0.88rem;
  color: var(--text-secondary);
}
.download-cta__features li::before {
  content: '✅ ';
}

/* ═══ Email Capture ═══ */
.email-capture {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid rgba(27,63,139,0.15);
}
.email-capture__label {
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.email-capture__row {
  display: flex;
  gap: 8px;
  max-width: 380px;
  margin: 0 auto;
}
.email-capture__input {
  flex: 1;
  font-size: 0.88rem !important;
  padding: 10px 14px !important;
}
.email-capture__btn {
  white-space: nowrap;
  font-size: 0.85rem;
  padding: 10px 18px;
}
.email-capture__note {
  font-size: 0.72rem;
  color: var(--text-muted);
  margin-top: 8px;
}

.paywall-overlay__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--accent);
  color: white;
  padding: 6px 16px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 0.85rem;
  margin-bottom: 12px;
}
.paywall-overlay__price {
  font-family: var(--font-display);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--text-primary);
  margin: 8px 0;
}
.paywall-overlay__price small {
  font-size: 0.85rem;
  font-weight: 400;
  color: var(--text-muted);
}
.paywall-overlay__features {
  list-style: none;
  padding: 0;
  margin: 16px 0;
  text-align: left;
  display: inline-block;
}
.paywall-overlay__features li {
  padding: 4px 0;
  font-size: 0.88rem;
  color: var(--text-secondary);
}
.paywall-overlay__features li::before {
  content: '✅ ';
}
.btn-pay {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--accent), #a00824);
  color: #fff;
  border: none;
  padding: 14px 32px;
  border-radius: var(--radius);
  font-size: 1rem;
  font-weight: 700;
  font-family: var(--font-display);
  cursor: pointer;
  transition: all 0.2s var(--ease);
  box-shadow: 0 4px 16px rgba(200,16,46,0.3);
}
.btn-pay:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(200,16,46,0.4);
}
.btn-pay:active { transform: translateY(0); }

/* ═══ Responsive ═══ */
@media(max-width:600px) {
  .logo-studio__workspace { grid-template-columns: 1fr; }
  .logo-studio__preview { width: 100%; height: 160px; }
  .logo-studio__prompt-row { flex-direction: column; }
  .logo-studio__prompt-row .btn { width: 100%; }
  .logo-studio__grid { grid-template-columns: repeat(2, 1fr); }
}

/* ═══ Mark Strength Meter ═══ */
.strength-meter {
  margin-top: 12px;
  padding: 16px 18px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  animation: fadeSlideUp 0.4s var(--ease);
}
.strength-meter__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}
.strength-meter__label {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text-primary);
}
.strength-meter__level {
  font-weight: 800;
  font-size: 0.82rem;
  padding: 3px 10px;
  border-radius: 20px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.strength-meter__level--generic { background: var(--danger-dim); color: var(--danger); }
.strength-meter__level--descriptive { background: var(--warning-dim); color: var(--warning); }
.strength-meter__level--suggestive { background: rgba(59,130,246,0.1); color: #3b82f6; }
.strength-meter__level--arbitrary { background: rgba(16,163,74,0.1); color: var(--success); }
.strength-meter__level--fanciful { background: var(--accent-dim); color: var(--accent); }
.strength-meter__bar {
  position: relative;
  height: 10px;
  background: linear-gradient(90deg, #dc2626 0%, #d97706 25%, #3b82f6 50%, #16a34a 75%, #1B3F8B 100%);
  border-radius: 6px;
  overflow: visible;
  margin-bottom: 28px;
}
.strength-meter__fill {
  position: absolute;
  top: -4px;
  width: 18px;
  height: 18px;
  background: white;
  border: 3px solid var(--text-primary);
  border-radius: 50%;
  transition: left 0.6s var(--ease);
  box-shadow: var(--shadow-sm);
  z-index: 2;
}
.strength-meter__markers {
  position: absolute;
  top: 16px;
  left: 0;
  right: 0;
  display: flex;
  justify-content: space-between;
  font-size: 0.68rem;
  color: var(--text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.strength-meter__explanation {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--accent-dim);
  border-radius: var(--radius-xs);
}

/* ═══ Digital Availability ═══ */
.digital-availability {
  margin-top: 16px;
  padding: 16px 18px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  animation: fadeSlideUp 0.4s var(--ease);
}
.digital-availability__header {
  margin-bottom: 12px;
}
.digital-availability__label {
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text-primary);
}
.digital-availability__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
}
.avail-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: var(--bg-input);
  border-radius: var(--radius-xs);
  font-size: 0.82rem;
  font-weight: 500;
  transition: all var(--duration) var(--ease);
}
.avail-item--available { border-left: 3px solid var(--success); }
.avail-item--taken { border-left: 3px solid var(--danger); opacity: 0.7; }
.avail-item--checking { border-left: 3px solid var(--text-muted); }
.avail-item__icon { font-size: 1rem; }
.avail-item__name { flex: 1; color: var(--text-secondary); }
.avail-item__status { font-weight: 700; font-size: 0.78rem; }
.avail-item__status--available { color: var(--success); }
.avail-item__status--taken { color: var(--danger); }

/* ═══ How It Works ═══ */
.how-it-works {
  padding: 40px 24px;
  text-align: center;
  background: var(--bg-surface);
  border-top: 1px solid var(--border);
}
.how-it-works__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--text-primary);
  margin-bottom: 28px;
}
.how-it-works__steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 16px;
  max-width: 900px;
  margin: 0 auto;
}
.hiw-step {
  flex: 1;
  max-width: 260px;
  padding: 24px 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--duration) var(--ease);
}
.hiw-step:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent);
}
.hiw-step__number {
  width: 28px;
  height: 28px;
  background: var(--accent);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.82rem;
  margin: 0 auto 10px;
}
.hiw-step__icon {
  font-size: 2rem;
  margin-bottom: 8px;
}
.hiw-step__title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.95rem;
  color: var(--text-primary);
  margin-bottom: 6px;
}
.hiw-step__desc {
  font-size: 0.82rem;
  color: var(--text-secondary);
  line-height: 1.5;
}
.hiw-step__arrow {
  display: flex;
  align-items: center;
  font-size: 1.5rem;
  color: var(--accent);
  font-weight: 800;
  padding-top: 48px;
}

/* ═══ Testimonials ═══ */
.testimonials-section {
  padding: 40px 24px;
  text-align: center;
  border-top: 1px solid var(--border);
}
.testimonials-section__title {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.4rem;
  color: var(--text-primary);
  margin-bottom: 24px;
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1000px;
  margin: 0 auto;
}
.testimonial-card {
  text-align: left;
  padding: 24px;
  background: var(--bg-surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: all var(--duration) var(--ease);
}
.testimonial-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent);
}
.testimonial-card__stars {
  color: #f59e0b;
  font-size: 1.1rem;
  margin-bottom: 12px;
  letter-spacing: 2px;
}
.testimonial-card__text {
  font-size: 0.88rem;
  color: var(--text-secondary);
  line-height: 1.65;
  font-style: italic;
  margin-bottom: 16px;
}
.testimonial-card__author {
  display: flex;
  align-items: center;
  gap: 10px;
}
.testimonial-card__avatar {
  width: 40px;
  height: 40px;
  background: linear-gradient(135deg, var(--accent), var(--brand-navy));
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.78rem;
}
.testimonial-card__role {
  font-size: 0.78rem;
  color: var(--text-muted);
}

/* ═══ Comparison Table Enhancements ═══ */
.comparison-table__total-row td {
  border-top: 2px solid var(--accent);
  padding-top: 12px;
  font-size: 1.05rem;
}
.comparison-table__total-row .comparison-table__highlight {
  color: var(--accent);
  font-size: 1.15rem;
}

/* Responsive for new sections */
@media (max-width: 768px) {
  .how-it-works__steps {
    flex-direction: column;
    align-items: center;
  }
  .hiw-step { max-width: 100%; }
  .hiw-step__arrow {
    transform: rotate(90deg);
    padding-top: 0;
    padding: 4px 0;
  }
  .testimonials-grid {
    grid-template-columns: 1fr;
  }
  .digital-availability__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ═══ Print Styles ═══ */
@media print {
  /* Hide everything except the filing package */
  .app-header, .col-debbie, .col-tracker, .wizard-tabs,
  .landing-layout, .agent-progress, .logo-studio,
  .wizard-nav, .disclaimer, .progress-step-container,
  .voice-toggle, .debbie-chat, .debbie-coach-bubble,
  .debbie-portrait, .btn, button, .paywall-overlay,
  .download-cta, .email-capture, .tia-step-guide,
  .attorney-card, #wizardTabs, .progress-steps {
    display: none !important;
  }

  /* Show only the active step */
  body { background: white; color: #1a1a1a; font-size: 11pt; }
  .main-row { display: block !important; padding: 0; gap: 0; }
  .col-wizard { width: 100% !important; max-width: 100% !important; padding: 0; overflow: visible; }
  .step-panel { display: block !important; padding: 0; box-shadow: none; border: none; background: white; }
  .step-panel:not([data-step="5"]) { display: none !important; }

  /* Package styling */
  .export-section {
    background: white;
    border: 1px solid #ddd;
    break-inside: avoid;
    page-break-inside: avoid;
    margin-bottom: 24px;
    box-shadow: none;
  }
  .export-item { border-bottom: 1px solid #eee; }

  /* Header for print */
  .step-panel[data-step="5"]::before {
    content: 'TIA TRADEMARK \2014 FILING PACKAGE';
    display: block;
    font-family: 'Outfit', sans-serif;
    font-size: 18pt;
    font-weight: 800;
    color: #1B3F8B;
    text-align: center;
    padding: 24px 0 8px;
    border-bottom: 3px solid #1B3F8B;
    margin-bottom: 24px;
  }
  .step-panel[data-step="5"]::after {
    content: 'Generated by Tia Trademark \2014 AI Filing Agent';
    display: block;
    text-align: center;
    font-size: 9pt;
    color: #888;
    padding-top: 24px;
    margin-top: 32px;
    border-top: 1px solid #ddd;
  }

  /* Clean typography */
  h2, h3, h4 { color: #1a1a1a; }
  a { color: #1B3F8B; text-decoration: underline; }
  .risk-badge { border: 1px solid currentColor; }

  @page {
    margin: 0.75in;
    size: letter;
  }
}

/* ============================================
   GOOGLE ADSENSE — Ad Container Styling
   Blends with navy/red/white patriotic theme
   ============================================ */
.ad-container{max-width:900px;margin:24px auto;padding:16px 0;text-align:center;position:relative;overflow:hidden}
.ad-container--landing{margin:32px auto;padding:24px 16px;border-top:1px solid rgba(27,63,139,0.12);border-bottom:1px solid rgba(27,63,139,0.12)}
.ad-container--wizard{margin:20px 0;padding:16px 0;border-top:1px solid var(--border)}
.ad-container::after{content:'Ad';position:absolute;top:4px;right:8px;font-size:0.6rem;color:var(--text-muted);opacity:0.5;font-family:var(--font-body);letter-spacing:0.5px;text-transform:uppercase}
.ad-container ins{background:transparent !important}

/* Hide ads in print */
@media print{.ad-container{display:none !important}}

/* Mobile: tighten ad spacing */
@media(max-width:768px){
  .ad-container--landing{margin:16px auto;padding:12px 8px}
}

/* ═══ Affiliate Partner Grid ═══ */
.affiliate-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 20px 0 16px;
}
.affiliate-card {
  display: flex;
  flex-direction: column;
  padding: 16px 14px;
  background: var(--bg-surface);
  border: 2px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--text-primary);
  transition: all var(--duration) var(--ease);
  position: relative;
  overflow: hidden;
}
.affiliate-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--brand-navy), var(--accent));
  opacity: 0;
  transition: opacity var(--duration) var(--ease);
}
.affiliate-card:hover {
  border-color: var(--brand-navy);
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(27,63,139,0.12);
}
.affiliate-card:hover::before { opacity: 1; }
.affiliate-card__name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.9rem;
  color: var(--brand-navy);
  margin-bottom: 4px;
}
.affiliate-card__price {
  font-size: 1rem;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 6px;
}
.affiliate-card__tag {
  display: inline-block;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 2px 8px;
  background: var(--accent-dim);
  color: var(--accent);
  border-radius: 20px;
  margin-bottom: auto;
  width: fit-content;
}
.affiliate-card__cta {
  margin-top: 12px;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--brand-navy);
}
.affiliate-card:hover .affiliate-card__cta { color: var(--accent); }

@media(max-width: 640px) {
  .affiliate-grid { grid-template-columns: 1fr; }
}

/* ── Domain Availability: Register & Manual Check Links ── */
.avail-item--manual { opacity: 0.85; }
.avail-item__status--link {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--brand-navy);
  text-decoration: none;
  padding: 2px 8px;
  border: 1px solid var(--brand-navy);
  border-radius: 12px;
  transition: all var(--duration);
}
.avail-item__status--link:hover { background: var(--brand-navy); color: #fff; }
.avail-item__register-link {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--accent);
  text-decoration: none;
  margin-left: 6px;
  padding: 1px 7px;
  border: 1px solid var(--accent);
  border-radius: 10px;
  transition: all var(--duration);
}
.avail-item__register-link:hover { background: var(--accent); color: #fff; }

/* ── Testimonials ── */
.testimonials-section {
  padding: 48px 32px;
  background: linear-gradient(135deg, var(--brand-navy) 0%, #0d1b40 100%);
  text-align: center;
}
.testimonials-section__title {
  font-size: 1.5rem;
  font-weight: 800;
  color: #fff;
  margin: 0 0 32px;
  letter-spacing: -0.3px;
}
.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}
.testimonial-card {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 24px;
  text-align: left;
  transition: transform 0.2s var(--ease), background 0.2s;
}
.testimonial-card:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,0.11);
}
.testimonial-card__stars {
  color: #FBBF24;
  font-size: 1rem;
  letter-spacing: 2px;
  margin-bottom: 12px;
}
.testimonial-card__quote {
  color: rgba(255,255,255,0.9);
  font-size: 0.88rem;
  line-height: 1.7;
  margin: 0 0 20px;
  font-style: italic;
}
.testimonial-card__author {
  display: flex;
  align-items: center;
  gap: 12px;
}
.testimonial-card__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--brand-navy);
  border: 2px solid rgba(255,255,255,0.3);
  color: #fff;
  font-weight: 800;
  font-size: 0.78rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.testimonial-card__name {
  font-weight: 700;
  color: #fff;
  font-size: 0.88rem;
}
.testimonial-card__biz {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.55);
}
@media (max-width: 860px) {
  .testimonials-grid { grid-template-columns: 1fr; }
  .testimonials-section { padding: 32px 16px; }
}


