/* ═══════════════════════════════════════════════════
   Grace-Agent.com — Shared Stylesheet
   ═══════════════════════════════════════════════════ */

/* ── Variables ── */
:root{
  --bg:#181716;
  --surface:#24211f;
  --border:#3a3430;
  --text-primary:#f6efe7;
  --text-secondary:#c5b8aa;
  --green:#e9bb6e;
  --green-dim:rgba(233,187,110,0.14);
  --green-glow:rgba(233,187,110,0.18);
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{overflow-x:hidden;}
body{font-family:'DM Sans',sans-serif;background:linear-gradient(180deg,#181716 0%,#151413 100%);color:var(--text-primary);line-height:1.6;overflow-x:hidden;width:100%;}
body::before{content:'';position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;background:radial-gradient(circle at 80% -10%,rgba(233,187,110,0.14),transparent 42%),radial-gradient(circle at 10% 110%,rgba(196,145,90,0.1),transparent 40%);pointer-events:none;z-index:0;overflow:hidden;}
img,video,iframe{max-width:100%;height:auto;}

/* ── Layout ── */
.container{max-width:1160px;width:100%;margin:0 auto;padding:0 24px;position:relative;z-index:1;}

/* ── Header ── */
header{border-bottom:1px solid var(--border);padding:20px 0;position:sticky;top:0;background:rgba(24,23,22,0.9);backdrop-filter:blur(12px);z-index:100;width:100%;}
header .inner{display:flex;justify-content:space-between;align-items:center;}
.logo{font-family:'DM Sans',sans-serif;font-size:22px;font-weight:700;letter-spacing:0;color:var(--text-primary);text-decoration:none;display:flex;align-items:center;gap:10px;}
.logo span{color:var(--green);}
.logo-mark{width:22px;height:22px;display:block;flex-shrink:0;}
.logo-word{display:inline-flex;align-items:baseline;gap:0;}

/* ── Navigation ── */
nav{display:flex;align-items:center;gap:28px;}
nav a{font-size:14px;color:var(--text-secondary);text-decoration:none;transition:color 0.2s;}
nav a:hover{color:var(--text-primary);}
.lang-switch{font-family:'DM Mono',monospace;font-size:12px;letter-spacing:2px;color:var(--text-secondary);text-decoration:none;border:1px solid var(--border);border-radius:6px;padding:5px 10px;transition:border-color 0.2s,color 0.2s;}
.lang-switch:hover{border-color:var(--green);color:var(--green);}
.btn-login{font-size:14px;color:var(--text-secondary);text-decoration:none;border:1px solid var(--border);border-radius:8px;padding:8px 16px;transition:border-color 0.2s,color 0.2s;position:relative;z-index:10;}
.btn-login:hover{border-color:var(--green);color:var(--green);}
.nav-avatar{width:34px;height:34px;border-radius:50%;background:var(--green-dim);border:1.5px solid var(--green);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--green);text-decoration:none;font-family:'DM Mono',monospace;cursor:pointer;position:relative;z-index:10;}

/* ── Buttons ── */
.btn-primary{background:var(--green);color:#201a13;padding:10px 20px;border-radius:10px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;transition:all 0.3s;text-decoration:none;display:inline-block;}
.btn-primary:hover{opacity:0.95;transform:translateY(-1px);box-shadow:0 8px 24px var(--green-glow);}
.btn-secondary{background:transparent;color:var(--text-primary);padding:10px 20px;border-radius:10px;border:1px solid var(--border);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;transition:all 0.3s;text-decoration:none;display:inline-block;}
.btn-secondary:hover{border-color:var(--green);background:var(--green-dim);transform:translateY(-2px);}

/* ── Section Labels ── */
.section-label{font-family:'DM Mono',monospace;font-size:12px;color:var(--green);letter-spacing:3px;margin-bottom:16px;text-transform:uppercase;}

/* ── Hero ── */
.hero{text-align:center;padding:120px 0 100px;position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:600px;height:600px;max-width:100vw;background:radial-gradient(circle,var(--green-glow) 0%,transparent 72%);pointer-events:none;}
.hero h1{font-size:60px;font-weight:700;line-height:1.15;margin-bottom:24px;letter-spacing:-1px;}
.hero h1 span{color:var(--green);}
.hero p{font-size:18px;color:var(--text-secondary);max-width:540px;margin:0 auto 48px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:var(--green-dim);border:1px solid rgba(233,187,110,0.35);border-radius:100px;padding:6px 16px;font-size:13px;color:var(--green);font-family:'DM Sans',sans-serif;letter-spacing:0.8px;margin-bottom:32px;}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero-buttons .btn-primary,.hero-buttons .btn-secondary{padding:14px 32px;font-size:15px;}


/* ── Mission ── */
.mission{padding:80px 0;border-top:1px solid var(--border);}
.mission-inner{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.mission-text h2{font-size:38px;font-weight:700;margin-bottom:20px;letter-spacing:-0.5px;line-height:1.2;}
.mission-text p{font-size:16px;color:var(--text-secondary);line-height:1.8;margin-bottom:16px;}
.mission-text p strong{color:var(--text-primary);}
.mission-stats{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden;}
.stat{background:var(--surface);padding:32px;}
.stat-value{font-size:42px;font-weight:700;color:var(--green);font-family:'DM Mono',monospace;line-height:1;margin-bottom:8px;}
.stat-label{font-size:14px;color:var(--text-secondary);}
.stat-label strong{color:var(--green);font-weight:600;}

/* ── Sections ── */
.section{padding:80px 0;border-top:1px solid var(--border);}
.section h2{font-size:42px;font-weight:700;margin-bottom:60px;letter-spacing:-0.5px;}

/* ── Features Grid ── */
.features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);border:1px solid var(--border);border-radius:16px;overflow:hidden;}
.features-grid .feature-card-feature-span{grid-column:1/-1;}
.feature-card{background:var(--surface);padding:36px 32px;transition:background 0.2s;position:relative;}
.feature-card:hover{background:#2b2724;}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--green),transparent);opacity:0;transition:opacity 0.3s;}
.feature-card:hover::before{opacity:1;}
.feature-icon{width:44px;height:44px;background:var(--green-dim);border:1px solid rgba(61,221,132,0.2);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:20px;}
.feature-card h3{font-size:17px;font-weight:600;margin-bottom:10px;}
.feature-card p{font-size:14px;color:var(--text-secondary);line-height:1.6;}

/* ── Pricing ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.pricing-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:36px 28px;transition:border-color 0.2s,transform 0.3s,box-shadow 0.3s;position:relative;}
.pricing-card:hover{border-color:rgba(233,187,110,0.4);transform:translateY(-4px);box-shadow:0 12px 26px rgba(0,0,0,0.2);}
.pricing-card.featured{border-color:var(--green);box-shadow:0 0 24px rgba(233,187,110,0.12);}
.pricing-card.featured:hover{box-shadow:0 12px 34px rgba(233,187,110,0.15);}
.featured-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--green);color:#201a13;font-size:11px;font-weight:700;padding:4px 14px;border-radius:100px;white-space:nowrap;letter-spacing:1px;}
.pricing-card h3{font-family:'DM Mono',monospace;font-size:13px;letter-spacing:3px;color:var(--text-secondary);text-transform:uppercase;margin-bottom:20px;}
.price{font-size:48px;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:6px;}
.price sup{font-size:20px;font-weight:500;vertical-align:super;}
.price-period{font-size:13px;color:var(--text-secondary);margin-bottom:28px;}
.pricing-divider{height:1px;background:var(--border);margin-bottom:24px;}
.feature-list{list-style:none;margin-bottom:32px;}
.feature-list li{font-size:13px;color:var(--text-secondary);padding:8px 0;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);}
.feature-list li:last-child{border-bottom:none;}
.feature-list li.included{color:var(--text-primary);}
.feature-list li.included::before{content:"✓";color:var(--green);font-weight:700;flex-shrink:0;}
.feature-list li.excluded::before{content:"×";color:var(--border);font-weight:700;flex-shrink:0;}

/* ── CTA Section ── */
.cta-section{padding:80px 0;border-top:1px solid var(--border);text-align:center;}
.cta-section h2{font-size:42px;font-weight:700;margin-bottom:16px;letter-spacing:-0.5px;}
.cta-section p{font-size:16px;color:var(--text-secondary);margin-bottom:40px;}

/* ── Social Proof ── */
.social-proof{padding:80px 0;border-top:1px solid var(--border);}
.social-proof h2{font-size:36px;font-weight:700;margin-bottom:48px;text-align:center;letter-spacing:-0.5px;}
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.testimonial-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;transition:border-color 0.2s;}
.testimonial-card:hover{border-color:rgba(233,187,110,0.35);}
.testimonial-text{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-bottom:16px;font-style:italic;}
.testimonial-author{display:flex;align-items:center;gap:10px;}
.testimonial-avatar{width:32px;height:32px;border-radius:50%;background:var(--green-dim);border:1px solid rgba(61,221,132,0.2);display:flex;align-items:center;justify-content:center;font-size:14px;}
.testimonial-name{font-size:13px;font-weight:600;}
.testimonial-role{font-size:12px;color:var(--text-secondary);}

/* ── OpenRouter Page ── */
.or-hero{padding:100px 0 60px;border-bottom:1px solid var(--border);}
.or-hero h1{font-size:52px;font-weight:700;letter-spacing:-1px;line-height:1.15;margin-bottom:20px;}
.or-hero h1 span{color:var(--green);}
.or-hero p{font-size:18px;color:var(--text-secondary);max-width:600px;margin-bottom:36px;}
.or-section{padding:72px 0;border-top:1px solid var(--border);}
.or-section h2{font-size:32px;font-weight:700;margin-bottom:16px;letter-spacing:-0.5px;}
.or-section p{font-size:16px;color:var(--text-secondary);max-width:700px;line-height:1.8;margin-bottom:12px;}
.or-section p strong{color:var(--text-primary);}
.or-analogy{background:var(--surface);border:1px solid var(--border);border-left:3px solid var(--green);border-radius:12px;padding:24px 28px;margin:20px 0;font-size:15px;color:var(--text-secondary);line-height:1.7;}
.or-analogy strong{color:var(--text-primary);}
.info-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:32px;}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;}
.info-card .icon{font-size:28px;margin-bottom:14px;display:block;}
.info-card h3{font-size:16px;font-weight:600;margin-bottom:8px;}
.info-card p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:0;}
.steps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:32px;}
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;display:flex;gap:20px;align-items:flex-start;}
.step-number{width:36px;height:36px;min-width:36px;background:var(--green-dim);border:1px solid rgba(61,221,132,0.25);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:600;color:var(--green);}
.step-content h3{font-size:16px;font-weight:600;margin-bottom:6px;}
.step-content p{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:0;}
.step-content a{color:var(--green);text-decoration:none;}
.or-cta{padding:80px 0;border-top:1px solid var(--border);text-align:center;}
.or-cta h2{font-size:36px;font-weight:700;margin-bottom:14px;letter-spacing:-0.5px;}
.or-cta p{font-size:16px;color:var(--text-secondary);margin-bottom:32px;max-width:500px;margin-left:auto;margin-right:auto;}

