:root{--primary:#8b5cf6;--primary-dark:#7c3aed;--primary-light:#a78bfa;--secondary:#06b6d4;--accent:#f472b6;--accent-light:#f9a8d4;--bg-dark:#0a0a12;--bg-surface:#12121c;--bg-card:rgba(25,22,35,0.95);--bg-card-hover:rgba(35,30,50,0.95);--bg-input:rgba(40,35,55,0.8);--text:#f5f0f8;--text-muted:rgba(245,240,248,0.6);--text-dim:rgba(245,240,248,0.55);--border:rgba(139,92,246,0.15);--border-hover:rgba(139,92,246,0.35);--glow:rgba(139,92,246,0.3);--glow-accent:rgba(244,114,182,0.3);--green:#4ade80;--success:#4ade80;--orange:#f97316;--red:#ef4444;--cyan:#00d4ff;--surface:#12121c;--surface-darker:#0d0d14;--bg:rgba(40,35,55,0.8);--nav-height:70px;--container-max:1200px;--container-narrow:800px;--transition-fast:.15s ease;--transition:.3s ease;--transition-slow:.5s ease}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,0.25) transparent}html{scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:rgba(139,92,246,0.3) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:rgba(139,92,246,0.25);border-radius:3px}*::-webkit-scrollbar-thumb:hover{background:rgba(139,92,246,0.5)}*::-webkit-scrollbar-corner{background:transparent}body{font-family:'Nunito',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:var(--bg-dark);color:var(--text);line-height:1.6;overflow-x:hidden;min-height:100vh;min-height:100dvh;overflow-anchor:auto;-webkit-tap-highlight-color:transparent}.bg-gradient{position:fixed;top:0;left:0;right:0;bottom:0;z-index:0;background:radial-gradient(ellipse at 20% 0,rgba(139,92,246,0.15) 0,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(6,182,212,0.1) 0,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(244,114,182,0.05) 0,transparent 40%),var(--bg-dark);pointer-events:none}.particles{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1;overflow:hidden}.particle{position:absolute;width:4px;height:4px;background:var(--primary-light);border-radius:50%;opacity:.3;animation:float 15s infinite}@keyframes float{0%,100%{transform:translateY(100vh) rotate(0);opacity:0}10%{opacity:.3}90%{opacity:.3}100%{transform:translateY(-100vh) rotate(720deg);opacity:0}}h1,h2,h3,h4,h5,h6{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.2}h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.5rem,4vw,2.5rem)}h3{font-size:clamp(1.25rem,3vw,1.75rem)}.gradient-text{background:linear-gradient(135deg,var(--primary-light),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}a{color:var(--primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent)}.container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem;position:relative;z-index:10}.container-narrow{max-width:var(--container-narrow)}section{padding:5rem 0}.nav{position:fixed;top:0;left:0;right:0;height:var(--nav-height);background:rgba(10,10,18,0.9);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:1000;display:flex;align-items:center}.nav-container{max-width:var(--container-max);margin:0 auto;padding:0 1.5rem;width:100%;display:flex;align-items:center;justify-content:space-between}.nav-logo{display:flex;align-items:center;gap:.75rem;font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:600;color:var(--text);text-decoration:none}.nav-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--primary),var(--accent));border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem}.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;margin:0;padding:0}.nav-links>li{margin:0;padding:0}.nav-link{color:var(--text-muted);font-weight:500;font-size:.95rem;transition:color var(--transition-fast);position:relative}.nav-link:hover{color:var(--text)}.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--primary);transition:width var(--transition)}.nav-link:hover::after{width:100%}.nav-actions{display:flex;align-items:center;gap:1rem}.nav-mobile-toggle{display:none;background:0;border:0;color:var(--text);font-size:1.5rem;cursor:pointer}.nav-mobile-auth{display:none}.nav-mobile-divider{display:none}@media(max-width:768px){.nav-links{position:fixed;top:var(--nav-height);left:0;right:0;background:var(--bg-surface);flex-direction:column;align-items:flex-start;padding:1.5rem 2rem;gap:1.25rem;transform:translateY(-100%);opacity:0;transition:all var(--transition);pointer-events:none;z-index:999;border-bottom:1px solid var(--border)}.nav-links.active{transform:translateY(0);opacity:1;pointer-events:auto}.nav-mobile-toggle{display:block}.nav-actions{display:none}.nav-desktop-only{display:none}.nav-mobile-auth{display:block}.nav-mobile-auth .nav-link-cta{display:inline-block;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:white !important;padding:.6rem 1.25rem;border-radius:10px;font-weight:600}.nav-mobile-divider{display:block;width:100%;height:0;border:0;border-top:1px solid var(--border);margin:0;padding:0 !important;list-style:none}.nav-mobile-auth .ih-menu-icon{display:inline-block;width:1.5rem;text-align:center;margin-right:.25rem}.nav-mobile-auth .nav-link-logout{color:#f87171}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;transition:all var(--transition);border:0;text-decoration:none}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:white;box-shadow:0 4px 20px var(--glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 30px var(--glow);color:white}.btn-secondary{background:rgba(255,255,255,0.05);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:rgba(255,255,255,0.1);border-color:var(--border-hover);color:var(--text)}.btn-outline{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-outline:hover{background:rgba(255,255,255,0.08);border-color:var(--primary);color:var(--text)}.btn-accent{background:linear-gradient(135deg,#ec4899,#db2777);color:white;box-shadow:0 4px 20px rgba(236,72,153,0.3)}.btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(236,72,153,0.45);color:white}.btn-emerald{background:linear-gradient(135deg,#34d399,#059669);color:white;box-shadow:0 4px 20px rgba(52,211,153,0.3)}.btn-emerald:hover{transform:translateY(-2px);box-shadow:0 6px 30px rgba(52,211,153,0.45);color:white}.btn-lg{padding:1rem 2rem;font-size:1.1rem}.btn-sm{padding:.5rem 1rem;font-size:.85rem}.btn-icon{width:40px;height:40px;padding:0;border-radius:10px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2rem;backdrop-filter:blur(10px);transition:all var(--transition)}.card:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-4px)}.card-glow{box-shadow:0 8px 40px var(--glow)}.hero{min-height:calc(100vh - var(--nav-height));min-height:calc(100dvh - var(--nav-height));display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:calc(var(--nav-height) + 4rem) 1.5rem 2rem;position:relative;z-index:10}.hero-fade{opacity:0;transform:translateY(25px)}.hero-animate .hero-fade{animation:heroFadeIn .7s ease forwards;animation-delay:var(--delay,0s)}@keyframes heroFadeIn{from{opacity:0;transform:translateY(25px)}to{opacity:var(--final-opacity,1);transform:translateY(0)}}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:rgba(139,92,246,0.15);border:1px solid var(--border);border-radius:100px;color:var(--primary-light);font-size:.85rem;font-weight:600;margin-bottom:1.5rem}.hero-title{max-width:800px;margin-bottom:1.5rem}.hero-subtitle{max-width:600px;color:var(--text-muted);font-size:1.1rem;margin-bottom:2.5rem}.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}.hero-visual{margin-top:4rem;max-width:100%}.social-proof-bar{width:100%;max-width:var(--container-max);margin-top:3.5rem;padding-top:2rem;border-top:1px solid var(--border)}.social-proof-stats{display:flex;align-items:center;justify-content:center;gap:2.5rem;flex-wrap:wrap}.proof-stat{text-align:center}.proof-number{display:block;font-family:'Playfair Display',Georgia,serif;font-size:2.25rem;font-weight:700;background:linear-gradient(135deg,#c4b5fd,var(--accent-light));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1.2;filter:drop-shadow(0 0 12px rgba(139,92,246,0.3))}.proof-label{display:block;color:var(--text-muted);font-size:.85rem;margin-top:.25rem}.proof-divider{width:1px;height:36px;background:var(--border)}.proof-freshness{text-align:center;color:var(--text-dim);font-size:.75rem;margin-top:1rem;letter-spacing:.02em}@media(max-width:600px){.social-proof-stats{gap:1.5rem}.proof-number{font-size:1.5rem}.proof-label{font-size:.78rem}.proof-divider{display:none}}.ih-proof-toast{position:fixed;bottom:1.5rem;left:1.5rem;z-index:9000;display:flex;align-items:center;gap:.75rem;max-width:320px;padding:.75rem 1rem;background:rgba(25,22,35,0.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(139,92,246,0.2);border-radius:14px;box-shadow:0 8px 32px rgba(0,0,0,0.4),0 0 0 1px rgba(139,92,246,0.05) inset;cursor:pointer;opacity:0;transform:translateY(16px) translateX(-8px);transition:opacity .4s ease,transform .4s ease;pointer-events:none}.ih-proof-toast.show{opacity:1;transform:translateY(0) translateX(0);pointer-events:auto}.ih-proof-toast-icon{font-size:1.1rem;flex-shrink:0}.ih-proof-toast-body{display:flex;flex-direction:column;min-width:0}.ih-proof-toast-msg{font-size:.85rem;color:var(--text);font-weight:500;line-height:1.3}.ih-proof-toast-time{font-size:.72rem;color:var(--text-dim);margin-top:.15rem}@media(max-width:480px){.ih-proof-toast{left:50%;transform:translateY(16px) translateX(-50%);max-width:260px;padding:.6rem .85rem;bottom:1rem;gap:.5rem}.ih-proof-toast.show{transform:translateY(0) translateX(-50%)}.ih-proof-toast-msg{font-size:.78rem}.ih-proof-toast-icon{font-size:.95rem}.ih-proof-toast-time{font-size:.68rem}}.footer-community-count{color:var(--text-muted);font-size:.9rem;margin-top:.5rem}.footer-community-count:empty{display:none}@media(prefers-reduced-motion:reduce){.ih-proof-toast{transition:none}}.features{padding:6rem 0}.features-header{text-align:center;margin-bottom:4rem}.features-header p{color:var(--text-muted);max-width:720px;margin:1rem auto 0}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.feature-card{padding:2rem;text-align:left}.feature-icon{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.75rem;margin-bottom:1.25rem;background:linear-gradient(135deg,var(--primary),var(--accent))}.feature-card h3{margin-bottom:.75rem;font-family:'Nunito',sans-serif;font-weight:700}.feature-card p{color:var(--text-muted);font-size:.95rem}.roles{padding:6rem 0;background:var(--bg-surface)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:3rem}.roles-grid.roles-grid-3x3{grid-template-columns:repeat(3,1fr);gap:1.25rem;max-width:1000px;margin-left:auto;margin-right:auto}@media(max-width:900px){.roles-grid.roles-grid-3x3{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.roles-grid.roles-grid-3x3{grid-template-columns:1fr}}.role-card{position:relative;overflow:hidden;display:flex;flex-direction:column}.role-card.adult{border-color:rgba(244,114,182,0.3)}.role-badge{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;border-radius:100px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.role-badge.free{background:rgba(74,222,128,0.2);color:var(--green)}.role-badge.platonic{background:rgba(74,222,128,0.2);color:var(--green)}.role-badge.romantic{background:rgba(139,92,246,0.2);color:var(--primary-light)}.role-badge.starter{background:rgba(139,92,246,0.2);color:var(--primary-light)}.role-badge.adult{background:rgba(244,114,182,0.2);color:var(--accent)}.role-badge.unlimited{background:rgba(52,211,153,0.2);color:#34d399}.role-badge.growth{background:rgba(251,191,36,0.2);color:#fbbf24}.role-icon{font-size:2.5rem;margin-bottom:1rem}.role-card h3{font-family:'Nunito',sans-serif;font-weight:700;margin-bottom:.5rem}.role-card p{color:var(--text-muted);font-size:.9rem;flex-grow:1}.preview-teaser{display:inline-block;align-self:flex-start;margin-top:.75rem;padding:.2rem .7rem;font-size:.75rem;font-weight:600;color:var(--accent);background:rgba(244,114,182,0.12);border:1px solid rgba(244,114,182,0.25);border-radius:100px;letter-spacing:.02em}.free-teaser{display:inline-block;align-self:flex-start;margin-top:.75rem;padding:.2rem .7rem;font-size:.75rem;font-weight:600;color:#67e8f9;background:rgba(103,232,249,0.10);border:1px solid rgba(103,232,249,0.22);border-radius:100px;letter-spacing:.02em}.pricing{padding:6rem 0}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.free-tier-section{padding:3rem 0 6rem}.pricing-grid-free{max-width:380px;margin:1.5rem auto 0}.pricing-card{position:relative;text-align:center}.pricing-card.outlined{border-color:rgba(139,92,246,0.45);box-shadow:0 0 40px rgba(139,92,246,0.15),0 0 100px rgba(124,58,237,0.06)}.pricing-card.featured{border-color:rgba(236,72,153,0.45);box-shadow:0 0 40px rgba(236,72,153,0.2),0 0 100px rgba(219,39,119,0.08)}.pricing-card.elevated{border-color:rgba(52,211,153,0.45);box-shadow:0 0 50px rgba(52,211,153,0.2),0 0 100px rgba(16,185,129,0.08)}.pricing-popular,.pricing-badge-adult,.pricing-badge-unlimited{position:absolute;top:-12px;left:50%;transform:translateX(-50%);padding:.35rem 1rem;border-radius:100px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.pricing-popular{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.pricing-badge-adult{background:linear-gradient(135deg,#ec4899,#db2777)}.pricing-badge-unlimited{background:linear-gradient(135deg,#10b981,#059669)}.pricing-name{font-family:'Nunito',sans-serif;font-weight:700;font-size:1.25rem;margin-bottom:.5rem}.pricing-price{font-size:3rem;font-weight:800;margin-bottom:.5rem;transition:opacity .2s ease}.pricing-price span{font-size:1rem;font-weight:400;color:var(--text-muted)}.pricing-desc{color:var(--text-muted);font-size:.9rem;margin-bottom:1.5rem}.pricing-features{list-style:none;text-align:left;margin-bottom:2rem}.pricing-features li{padding:.5rem 0;display:flex;align-items:center;gap:.75rem;font-size:.9rem}.pricing-features li::before{content:'✓';color:var(--green);font-weight:700}.pricing .features-header{margin-bottom:0rem}.billing-toggle{display:flex;justify-content:center;margin-top:1.25rem;margin-bottom:1.75rem}.billing-option{padding:.6rem 1.5rem;border:1px solid rgba(139,92,246,0.3);background:transparent;color:var(--text-muted);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .25s ease}.billing-option:first-child{border-radius:100px 0 0 100px;border-right:0}.billing-option:last-child{border-radius:0 100px 100px 0}.billing-option:hover:not(.active){background:rgba(139,92,246,0.1);border-color:rgba(139,92,246,0.5);color:var(--text)}.billing-option.active{background:var(--primary);border-color:var(--primary);color:#fff}.billing-save{display:inline-block;margin-left:.4rem;padding:.15rem .5rem;background:rgba(74,222,128,0.15);color:var(--green);font-size:.7rem;font-weight:700;border-radius:100px;text-transform:uppercase;letter-spacing:.02em;vertical-align:middle}.pricing-billed{display:none;font-size:.8rem;color:var(--text-muted);margin-bottom:.25rem}.cta{padding:6rem 0;text-align:center}.cta-card{background:linear-gradient(135deg,rgba(139,92,246,0.2),rgba(244,114,182,0.1));border-color:rgba(139,92,246,0.3);padding:4rem}.cta h2{margin-bottom:1rem}.cta p{color:var(--text-muted);max-width:500px;margin:0 auto 2rem}.footer{background:var(--bg-surface);border-top:1px solid var(--border);padding:4rem 0 2rem}.footer-grid{display:grid;grid-template-columns:2fr repeat(3,1fr);gap:3rem;margin-bottom:3rem}.footer-brand p{color:var(--text-muted);font-size:.9rem;margin-top:1rem;max-width:300px}.footer-column h4{font-family:'Nunito',sans-serif;font-weight:700;font-size:.9rem;margin-bottom:1rem;color:var(--text)}.footer-links{list-style:none}.footer-links li{margin-bottom:.5rem}.footer-links a{color:var(--text-muted);font-size:.9rem}.footer-links a:hover{color:var(--primary-light)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--text-muted)}.footer-socials{display:flex;gap:1rem}.footer-socials a{color:var(--text-muted);font-size:1.25rem}.footer-socials a:hover{color:var(--primary-light)}@media(max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.footer-brand{grid-column:span 2}.footer-bottom{flex-direction:column;gap:1rem;text-align:center}}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-weight:600;margin-bottom:.5rem;font-size:.9rem}.form-input{width:100%;padding:.75rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:12px;color:var(--text);font-family:inherit;font-size:.95rem;transition:all var(--transition-fast)}.form-input:focus:not(:focus-visible){outline:0}.form-input:focus-visible{outline:2px solid currentColor;outline-offset:2px}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--glow)}.form-input::placeholder{color:var(--text-dim)}.form-hint{font-size:.8rem;color:var(--text-muted);margin-top:.35rem}.ih-select{position:relative;display:inline-flex;min-width:0}.ih-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;padding:.65rem 1rem;background:var(--bg-input);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:inherit;font-size:.92rem;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);text-align:left;white-space:nowrap;overflow:hidden}.ih-select-trigger:hover{border-color:var(--border-hover)}.ih-select-trigger:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}.ih-select.open .ih-select-trigger{border-color:var(--primary);box-shadow:0 0 0 3px rgba(139,92,246,0.12)}.ih-select-label{overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.ih-select-arrow{display:flex;align-items:center;flex-shrink:0;transition:transform .2s ease;opacity:.5;font-size:.65rem;margin-left:auto}.ih-select.open .ih-select-arrow{transform:rotate(180deg);opacity:.8}.ih-select-dropdown{position:fixed;z-index:9999;background:rgba(18,18,30,0.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(139,92,246,0.2);border-radius:10px;padding:4px;box-shadow:0 8px 32px rgba(0,0,0,0.5),0 0 0 1px rgba(139,92,246,0.06) inset;overflow-y:auto;overflow-x:hidden;max-height:420px;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity .15s ease,transform .15s ease,visibility .15s;overscroll-behavior:contain}.ih-select-dropdown.open{opacity:1;visibility:visible;transform:translateY(0)}.ih-select-dropdown.above{transform:translateY(4px)}.ih-select-dropdown.above.open{transform:translateY(0)}.ih-select-group{padding:.5rem .75rem .25rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary-light);pointer-events:none;user-select:none}.ih-select-group:not(:first-child){margin-top:.25rem;border-top:1px solid rgba(139,92,246,0.1);padding-top:.5rem}.ih-select-option{padding:.5rem .75rem;border-radius:6px;cursor:pointer;font-size:.9rem;color:var(--text);transition:background .1s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ih-select-option:hover,.ih-select-option.focused{background:rgba(139,92,246,0.15)}.ih-select-option.selected{background:rgba(139,92,246,0.22);color:var(--primary-light);font-weight:500}.ih-select-option.selected:hover,.ih-select-option.selected.focused{background:rgba(139,92,246,0.3)}.ih-select--sm .ih-select-trigger{padding:.4rem .7rem;font-size:.82rem;border-radius:8px}.ih-select--xs .ih-select-trigger{padding:.3rem .55rem;font-size:.75rem;border-radius:6px;gap:.35rem}.ih-select--xs .ih-select-option,.ih-select--sm .ih-select-option{padding:.4rem .65rem;font-size:.82rem}.ih-select--xs .ih-select-group,.ih-select--sm .ih-select-group{padding:.4rem .65rem .2rem;font-size:.65rem}.form-group .ih-select,.wizard-input-group .ih-select,.filter-group .ih-select{width:100%}.form-group .ih-select .ih-select-trigger,.wizard-input-group .ih-select .ih-select-trigger{padding:.75rem 1rem;border-radius:12px;font-size:.95rem}.form-error{font-size:.8rem;color:var(--red);margin-top:.35rem}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:100%;max-width:440px;padding:2.5rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;margin-bottom:.5rem}.auth-header p{color:var(--text-muted)}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--text-muted);font-size:.85rem}.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.9rem;color:var(--text-muted)}.text-center{text-align:center}.text-left{text-align:left}.text-muted{color:var(--text-muted)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.hidden{display:none !important}@keyframes fadeIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-pulse{animation:pulse 2s infinite}.reveal{opacity:0;transform:translateY(30px);transition:all .6s ease}.reveal.visible{opacity:1;transform:translateY(0)}.role-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);backdrop-filter:blur(4px);z-index:2000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:all .3s ease}.role-modal-overlay.active{opacity:1;visibility:visible}.role-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:2.5rem;max-width:640px;width:90%;max-height:90vh;max-height:90dvh;overflow-y:auto;overscroll-behavior:contain;position:relative;transform:translateY(20px) scale(0.97);transition:transform .3s ease}.role-modal-overlay.active .role-modal{transform:translateY(0) scale(1)}.role-modal-close{position:absolute;top:1rem;right:1.25rem;background:0;border:0;color:var(--text-muted);font-size:1.8rem;cursor:pointer;line-height:1;transition:color .2s}.role-modal-close:hover{color:var(--text)}.role-modal-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.role-modal-icon{font-size:2.5rem}.role-modal-header h2{font-family:'Playfair Display',serif;font-size:1.6rem;margin:0;color:var(--text)}.role-modal-badge{display:inline-block;padding:.15rem .6rem;border-radius:100px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem}.role-modal-badge.free,.role-modal-badge.platonic{background:rgba(74,222,128,0.2);color:var(--green)}.role-modal-badge.starter,.role-modal-badge.romantic{background:rgba(139,92,246,0.2);color:var(--primary-light)}.role-modal-badge.growth{background:rgba(251,191,36,0.2);color:#fbbf24}.role-modal-badge.adult{background:rgba(244,114,182,0.2);color:var(--accent)}.role-modal-badge.unlimited{background:rgba(52,211,153,0.2);color:#34d399}.role-modal-preview-badge{display:inline-block;padding:.15rem .6rem;border-radius:100px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-top:.25rem;margin-left:.4rem;background:rgba(236,72,153,0.25);color:#f472b6;border:1px solid rgba(236,72,153,0.3)}.role-modal-description{color:var(--text-muted);font-size:.95rem;line-height:1.6;margin-bottom:1.5rem}.role-modal-characters{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}.role-modal-character{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:1.25rem;text-align:center;transition:border-color .2s}.role-modal-character:hover{border-color:var(--primary)}.character-emoji{font-size:2rem;margin-bottom:.75rem;display:flex;align-items:center;justify-content:center}.character-emoji img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:2px solid rgba(168,85,247,0.4);box-shadow:0 0 16px rgba(168,85,247,0.15);transition:transform .25s ease,box-shadow .25s ease}.role-modal-character:hover .character-emoji img{transform:scale(1.05);box-shadow:0 0 24px rgba(168,85,247,0.3)}.role-modal-character h4{font-family:'Nunito',sans-serif;font-weight:700;font-size:1.05rem;color:var(--text);margin:0 0 .4rem 0}.role-modal-character p{color:var(--text-muted);font-size:.82rem;line-height:1.5;margin:0}.role-modal-cta{text-align:center}.role-modal-cta .btn{min-width:200px}@media(max-width:500px){.role-modal{padding:1.5rem}.role-modal-characters{grid-template-columns:1fr}.role-modal-header h2{font-size:1.3rem}}.age-verify-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.75);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease;padding:1.5rem}.age-verify-overlay.active{opacity:1;visibility:visible}.age-verify-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:2.5rem;max-width:450px;width:100%;position:relative;transform:translateY(20px) scale(0.96);transition:transform .3s ease;text-align:center}.age-verify-overlay.active .age-verify-modal{transform:translateY(0) scale(1)}.age-verify-close{position:absolute;top:1rem;right:1.25rem;background:0;border:0;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:color .2s;line-height:1}.age-verify-close:hover{color:var(--text)}.age-verify-icon{font-size:2.5rem;margin-bottom:.75rem}.age-verify-title{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--text);margin:0 0 1.25rem 0;line-height:1.4}.age-verify-body{text-align:left;margin-bottom:1.75rem}.age-verify-body p{color:var(--text-muted);font-size:.95rem;margin:0 0 .75rem 0;line-height:1.5}.age-verify-list{list-style:none;padding:0;margin:0}.age-verify-list li{color:var(--text-muted);font-size:.9rem;line-height:1.6;padding-left:1.5rem;position:relative;margin-bottom:.35rem}.age-verify-list li::before{content:'✓';position:absolute;left:0;color:var(--green,#4ade80);font-weight:700}.age-verify-actions{display:flex;flex-direction:column}@media(max-width:500px){.age-verify-modal{padding:1.75rem}.age-verify-title{font-size:1.15rem}}.skip-link{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;text-decoration:none}.skip-link:focus-visible{position:fixed;top:0;left:0;width:auto;height:auto;padding:12px 24px;margin:0;overflow:visible;clip:auto;white-space:normal;background:var(--accent,#a855f7);color:#fff;font-weight:600;font-size:.9rem;z-index:10000;border-radius:0 0 6px 0;outline:2px solid #fff;outline-offset:-2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.ih-refresh-section{margin:.75rem 0 1.25rem;padding:1rem 1.25rem;background:var(--bg-input,rgba(40,35,55,0.8));border:1px solid var(--border,rgba(139,92,246,0.15));border-radius:14px;text-align:center;transition:all .3s ease}.ih-refresh-section.glow{border-color:rgba(251,191,36,0.5);box-shadow:0 0 20px rgba(251,191,36,0.12),0 0 40px rgba(251,191,36,0.06);animation:refreshPulse 2.5s ease-in-out infinite}.ih-refresh-section.depleted{border-color:rgba(239,68,68,0.4);background:linear-gradient(135deg,rgba(239,68,68,0.08),rgba(249,115,22,0.06));box-shadow:0 0 24px rgba(239,68,68,0.12);animation:refreshPulse 2s ease-in-out infinite}@keyframes refreshPulse{0%,100%{box-shadow:0 0 20px rgba(251,191,36,0.1)}50%{box-shadow:0 0 30px rgba(251,191,36,0.2),0 0 60px rgba(251,191,36,0.08)}}.ih-refresh-icon{display:none}.ih-refresh-title{font-weight:700;font-size:.95rem;color:var(--text,#f5f0f8);margin-bottom:.25rem}.ih-refresh-desc{font-size:.82rem;color:var(--text-muted,rgba(245,240,248,0.6));margin-bottom:.75rem;line-height:1.4}.ih-refresh-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.75rem;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#1a1520;font-weight:700;font-size:.9rem;border:0;border-radius:12px;cursor:pointer;font-family:inherit;transition:all .2s ease}.ih-refresh-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(251,191,36,0.35)}.ih-refresh-btn:active{transform:translateY(0)}.ih-refresh-used{font-size:.78rem;color:var(--text-dim,rgba(245,240,248,0.4));margin-top:.5rem}.refill-refresh-link{cursor:pointer;color:#fbbf24;font-weight:600;margin-left:.5rem;transition:color .2s}.refill-refresh-link:hover{color:#f59e0b;text-decoration:underline}@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important;scroll-behavior:auto !important}}