/* ── Waitlist ── */
.waitlist-layout{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;padding:72px 0;}
.waitlist-form-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;}
.wl-field{margin-bottom:20px;}
.wl-field label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500;}
.wl-field input{width:100%;padding:12px 16px;background:var(--bg);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:'DM Sans',sans-serif;font-size:15px;outline:none;transition:border-color 0.2s;}
.wl-field input:focus{border-color:var(--green);}
.wl-field input::placeholder{color:var(--text-secondary);}
.wl-plan{margin-bottom:24px;}
.wl-plan>label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:500;}
.wl-plan-options{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.wl-plan-option{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:10px 14px;cursor:pointer;font-size:14px;transition:border-color 0.2s;}
.wl-plan-option:hover{border-color:rgba(61,221,132,0.4);}
.wl-plan-option input{width:auto;min-width:unset;}
.wl-plan-featured{border-color:rgba(61,221,132,0.35)!important;color:var(--green);}
.waitlist-summary{padding-top:4px;}
.wl-tier{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px 24px;margin-bottom:12px;}
.wl-tier-special{border-color:var(--green);background:linear-gradient(135deg,rgba(61,221,132,0.06) 0%,transparent 100%);}
.wl-tier-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.wl-tier-name{font-weight:700;font-size:16px;}
.wl-tier-price{font-family:'DM Mono',monospace;font-size:14px;color:var(--text-secondary);}

/* ── Lifetime Banner ── */
.lifetime-banner{margin-top:32px;background:linear-gradient(135deg,rgba(233,187,110,0.1) 0%,rgba(233,187,110,0.04) 100%);border:1px solid var(--green);border-radius:16px;padding:40px;display:flex;gap:48px;align-items:center;position:relative;overflow:hidden;}
.lifetime-banner::before{content:'';position:absolute;top:-60px;right:-60px;width:240px;height:240px;background:radial-gradient(circle,rgba(233,187,110,0.15) 0%,transparent 70%);pointer-events:none;}
.lifetime-tag{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:2px;color:var(--green);margin-bottom:12px;}
.lifetime-banner-left{flex:1;}
.lifetime-banner-left h3{font-size:28px;font-weight:700;margin-bottom:12px;letter-spacing:-0.5px;}
.lifetime-banner-left h3 span{color:var(--green);}
.lifetime-banner-left>p{font-size:15px;color:var(--text-secondary);line-height:1.7;margin-bottom:20px;max-width:560px;}
.lifetime-perks{list-style:none;display:flex;flex-wrap:wrap;gap:10px 24px;}
.lifetime-perks li{font-size:13px;color:var(--text-primary);}
.lifetime-banner-right{min-width:200px;text-align:center;}
.lifetime-price{font-size:52px;font-weight:700;color:var(--green);font-family:'DM Mono',monospace;line-height:1;margin-bottom:4px;}
.lifetime-price sup{font-size:22px;font-weight:500;vertical-align:super;}
.lifetime-price span{font-size:16px;font-weight:400;color:var(--text-secondary);font-family:'DM Sans',sans-serif;}
.lifetime-saved{font-size:13px;color:var(--text-secondary);margin-bottom:20px;text-decoration:line-through;}

/* ── Model Universe ── */
.model-universe{margin-top:40px;}
.model-universe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px;}
.model-category{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;}
.model-category-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:2px;color:var(--green);text-transform:uppercase;margin-bottom:12px;}
.model-tags{display:flex;flex-wrap:wrap;gap:6px;}
.model-tag{font-family:'DM Mono',monospace;font-size:11px;font-weight:500;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:4px 10px;color:var(--text-primary);letter-spacing:0.5px;transition:border-color 0.2s,color 0.2s;}
.model-tag:hover{border-color:rgba(61,221,132,0.4);color:var(--green);}
.model-universe-footer{margin-top:14px;font-size:13px;color:var(--text-secondary);font-family:'DM Mono',monospace;letter-spacing:1px;}

/* ── Download Section ── */
.download-section{padding:60px 0;border-top:1px solid var(--border);text-align:center;}
.download-section h2{font-size:32px;font-weight:700;margin-bottom:10px;letter-spacing:-0.5px;}
.download-section p{font-size:16px;color:var(--text-secondary);margin-bottom:36px;}
.store-buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}
.store-btn{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 22px;text-decoration:none;color:var(--text-primary);transition:border-color 0.2s,background 0.2s,transform 0.2s;min-width:160px;}
.store-btn:hover{border-color:var(--green);background:#2a2623;transform:translateY(-2px);}
.store-btn-icon{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.store-btn-icon svg{width:26px;height:26px;}
.store-btn-text{text-align:left;}
.store-btn-sub{font-size:10px;color:var(--text-secondary);display:block;line-height:1;}
.store-btn-name{font-size:15px;font-weight:600;display:block;line-height:1.4;}
.store-note{font-size:12px;color:var(--text-secondary);margin-top:16px;font-family:'DM Mono',monospace;letter-spacing:1px;}

/* ── Supported Models ── */
.models-section{padding:60px 0;border-top:1px solid var(--border);}
.models-inner{display:flex;align-items:center;gap:48px;flex-wrap:wrap;}
.models-label{font-family:'DM Mono',monospace;font-size:12px;color:var(--text-secondary);letter-spacing:2px;white-space:nowrap;flex-shrink:0;}
.models-badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.model-badge{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;transition:border-color 0.2s;}
.model-badge:hover{border-color:rgba(233,187,110,0.35);}
.model-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}

/* ── Message Highlight ── */
.msg-highlight{background:var(--green-dim);border:1px solid rgba(233,187,110,0.35);border-radius:10px;padding:12px 16px;margin:12px 0 20px;display:flex;align-items:center;gap:12px;}
.msg-highlight-val{font-family:'DM Mono',monospace;font-size:22px;font-weight:700;color:var(--green);white-space:nowrap;}
.msg-highlight-label{font-size:13px;color:var(--text-secondary);line-height:1.4;}
.msg-highlight-label strong{color:var(--text-primary);}

/* ── FOMO Timer ── */
.fomo-bar{background:linear-gradient(90deg,rgba(233,187,110,0.12),rgba(233,187,110,0.06));border:1px solid rgba(233,187,110,0.3);border-radius:10px;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap;}
.fomo-bar-left{display:flex;align-items:center;gap:10px;font-size:13px;}
.fomo-dot{width:8px;height:8px;border-radius:50%;background:var(--green);animation:pulse 2.6s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.72;transform:scale(1.1);}}
.fomo-timer{display:flex;gap:8px;align-items:center;}
.fomo-unit{text-align:center;}
.fomo-val{font-family:'DM Mono',monospace;font-size:18px;font-weight:700;color:var(--green);display:block;line-height:1;}
.fomo-lab{font-size:10px;color:var(--text-secondary);display:block;margin-top:2px;letter-spacing:1px;}
.fomo-sep{font-family:'DM Mono',monospace;font-size:18px;font-weight:700;color:var(--green);margin-bottom:8px;}
.seats-badge{font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;color:#201a13;background:var(--green);padding:4px 10px;border-radius:8px;white-space:nowrap;}

/* ── Billing Toggle ── */
.billing-toggle-wrap{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:36px;}
.billing-toggle-wrap span{font-size:13px;color:var(--text-secondary);}
.billing-toggle-wrap span.active{color:var(--text-primary);font-weight:600;}
.toggle-pill{position:relative;width:48px;height:26px;background:var(--border);border-radius:100px;cursor:pointer;transition:background 0.25s;flex-shrink:0;}
.toggle-pill.yearly{background:var(--green);}
.toggle-pill::after{content:'';position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform 0.25s;}
.toggle-pill.yearly::after{transform:translateX(22px);}
.toggle-save-badge{font-size:11px;font-weight:700;letter-spacing:.5px;color:#201a13;background:var(--green);padding:3px 9px;border-radius:100px;margin-left:2px;}

/* ── Footer ── */
footer{border-top:1px solid var(--border);padding:32px 0;}
footer .footer-inner{display:flex;flex-direction:column;align-items:center;gap:12px;}
footer .footer-top{display:flex;justify-content:space-between;align-items:center;width:100%;flex-wrap:wrap;gap:12px;}
footer .footer-links{display:flex;gap:20px;flex-wrap:wrap;justify-content:center;}
footer p{font-size:13px;color:var(--text-secondary);}
footer a.footer-link{font-size:13px;color:var(--text-secondary);text-decoration:none;transition:color 0.2s;}
footer a.footer-link:hover{color:var(--green);}

/* ── Legal, AGB & Support (shared layout) ── */
.legal-page-hero,.page-hero{padding:72px 0 48px;border-bottom:1px solid var(--border);position:relative;text-align:left;}
.legal-page-hero::before,.page-hero::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:560px;height:420px;max-width:100vw;background:radial-gradient(circle,rgba(233,187,110,0.15) 0%,transparent 72%);pointer-events:none;z-index:0;}
.legal-page-hero .container,.page-hero .container{position:relative;z-index:1;}
.legal-page-hero h1,.page-hero h1{font-size:44px;font-weight:700;letter-spacing:-1px;line-height:1.12;margin-bottom:14px;}
.legal-page-hero h1 span,.page-hero h1 span{color:var(--green);}
.legal-page-hero .hero-lead,.page-hero > .container > p:last-of-type{font-size:17px;color:var(--text-secondary);max-width:560px;line-height:1.65;margin-top:0;}
.legal-document,.legal-content{padding:56px 0 88px;}
.legal-document-inner,.legal-content > .container{max-width:700px;margin:0 auto;}
.legal-document h2,.legal-content h2{font-size:19px;font-weight:700;color:var(--text-primary);margin:36px 0 14px;letter-spacing:-0.2px;padding-top:28px;border-top:1px solid var(--border);line-height:1.35;}
.legal-document h2:first-child,.legal-content h2:first-of-type{margin-top:0;padding-top:0;border-top:none;}
.legal-document h3,.legal-content h3{font-size:16px;font-weight:600;margin:22px 0 10px;color:var(--text-primary);}
.legal-document p,.legal-document li,.legal-content p,.legal-content li{font-size:15px;color:var(--text-secondary);line-height:1.78;margin-bottom:14px;}
.legal-document ul,.legal-document ol,.legal-content ul,.legal-content ol{padding-left:22px;margin-bottom:18px;}
.legal-document li,.legal-content li{margin-bottom:8px;}
.legal-document a,.legal-content a{color:var(--green);text-decoration:none;border-bottom:1px solid rgba(233,187,110,0.35);transition:color 0.2s,border-color 0.2s;}
.legal-document a:hover,.legal-content a:hover{color:var(--text-primary);border-color:var(--green);}
.legal-card,.legal-box{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px 26px;margin:14px 0 22px;}
.legal-card p:last-child,.legal-box p:last-child{margin-bottom:0;}
.legal-card p,.legal-box p{margin-bottom:10px;}
.legal-card strong,.legal-box strong{color:var(--text-primary);}
.support-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:28px 0 8px;}
.support-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px 26px;transition:border-color 0.2s,box-shadow 0.2s;}
.support-card:hover{border-color:rgba(233,187,110,0.38);box-shadow:0 8px 24px rgba(0,0,0,0.2);}
.support-card h2{font-size:17px;font-weight:600;margin:0 0 10px;padding:0;border:none;}
.support-card p{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.65;}
.support-card a.support-mail{display:inline-flex;margin-top:14px;font-family:'DM Mono',monospace;font-size:13px;font-weight:600;color:var(--green);text-decoration:none;border-bottom:none;}
.support-card a.support-mail:hover{color:var(--text-primary);}
.support-note{font-size:14px;color:var(--text-secondary);line-height:1.7;margin-top:24px;padding:18px 20px;background:var(--surface);border:1px solid var(--border);border-radius:12px;border-left:3px solid var(--green);}

/* ── Hamburger / Mobile Menu ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;}
.hamburger span{display:block;width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-menu{display:none;position:fixed;top:65px;left:0;right:0;background:rgba(24,23,22,0.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:20px 24px;z-index:99;flex-direction:column;gap:4px;}
.mobile-menu.open{display:flex;}
.mobile-menu a{font-size:16px;color:var(--text-secondary);text-decoration:none;padding:12px 0;border-bottom:1px solid var(--border);transition:color 0.2s;min-height:44px;display:flex;align-items:center;}
.mobile-menu a:last-child{border-bottom:none;}
.mobile-menu a:hover{color:var(--green);}
.mobile-menu .btn-primary{margin-top:8px;text-align:center;padding:14px;min-height:auto;}
.mobile-menu .lang-switch{border:none;padding:12px 0;letter-spacing:2px;min-height:auto;}

/* ── Animations ── */
.fade-in{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease,transform 0.7s ease;}
.fade-in.visible{opacity:1;transform:none;}
.hero{animation:heroFloat 8s ease-in-out infinite;transform-style:preserve-3d;}
@keyframes heroFloat{0%,100%{transform:translateY(0);}50%{transform:translateY(-5px);}}
.hero h1{animation:fadeInUp 0.8s ease forwards;opacity:0;}
.hero p{animation:fadeInUp 0.8s ease 0.2s forwards;opacity:0;}
.hero-buttons{animation:fadeInUp 0.8s ease 0.4s forwards;opacity:0;}
.hero-badge{animation:fadeInDown 0.8s ease forwards;opacity:0;}
@keyframes fadeInUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:none;}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-20px);}to{opacity:1;transform:none;}}
.cursor-glow{position:fixed;width:280px;height:280px;background:radial-gradient(circle,var(--green-glow) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0;opacity:0;transition:opacity 0.3s;}

/* ── Grace Screenshot Showcase ── */
.showcase-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.showcase-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:10px;}
.showcase-card img{display:block;width:100%;border-radius:12px;}

/* ── Responsive: Tablet ── */
@media(max-width:900px){.info-cards{grid-template-columns:1fr 1fr;}}

/* ── Responsive: Mobile ── */
@media(max-width:768px){
    .hero{padding:80px 0 60px;animation:none;}
    .hero h1{font-size:36px;letter-spacing:-0.5px;animation:none;opacity:1;}
    .hero p{font-size:16px;animation:none;opacity:1;}
    .hero-buttons{animation:none;opacity:1;}
    .hero-badge{animation:none;opacity:1;}
    .features-grid{grid-template-columns:1fr;}
    .pricing-grid{grid-template-columns:1fr;}
    .steps-grid{grid-template-columns:1fr;}
    .mission-inner{grid-template-columns:1fr;gap:40px;}
    .mission-text h2{font-size:28px;}
    .section h2{font-size:28px;}
    .cta-section h2{font-size:28px;}
    .or-hero h1{font-size:32px;}
    .or-section h2{font-size:26px;}
    .legal-page-hero h1,.page-hero h1{font-size:30px;}
    .waitlist-layout{grid-template-columns:1fr;padding:40px 0;}
    .waitlist-form-box{padding:24px;}
    .wl-plan-options{grid-template-columns:1fr;}
    .info-cards{grid-template-columns:1fr;}
    .testimonial-grid{grid-template-columns:1fr;}
    .showcase-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;gap:12px;padding:0 4px;scrollbar-width:none;}
    .showcase-grid::-webkit-scrollbar{display:none;}
    .showcase-card{min-width:78vw;max-width:320px;flex:none;scroll-snap-align:center;}
    .model-universe-grid{grid-template-columns:1fr;}
    .lifetime-banner{flex-direction:column;gap:32px;padding:28px 20px;}
    .lifetime-price{font-size:42px;}
    footer .footer-top{flex-direction:column;text-align:center;}
    .hamburger{display:flex;}
    nav a:not(.btn-primary):not(.lang-switch):not(.btn-login){display:none;}
    nav .lang-switch{display:none;}
    nav .btn-primary{display:none;}
}

/* ── Responsive: Small Mobile ── */
@media(max-width:600px){
    .store-buttons{flex-direction:column;align-items:center;}
    .store-btn{width:100%;max-width:280px;}
    .models-inner{flex-direction:column;gap:16px;}
    .fomo-bar{flex-direction:column;gap:10px;text-align:center;}
}

/* ═══════════════════════════════════════════════════
   Page-Specific: Login / Profile
   ═══════════════════════════════════════════════════ */

/* ── Login / Auth ── */
.auth-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:60px 24px;position:relative;z-index:1;}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:48px 40px;width:100%;max-width:440px;}
.auth-logo{font-family:'DM Sans',sans-serif;font-size:28px;font-weight:700;text-align:center;margin-bottom:8px;display:flex;align-items:center;justify-content:center;gap:10px;}
.auth-logo span{color:var(--green);}
.auth-logo-mark{width:28px;height:28px;}
.auth-subtitle{text-align:center;color:var(--text-secondary);font-size:15px;margin-bottom:36px;}
.auth-tabs{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:4px;margin-bottom:32px;gap:4px;}
.auth-tab{flex:1;text-align:center;padding:9px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:background 0.2s,color 0.2s;color:var(--text-secondary);border:none;background:none;font-family:'DM Sans',sans-serif;}
.auth-tab.active{background:var(--surface);color:var(--text-primary);box-shadow:0 1px 4px rgba(0,0,0,0.4);}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group label{font-size:13px;color:var(--text-secondary);font-weight:500;}
.form-group input{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px 16px;font-size:15px;color:var(--text-primary);font-family:'DM Sans',sans-serif;transition:border-color 0.2s;outline:none;}
.form-group input:focus{border-color:var(--green);}
.form-group input::placeholder{color:#444;}
.auth-btn{background:var(--green);color:#0A0A0A;padding:14px;border-radius:10px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;transition:opacity 0.2s,transform 0.2s;width:100%;margin-top:4px;}
.auth-btn:hover{opacity:0.85;transform:scale(1.01);}
.auth-btn:disabled{opacity:0.5;cursor:not-allowed;transform:none;}
.form-hint{font-size:12px;color:var(--text-secondary);text-align:center;margin-top:4px;}
.form-hint a{color:var(--green);text-decoration:none;}
.form-divider{display:flex;align-items:center;gap:12px;color:var(--text-secondary);font-size:12px;margin:4px 0;}
.form-divider::before,.form-divider::after{content:'';flex:1;height:1px;background:var(--border);}
.social-coming{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center;font-size:13px;color:var(--text-secondary);}
.msg-error{background:rgba(255,80,80,0.1);border:1px solid rgba(255,80,80,0.3);border-radius:8px;padding:10px 14px;font-size:13px;color:#ff8080;display:none;}
.msg-success{background:var(--green-dim);border:1px solid rgba(61,221,132,0.3);border-radius:8px;padding:10px 14px;font-size:13px;color:var(--green);display:none;}
#panelLogin{display:flex;flex-direction:column;gap:16px;}
#panelSignup{display:none;flex-direction:column;gap:16px;}
.auth-card footer{border-top:none;padding:0;margin-top:24px;}
.auth-card .footer-inner{display:flex;flex-direction:column;align-items:center;gap:16px;text-align:center;}
.auth-card .footer-inner p{font-size:13px;color:var(--text-secondary);}
.auth-card .footer-links{display:flex;gap:20px;}
.auth-card .footer-link:hover{color:var(--text-primary);}
