/* Heart2.eu Premium Redesign v2.0 */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');
:root{--rose:#E8426A;--rose-2:#C8315A;--rose-3:#A01F45;--rose-light:#FFF0F3;--rose-mid:#FDDDE5;--gold:#F0C060;--gold-2:#D4A030;--dark:#0F0810;--dark-2:#1A0F18;--cream:#FDF8F9;--cream-2:#F9F0F3;--charcoal:#1A0F18;--mid-gray:#8A7080;--light-gray:#C8B0BC;--white:#FFFFFF;--success:#22C55E;--success-bg:#F0FDF4;--danger:#EF4444;--danger-bg:#FEF2F2;--warn:#F59E0B;--warn-bg:#FFFBEB;--shadow-sm:0 2px 12px rgba(232,66,106,0.08);--shadow-md:0 8px 32px rgba(232,66,106,0.15);--shadow-lg:0 20px 60px rgba(232,66,106,0.20);--shadow-dark:0 8px 32px rgba(0,0,0,0.3);--radius-sm:8px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:999px;--transition:0.25s cubic-bezier(0.4,0,0.2,1);--font-main:'DM Sans',system-ui,sans-serif;--font-serif:'Playfair Display',Georgia,serif;--nav-h:68px}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-main);background:var(--cream);color:var(--charcoal);line-height:1.6;min-height:100vh}
img{max-width:100%;display:block}
a{color:var(--rose);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--rose-2)}
input,select,textarea,button{font-family:var(--font-main)}
.container{max-width:1180px;margin:0 auto;padding:0 24px}

/* NAVBAR */
.navbar{position:sticky;top:0;z-index:1000;height:var(--nav-h);background:rgba(253,248,249,0.93);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(232,66,106,0.10);box-shadow:0 1px 20px rgba(232,66,106,0.06)}
.nav-inner{display:flex;align-items:center;height:var(--nav-h);gap:28px}
.nav-logo{display:flex;align-items:center;gap:8px;font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--charcoal);text-decoration:none;flex-shrink:0}
.logo-heart{width:34px;height:34px;background:var(--rose);border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:16px;box-shadow:0 4px 12px rgba(232,66,106,0.4)}
.logo-text strong{color:var(--rose)}
.nav-center{display:flex;gap:4px;margin:0 auto}
.nav-link{padding:8px 18px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--mid-gray);transition:all var(--transition)}
.nav-link:hover,.nav-link.active{background:var(--rose-light);color:var(--rose-2)}
.nav-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.nav-icon-btn{position:relative;font-size:18px;padding:8px;border-radius:var(--radius-sm);color:var(--mid-gray);transition:all var(--transition)}
.nav-icon-btn:hover{background:var(--rose-light);color:var(--rose)}
.nav-avatar{width:38px;height:38px;border-radius:50%;overflow:hidden;border:2.5px solid var(--rose)}
.nav-avatar img{width:100%;height:100%;object-fit:cover}
.av-initials{width:38px;height:38px;border-radius:50%;background:var(--rose);color:white;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.badge{position:absolute;top:0;right:0;background:var(--rose);color:white;border-radius:50%;width:17px;height:17px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid white}
.lang-switcher{display:flex;gap:2px}
.lang-btn{padding:4px 8px;border-radius:var(--radius-sm);font-size:13px;color:var(--mid-gray);border:1px solid transparent;transition:all var(--transition)}
.lang-btn:hover,.lang-btn.active{background:var(--rose-light);border-color:var(--rose-mid);color:var(--rose-2)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.hamburger span{width:22px;height:2px;background:var(--charcoal);display:block;border-radius:2px;transition:all var(--transition)}
.mobile-menu{display:none;flex-direction:column;background:white;border-bottom:1px solid var(--rose-mid);padding:12px 24px}
.mobile-menu a{padding:12px 0;font-size:15px;font-weight:500;border-bottom:1px solid var(--cream-2);color:var(--charcoal)}
.mobile-menu.open{display:flex}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:11px 26px;border-radius:var(--radius-full);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);border:2px solid transparent;text-decoration:none;white-space:nowrap;letter-spacing:0.01em}
.btn-primary{background:var(--rose);color:white;border-color:var(--rose);box-shadow:0 4px 16px rgba(232,66,106,0.35)}
.btn-primary:hover{background:var(--rose-2);border-color:var(--rose-2);transform:translateY(-1px);box-shadow:0 6px 20px rgba(232,66,106,0.45);color:white}
.btn-secondary{background:white;color:var(--rose);border-color:var(--rose)}
.btn-secondary:hover{background:var(--rose-light)}
.btn-outline{background:transparent;color:var(--mid-gray);border-color:var(--light-gray)}
.btn-outline:hover{border-color:var(--rose);color:var(--rose);background:var(--rose-light)}
.btn-liked{background:var(--rose-light);color:var(--rose-2);border-color:var(--rose)}
.btn-hero-primary{background:var(--rose);color:white;padding:15px 36px;font-size:16px;border-radius:var(--radius-full);box-shadow:0 6px 28px rgba(232,66,106,0.45);border:none;letter-spacing:0.02em;font-weight:700}
.btn-hero-primary:hover{background:var(--rose-2);transform:translateY(-2px);box-shadow:0 10px 36px rgba(232,66,106,0.55);color:white}
.btn-hero-outline{background:rgba(255,255,255,0.12);color:white;border:2px solid rgba(255,255,255,0.5);padding:15px 36px;font-size:16px;border-radius:var(--radius-full);backdrop-filter:blur(8px);font-weight:600}
.btn-hero-outline:hover{background:rgba(255,255,255,0.22);border-color:white;color:white}
.btn-primary-sm{padding:7px 18px;font-size:12px;border-radius:var(--radius-full);background:var(--rose);color:white;border:none;cursor:pointer;font-weight:600;box-shadow:0 2px 10px rgba(232,66,106,0.3)}
.btn-outline-sm{padding:6px 14px;font-size:12px;border-radius:var(--radius-full);background:white;color:var(--mid-gray);border:1.5px solid var(--light-gray);cursor:pointer;font-weight:500;transition:all var(--transition)}
.btn-outline-sm:hover{border-color:var(--rose);color:var(--rose)}
.btn-danger-sm{padding:5px 12px;font-size:12px;border-radius:var(--radius-full);background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,0.3);cursor:pointer}
.btn-block{width:100%;display:block}
.btn-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:white;border:1.5px solid var(--light-gray);cursor:pointer;font-size:16px;transition:all var(--transition)}
.btn-icon:hover{border-color:var(--rose);background:var(--rose-light)}

/* FORMS */
.form-group{margin-bottom:18px}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--charcoal);margin-bottom:6px;letter-spacing:0.01em}
.form-control{width:100%;padding:11px 16px;border-radius:var(--radius-md);border:2px solid #EDD8E0;font-size:14px;color:var(--charcoal);background:white;outline:none;transition:all var(--transition)}
.form-control:focus{border-color:var(--rose);box-shadow:0 0 0 4px rgba(232,66,106,0.08)}
.form-control:hover{border-color:#D4A0B0}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-row-sb{display:flex;justify-content:space-between;align-items:center}
.check-item{display:flex;align-items:center;gap:9px;font-size:14px;cursor:pointer}
.check-item input{width:17px;height:17px;accent-color:var(--rose)}
.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}
.radio-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:8px}
.radio-card{display:flex;align-items:center;gap:8px;padding:11px 14px;border-radius:var(--radius-md);border:2px solid #EDD8E0;cursor:pointer;font-size:13px;transition:all var(--transition)}
.radio-card:has(input:checked){border-color:var(--rose);background:var(--rose-light);color:var(--rose-2)}
.radio-card input{accent-color:var(--rose)}
.age-range-row{display:flex;align-items:center;gap:10px}
.age-range-row span{color:var(--mid-gray);font-size:14px}
.interests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.interest-check{display:flex;align-items:center;gap:8px;padding:10px 13px;border-radius:var(--radius-md);border:2px solid #EDD8E0;cursor:pointer;font-size:13px;transition:all var(--transition)}
.interest-check:has(input:checked){border-color:var(--rose);background:var(--rose-light);color:var(--rose-2)}
.interest-check input{display:none}
.alert{padding:13px 18px;border-radius:var(--radius-md);font-size:14px;margin-bottom:18px;font-weight:500}
.alert-success{background:var(--success-bg);color:#15803D;border:1.5px solid rgba(34,197,94,0.3)}
.alert-error{background:var(--danger-bg);color:#DC2626;border:1.5px solid rgba(239,68,68,0.3)}

/* HERO — SPLIT LAYOUT */
.hero-section{background:#FFFBFC;border-bottom:1px solid #F0E4EC;overflow:hidden}
.hero-split{display:grid;grid-template-columns:1fr 380px;min-height:500px;max-width:1180px;margin:0 auto;padding:0 24px;align-items:stretch}
.hero-left{padding:64px 56px 64px 0;display:flex;flex-direction:column;justify-content:center;border-right:1px solid #F5E0EA}
.hero-tag{display:flex;align-items:center;gap:10px;margin-bottom:22px}
.hero-tag-line{width:28px;height:2.5px;background:var(--rose);border-radius:2px;flex-shrink:0}
.hero-tag span{font-size:11px;font-weight:700;color:var(--rose);text-transform:uppercase;letter-spacing:1.5px}
.hero-title{font-family:var(--font-serif);font-size:clamp(34px,3.5vw,52px);line-height:1.12;color:var(--charcoal);margin-bottom:16px}
.text-rose{color:var(--rose)}
.hero-sub{font-size:16px;color:var(--mid-gray);max-width:420px;margin-bottom:30px;line-height:1.72}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.btn-hero-primary{background:var(--rose);color:white;padding:13px 28px;font-size:14px;border-radius:var(--radius-full);border:none;font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;box-shadow:0 5px 20px rgba(232,66,106,0.32);transition:all var(--transition);letter-spacing:0.01em}
.btn-hero-primary:hover{background:var(--rose-2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(232,66,106,0.42);color:white}
.btn-hero-soft{background:var(--rose-light);color:var(--rose-2);padding:13px 28px;font-size:14px;border-radius:var(--radius-full);border:1.5px solid var(--rose-mid);font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;transition:all var(--transition)}
.btn-hero-soft:hover{background:var(--rose-mid);color:var(--rose-2)}
.btn-hero-outline{background:var(--rose-light);color:var(--rose-2);padding:13px 28px;font-size:14px;border-radius:var(--radius-full);border:1.5px solid var(--rose-mid);font-weight:700;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;transition:all var(--transition)}
.btn-hero-outline:hover{background:var(--rose-mid)}
.hero-trust{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--mid-gray)}
.hero-trust strong{color:var(--charcoal)}
.hero-stars{color:#F0A030;font-size:13px;letter-spacing:1px}
.hero-right{background:linear-gradient(160deg,#FFF0F5 0%,#FFE4EE 50%,#FFF5F0 100%);padding:24px 20px;display:flex;align-items:center}
.hero-cards-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr 1fr;gap:10px;width:100%;height:100%}
.hcard{background:white;border-radius:16px;overflow:hidden;border:1.5px solid rgba(232,66,106,0.10);box-shadow:0 3px 14px rgba(232,66,106,0.08);transition:transform 0.2s}
.hcard:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(232,66,106,0.14)}
.hcard-tall{grid-row:span 2}
.hcard-photo{position:relative;display:flex;align-items:center;justify-content:center;height:190px;overflow:hidden;background:#FFF0F3}
.hcard-photo img{width:100%;height:100%;object-fit:cover}
.hcard-photo-sm{height:88px}
.hcard-emoji{font-size:56px;line-height:1}
.hcard-emoji-sm{font-size:32px;line-height:1}
.hcard-online-dot{position:absolute;bottom:8px;right:8px;width:10px;height:10px;background:#DDD;border-radius:50%;border:2px solid white}
.hcard-online-dot.active{background:#22C55E;box-shadow:0 0 6px rgba(34,197,94,0.6)}
.hcard-info{padding:8px 12px 10px}
.hcard-info strong{display:block;font-size:12px;font-weight:700;color:var(--charcoal);margin-bottom:1px}
.hcard-info span{font-size:11px;color:var(--mid-gray)}
.hcard-stat{background:var(--rose);border:none;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:14px;text-align:center;border-radius:16px}
.hcard-stat-num{font-family:var(--font-serif);font-size:24px;font-weight:700;color:white;line-height:1}
.hcard-stat-label{font-size:10px;color:rgba(255,255,255,0.85);margin-top:5px;font-weight:600;letter-spacing:0.3px}
.hero-bg,.hstat,.hstat-divider,.hero-stats,.hero-profiles,.hero-profile-card,.hp-photo,.hp-initials,.hp-info,.hp-online{display:none}

/* FEATURES */
.features-section{padding:100px 0;background:var(--cream)}
.section-header{text-align:center;margin-bottom:56px}
.section-header h2{font-family:var(--font-serif);font-size:clamp(28px,4vw,42px);color:var(--charcoal);margin-bottom:10px}
.section-header p{font-size:16px;color:var(--mid-gray);max-width:480px;margin:0 auto}
.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:22px}
.feature-card{padding:28px 24px;border-radius:var(--radius-lg);border:1.5px solid rgba(232,66,106,0.10);background:white;transition:all var(--transition);position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(232,66,106,0.03) 0%,transparent 60%);pointer-events:none}
.feature-card:hover{border-color:rgba(232,66,106,0.30);transform:translateY(-4px);box-shadow:var(--shadow-md)}
.feat-icon{font-size:32px;margin-bottom:14px;display:block}
.feature-card h3{font-size:16px;font-weight:700;color:var(--charcoal);margin-bottom:8px}
.feature-card p{font-size:13px;color:var(--mid-gray);line-height:1.65}

/* HOW IT WORKS */
.how-section{padding:100px 0;background:var(--cream-2)}
.steps-row{display:flex;align-items:flex-start;gap:0;margin-bottom:44px}
.step-card{flex:1;padding:28px 24px;text-align:center}
.step-num{font-family:var(--font-serif);font-size:58px;font-weight:700;line-height:1;margin-bottom:12px;-webkit-text-stroke:2px var(--rose-mid);color:transparent}
.step-card h3{font-size:17px;font-weight:700;color:var(--charcoal);margin-bottom:8px}
.step-card p{font-size:14px;color:var(--mid-gray);line-height:1.65}
.step-arrow{font-size:24px;color:var(--rose-mid);padding-top:40px;flex-shrink:0}
.how-cta{text-align:center}

/* PROFILES PREVIEW */
.recent-section{padding:100px 0;background:white}
.profiles-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:14px}
.preview-card{border-radius:var(--radius-lg);overflow:hidden;background:white;border:1.5px solid rgba(232,66,106,0.10);transition:all var(--transition);text-decoration:none}
.preview-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(232,66,106,0.30)}
.pc-photo{height:150px;background:var(--cream-2);position:relative;overflow:hidden}
.pc-photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.preview-card:hover .pc-photo img{transform:scale(1.06)}
.pc-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:44px;color:var(--rose);background:var(--rose-light)}
.pc-info{padding:10px 12px}
.pc-info strong{display:block;font-size:12px;font-weight:700;color:var(--charcoal)}
.pc-info span{font-size:11px;color:var(--mid-gray)}
.online-dot{position:absolute;bottom:8px;right:8px;width:11px;height:11px;background:#22C55E;border-radius:50%;border:2.5px solid white;box-shadow:0 0 6px rgba(34,197,94,0.6)}
.online-dot.small{width:9px;height:9px}
.blur-cta{position:relative;margin-top:-80px;background:linear-gradient(to bottom,transparent,white 40%);padding:80px 0 20px;text-align:center}
.blur-cta p{font-size:16px;color:var(--mid-gray);margin-bottom:14px}

/* SUCCESS STORIES */
.stories-section{padding:100px 0;background:var(--cream)}
.stories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}
.story-card{background:white;border-radius:var(--radius-xl);padding:28px;border:1.5px solid rgba(232,66,106,0.10);box-shadow:var(--shadow-sm);transition:all var(--transition)}
.story-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.story-photos{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.story-av{width:46px;height:46px;border-radius:50%;background:var(--rose-light);display:flex;align-items:center;justify-content:center;font-size:22px}
.story-heart{color:var(--rose);font-size:18px}
blockquote{font-size:14px;color:var(--mid-gray);line-height:1.75;font-style:italic;margin-bottom:12px}
cite{font-size:12px;color:var(--rose-2);font-weight:700;font-style:normal}

/* PREMIUM CTA */
.premium-cta-section{padding:60px 0;background:white}
.prem-card{background:linear-gradient(135deg,#1A0514 0%,#2D0F28 50%,#1A0514 100%);border-radius:var(--radius-xl);padding:56px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.prem-card::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(232,66,106,0.15) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.prem-left h2{font-family:var(--font-serif);font-size:36px;color:white;margin-bottom:12px}
.prem-left p{color:rgba(255,255,255,0.65);font-size:15px;margin-bottom:24px;line-height:1.7}
.prem-left .btn-primary{background:var(--gold);border-color:var(--gold);color:var(--charcoal);font-weight:700}
.prem-left .btn-primary:hover{background:var(--gold-2);border-color:var(--gold-2)}
.prem-features{display:grid;grid-template-columns:1fr 1fr;gap:14px;position:relative;z-index:1}
.pf{color:rgba(255,255,255,0.85);font-size:14px;display:flex;align-items:center;gap:8px}
.pf::before{content:'✓';color:var(--rose);font-weight:700;font-size:15px}

/* AUTH */
.auth-section{min-height:calc(100vh - var(--nav-h));display:flex;align-items:flex-start;justify-content:center;padding:48px 20px;background:var(--cream)}
.auth-container{width:100%;max-width:560px}
.auth-container--sm{max-width:440px}
.auth-brand{text-align:center;margin-bottom:28px}
.auth-brand h1{font-family:var(--font-serif);font-size:30px;color:var(--charcoal);margin:14px 0 6px}
.auth-brand p{color:var(--mid-gray);font-size:15px}
.auth-form{background:white;border-radius:var(--radius-xl);padding:36px;border:1.5px solid rgba(232,66,106,0.12);box-shadow:0 8px 40px rgba(232,66,106,0.08)}
.auth-alt{text-align:center;margin-top:18px;font-size:14px;color:var(--mid-gray)}
.reg-steps{display:flex;gap:6px;margin-bottom:28px}
.reg-step-item{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:9px 4px;border-radius:var(--radius-md);font-size:12px;font-weight:600;color:var(--mid-gray);background:var(--cream-2);transition:all var(--transition)}
.reg-step-item span{width:22px;height:22px;border-radius:50%;background:var(--light-gray);color:white;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.reg-step-item.active{background:var(--rose-light);color:var(--rose-2)}
.reg-step-item.active span{background:var(--rose);box-shadow:0 2px 8px rgba(232,66,106,0.4)}
.reg-panel{display:none}
.reg-panel.active{display:block}
.reg-panel h3{font-size:18px;font-weight:700;color:var(--charcoal);margin-bottom:22px}
.step-nav{display:flex;gap:12px;margin-top:22px}
.step-nav .btn-primary{flex:1}

/* BROWSE */
.browse-section{padding:28px 0 56px}
.browse-layout{display:grid;grid-template-columns:270px 1fr;gap:26px;align-items:start}
.filter-sidebar{background:white;border-radius:var(--radius-xl);padding:22px;border:1.5px solid rgba(232,66,106,0.10);position:sticky;top:86px;box-shadow:var(--shadow-sm)}
.filter-sidebar h3{font-size:16px;font-weight:700;color:var(--charcoal);margin-bottom:18px}
.filter-group{margin-bottom:20px}
.filter-group label{display:block;font-size:12px;font-weight:700;color:var(--mid-gray);margin-bottom:7px;text-transform:uppercase;letter-spacing:0.5px}
.browse-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px}
.browse-header h2{font-size:20px;font-weight:700;color:var(--charcoal)}
.browse-header strong{color:var(--rose)}
.profiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:18px}
.profile-card{background:white;border-radius:var(--radius-xl);overflow:hidden;border:1.5px solid rgba(232,66,106,0.10);transition:all var(--transition);position:relative}
.profile-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-md);border-color:rgba(232,66,106,0.25)}
.pc-photo-link{display:block}
.pc-photo{height:210px;position:relative;overflow:hidden;background:var(--cream-2)}
.pc-photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.profile-card:hover .pc-photo img{transform:scale(1.05)}
.pc-initials-lg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:64px;color:var(--rose);background:var(--rose-light)}
.pc-match-badge{position:absolute;bottom:10px;left:10px;background:rgba(15,8,16,0.80);color:white;font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--radius-full);backdrop-filter:blur(6px);border:1px solid rgba(232,66,106,0.3)}
.pc-body{padding:14px 16px}
.pc-name-row{display:flex;align-items:center;gap:6px;margin-bottom:3px}
.pc-name{font-size:14px;font-weight:700;color:var(--charcoal)}
.verified-badge{background:#22C55E;color:white;border-radius:50%;width:17px;height:17px;font-size:10px;display:flex;align-items:center;justify-content:center}
.pc-meta{font-size:12px;color:var(--mid-gray);margin-bottom:8px}
.pc-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}
.tag-pill{background:var(--rose-light);color:var(--rose-2);font-size:10px;padding:3px 9px;border-radius:var(--radius-full);font-weight:600}
.pc-actions{display:flex;gap:7px;align-items:center}
.btn-like{background:white;border:2px solid #EDD8E0;border-radius:50%;width:34px;height:34px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.btn-like:hover,.btn-like.liked{background:var(--rose-light);border-color:var(--rose);transform:scale(1.1)}
.btn-msg{background:white;border:2px solid #EDD8E0;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all var(--transition)}
.btn-msg:hover{background:var(--rose-light);border-color:var(--rose);transform:scale(1.1)}
.btn-view{margin-left:auto;font-size:12px;font-weight:700;color:var(--rose);background:var(--rose-light);padding:5px 14px;border-radius:var(--radius-full);transition:all var(--transition)}
.btn-view:hover{background:var(--rose);color:white}
.empty-state{text-align:center;padding:70px 20px}
.empty-icon{font-size:52px;margin-bottom:14px}
.empty-state h3{font-size:22px;font-weight:700;color:var(--charcoal);margin-bottom:8px}
.empty-state p{color:var(--mid-gray);margin-bottom:22px}
.pagination{display:flex;gap:7px;justify-content:center;margin-top:36px;flex-wrap:wrap}
.page-btn{width:38px;height:38px;border-radius:var(--radius-md);border:2px solid rgba(232,66,106,0.15);background:white;color:var(--charcoal);font-size:13px;font-weight:600;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.page-btn.active,.page-btn:hover{background:var(--rose);border-color:var(--rose);color:white}

/* PROFILE VIEW */
.profile-section{padding:36px 0 70px}
.profile-layout{display:grid;grid-template-columns:350px 1fr;gap:36px;align-items:start}
.profile-left{position:sticky;top:86px}
.main-photo{border-radius:var(--radius-xl);overflow:hidden;aspect-ratio:3/4;background:var(--rose-light);position:relative;box-shadow:var(--shadow-lg)}
.main-photo img{width:100%;height:100%;object-fit:cover}
.big-initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:110px;color:var(--rose)}
.online-status-badge{position:absolute;top:14px;left:14px;background:rgba(34,197,94,0.9);color:white;padding:5px 14px;border-radius:var(--radius-full);font-size:12px;font-weight:700;backdrop-filter:blur(6px)}
.match-overlay{position:absolute;bottom:14px;left:14px;background:rgba(232,66,106,0.88);color:white;padding:7px 16px;border-radius:var(--radius-full);font-size:14px;font-weight:700;backdrop-filter:blur(6px)}
.photo-thumbs{display:flex;gap:9px;margin-top:14px;overflow-x:auto}
.photo-thumbs img{width:74px;height:84px;border-radius:var(--radius-md);object-fit:cover;cursor:pointer;transition:all var(--transition);border:2.5px solid transparent}
.photo-thumbs img:hover{border-color:var(--rose);transform:scale(1.04)}
.profile-title-row{margin-bottom:18px}
.profile-title-row h1{font-family:var(--font-serif);font-size:34px;color:var(--charcoal);display:flex;align-items:center;gap:10px}
.age-location{display:block;font-size:15px;color:var(--mid-gray);margin-top:5px}
.profile-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:22px;align-items:center}
.profile-bio{background:white;border-radius:var(--radius-lg);padding:18px 22px;border:1.5px solid rgba(232,66,106,0.10);margin-bottom:22px;box-shadow:var(--shadow-sm)}
.profile-bio p{font-size:15px;color:var(--charcoal);line-height:1.75}
.match-chip{background:var(--rose-light);color:var(--rose-2);padding:9px 16px;border-radius:var(--radius-full);font-size:14px;font-weight:700}
.profile-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-bottom:22px;border:1.5px solid rgba(232,66,106,0.10);border-radius:var(--radius-lg);overflow:hidden;background:white;box-shadow:var(--shadow-sm)}
.pd-item{padding:13px 18px;border-bottom:1px solid rgba(232,66,106,0.07);display:flex;justify-content:space-between;align-items:center;font-size:13px}
.pd-item:nth-last-child(-n+2){border-bottom:none}
.pd-label{color:var(--mid-gray)}
.pd-item span:last-child{font-weight:600;color:var(--charcoal)}
.profile-interests h3{font-size:16px;font-weight:700;color:var(--charcoal);margin-bottom:12px}
.interests-row{display:flex;flex-wrap:wrap;gap:7px}
.dropdown{position:relative}
.dropdown-menu{display:none;position:absolute;right:0;top:40px;background:white;border:1.5px solid rgba(232,66,106,0.12);border-radius:var(--radius-lg);min-width:140px;box-shadow:var(--shadow-md);z-index:100;padding:6px}
.dropdown:hover .dropdown-menu{display:block}
.dropdown-menu a{display:block;padding:10px 16px;font-size:13px;color:var(--charcoal);border-radius:var(--radius-md)}
.dropdown-menu a:hover{background:var(--rose-light);color:var(--rose)}

/* MESSAGES */
.messages-section{padding:24px 0;height:calc(100vh - var(--nav-h))}
.messages-layout{display:grid;grid-template-columns:310px 1fr;height:100%;gap:0;background:white;border-radius:var(--radius-xl);border:1.5px solid rgba(232,66,106,0.10);overflow:hidden;box-shadow:var(--shadow-sm)}
.conv-list{border-right:1px solid rgba(232,66,106,0.08);display:flex;flex-direction:column;overflow:hidden}
.conv-list-header{display:flex;justify-content:space-between;align-items:center;padding:18px;border-bottom:1px solid rgba(232,66,106,0.08);flex-shrink:0}
.conv-list-header h3{font-size:16px;font-weight:700}
.conv-item{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid rgba(232,66,106,0.05);transition:background var(--transition);cursor:pointer;text-decoration:none;color:inherit}
.conv-item:hover,.conv-item.active{background:var(--rose-light)}
.cv-av{width:44px;height:44px;border-radius:50%;overflow:hidden;background:var(--rose-light);flex-shrink:0;position:relative}
.cv-av img{width:100%;height:100%;object-fit:cover}
.cv-info{flex:1;min-width:0}
.cv-name-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}
.cv-name-row strong{font-size:13px;font-weight:700;color:var(--charcoal)}
.unread-badge{background:var(--rose);color:white;border-radius:50%;min-width:19px;height:19px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}
.cv-last{font-size:12px;color:var(--mid-gray);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.empty-convs{padding:36px 18px;text-align:center}
.chat-window{display:flex;flex-direction:column;min-width:0}
.chat-header{display:flex;align-items:center;gap:14px;padding:16px 22px;border-bottom:1px solid rgba(232,66,106,0.08);flex-shrink:0}
.chat-av{width:40px;height:40px;border-radius:50%;object-fit:cover}
.chat-header strong{display:block;font-size:14px;font-weight:700}
.chat-status{font-size:12px;color:var(--mid-gray)}
.chat-header-actions{margin-left:auto;display:flex;gap:8px}
.chat-messages{flex:1;overflow-y:auto;padding:20px 22px;display:flex;flex-direction:column;gap:10px}
.msg-bubble{max-width:65%}
.msg-bubble.mine{align-self:flex-end}
.msg-bubble.theirs{align-self:flex-start}
.msg-text{padding:11px 16px;border-radius:var(--radius-lg);font-size:14px;line-height:1.55}
.msg-bubble.mine .msg-text{background:var(--rose);color:white;border-radius:var(--radius-lg) var(--radius-lg) 4px var(--radius-lg);box-shadow:0 2px 10px rgba(232,66,106,0.3)}
.msg-bubble.theirs .msg-text{background:var(--cream-2);color:var(--charcoal);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) 4px}
.msg-time{font-size:10px;color:var(--light-gray);margin-top:4px;padding:0 4px}
.msg-bubble.mine .msg-time{text-align:right}
.chat-input-form{display:flex;gap:10px;padding:16px 22px;border-top:1px solid rgba(232,66,106,0.08);flex-shrink:0}
.chat-input-form .form-control{flex:1;border-radius:var(--radius-full)}
.chat-empty{text-align:center;color:var(--mid-gray);font-size:14px;padding:24px}
.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;padding:48px}

/* ADMIN */
.admin-section{min-height:calc(100vh - var(--nav-h))}
.admin-layout{display:grid;grid-template-columns:230px 1fr;min-height:calc(100vh - var(--nav-h))}
.admin-nav{background:#0F0810;padding:0;display:flex;flex-direction:column}
.admin-nav-logo{padding:20px 18px;font-family:var(--font-serif);color:white;font-size:17px;border-bottom:1px solid rgba(255,255,255,0.06);margin-bottom:10px}
.admin-nav-logo small{display:block;font-size:10px;color:rgba(255,255,255,0.35);font-family:var(--font-main);font-weight:400;margin-top:2px}
.admin-nav-item{display:flex;align-items:center;gap:10px;padding:11px 18px;font-size:13px;color:rgba(255,255,255,0.50);border:none;background:none;cursor:pointer;width:100%;text-decoration:none;transition:all var(--transition);position:relative;font-weight:500}
.admin-nav-item:hover{background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.85)}
.admin-nav-item.active{background:var(--rose);color:white}
.admin-nav-logout{margin-top:auto;color:rgba(232,66,106,0.6) !important}
.nav-badge{background:var(--rose);color:white;border-radius:50%;min-width:18px;height:18px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-left:auto}
.admin-content{background:#F8F0F3;padding:26px;overflow-y:auto}
.admin-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}
.admin-topbar h1{font-size:24px;font-weight:700;color:var(--charcoal)}
.admin-topbar-time{font-size:12px;color:var(--mid-gray)}
.admin-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(145px,1fr));gap:14px;margin-bottom:26px}
.metric-card{background:white;border-radius:var(--radius-lg);padding:18px;border:1.5px solid rgba(232,66,106,0.08);box-shadow:var(--shadow-sm)}
.metric-card.metric-warn{border-color:var(--warn);background:var(--warn-bg)}
.mc-icon{font-size:24px;margin-bottom:10px}
.mc-val{font-family:var(--font-serif);font-size:28px;font-weight:700;color:var(--charcoal);line-height:1}
.mc-label{font-size:11px;color:var(--mid-gray);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:0.3px}
.admin-two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.admin-card{background:white;border-radius:var(--radius-lg);border:1.5px solid rgba(232,66,106,0.08);overflow:hidden;box-shadow:var(--shadow-sm)}
.admin-card-header{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid rgba(232,66,106,0.08)}
.admin-card-header h3{font-size:14px;font-weight:700;color:var(--charcoal)}
.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th{padding:11px 14px;text-align:left;font-weight:700;color:var(--mid-gray);font-size:11px;text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid rgba(232,66,106,0.08)}
.admin-table td{padding:11px 14px;border-bottom:1px solid rgba(232,66,106,0.05);vertical-align:middle}
.admin-table tr:last-child td{border-bottom:none}
.admin-table tr:hover td{background:var(--rose-light)}
.table-user{display:flex;align-items:center;gap:10px}
.tav{width:34px;height:34px;border-radius:50%;background:var(--rose-light);color:var(--rose);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.status-badge{display:inline-block;padding:3px 11px;border-radius:var(--radius-full);font-size:11px;font-weight:700}
.status-active{background:var(--success-bg);color:#15803D}
.status-pending{background:var(--warn-bg);color:#B45309}
.status-banned{background:var(--danger-bg);color:#DC2626}
.empty-state-sm{padding:32px;text-align:center;color:var(--mid-gray);font-size:14px}

/* FOOTER */
.site-footer{background:var(--dark);color:rgba(255,255,255,0.55);padding:70px 0 0}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px}
.footer-brand p{font-size:13px;line-height:1.75;margin-top:12px;max-width:230px}
.footer-brand .nav-logo{margin-bottom:8px;color:white}
.footer-brand .logo-text{color:white}
.footer-brand .logo-text strong{color:var(--rose)}
.footer-langs{display:flex;flex-wrap:wrap;gap:4px;margin-top:16px}
.footer-langs .lang-btn{color:rgba(255,255,255,0.45);border-color:rgba(255,255,255,0.10);background:transparent;font-size:13px}
.footer-langs .lang-btn:hover,.footer-langs .lang-btn.active{background:var(--rose);border-color:var(--rose);color:white}
.footer-links h4{color:rgba(255,255,255,0.85);font-size:12px;font-weight:700;margin-bottom:14px;text-transform:uppercase;letter-spacing:0.8px}
.footer-links a{display:block;font-size:13px;color:rgba(255,255,255,0.45);margin-bottom:10px;transition:color var(--transition)}
.footer-links a:hover{color:var(--rose-light)}
.footer-app h4{color:rgba(255,255,255,0.85);font-size:12px;font-weight:700;margin-bottom:12px;text-transform:uppercase;letter-spacing:0.8px}
.footer-app p{font-size:13px;line-height:1.65;margin-bottom:16px}
.app-badges{display:flex;gap:7px;margin-top:12px;flex-wrap:wrap}
.badge-os{background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.55);font-size:11px;padding:4px 12px;border-radius:var(--radius-full);border:1px solid rgba(255,255,255,0.10)}
.footer-bottom{margin-top:48px;border-top:1px solid rgba(255,255,255,0.05);padding:20px 0}
.footer-bottom .container{display:flex;justify-content:space-between;font-size:12px;color:rgba(255,255,255,0.25)}

/* MISC */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--dark);color:white;padding:13px 28px;border-radius:var(--radius-full);font-size:14px;font-weight:600;z-index:9999;opacity:0;transition:all 0.3s;white-space:nowrap;box-shadow:var(--shadow-dark);border:1px solid rgba(232,66,106,0.3)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.pwa-banner{position:fixed;bottom:0;left:0;right:0;background:var(--dark);color:white;padding:14px 22px;z-index:5000;border-top:1px solid rgba(232,66,106,0.2)}
.pwa-banner-inner{display:flex;align-items:center;gap:14px;max-width:640px;margin:0 auto}
.pwa-banner-inner span{flex:1;font-size:14px}
.pwa-dismiss{background:none;border:none;color:rgba(255,255,255,0.4);font-size:18px;cursor:pointer}
.cookie-bar{position:fixed;bottom:0;left:0;right:0;background:white;border-top:2px solid rgba(232,66,106,0.12);padding:16px 22px;display:flex;align-items:center;gap:14px;z-index:4999;box-shadow:0 -4px 20px rgba(0,0,0,0.08)}
.cookie-bar p{flex:1;font-size:13px;color:var(--mid-gray)}

/* MATCHES */
.matches-section{padding:36px 0 70px}
.matches-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}
.matches-header h1{font-family:var(--font-serif);font-size:32px;color:var(--charcoal)}
.matches-sub{color:var(--mid-gray);font-size:15px;margin-top:5px}
.matches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:22px;margin-bottom:52px}
.match-card{background:white;border-radius:var(--radius-xl);overflow:hidden;border:1.5px solid rgba(232,66,106,0.10);transition:all var(--transition);box-shadow:var(--shadow-sm)}
.match-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.match-photo{display:block;height:250px;position:relative;background:var(--rose-light);overflow:hidden}
.match-photo img{width:100%;height:100%;object-fit:cover;transition:transform 0.4s}
.match-card:hover .match-photo img{transform:scale(1.05)}
.match-badge{position:absolute;top:12px;left:12px;background:var(--rose);color:white;font-size:12px;font-weight:700;padding:5px 12px;border-radius:var(--radius-full);box-shadow:0 3px 12px rgba(232,66,106,0.4)}
.match-body{padding:16px 18px}
.match-name{font-size:17px;font-weight:700;color:var(--charcoal)}
.match-meta{font-size:13px;color:var(--mid-gray);margin-bottom:10px}
.match-actions{display:flex;gap:10px}

/* PREMIUM PAGE */
.premium-section{padding:56px 0 90px}
.prem-hero{text-align:center;margin-bottom:56px}
.prem-hero-badge{display:inline-block;background:var(--rose-light);color:var(--rose-2);padding:7px 18px;border-radius:var(--radius-full);font-size:13px;font-weight:700;margin-bottom:16px;letter-spacing:0.02em}
.prem-hero h1{font-family:var(--font-serif);font-size:46px;color:var(--charcoal);margin-bottom:12px}
.prem-hero p{font-size:17px;color:var(--mid-gray)}
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:22px;margin-bottom:70px;align-items:start}
.plan-card{background:white;border-radius:var(--radius-xl);padding:32px;border:2px solid rgba(232,66,106,0.10);position:relative;transition:all var(--transition)}
.plan-card:hover{border-color:rgba(232,66,106,0.25);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.plan-card.plan-featured{border-color:var(--rose);box-shadow:var(--shadow-lg);transform:scale(1.02)}
.plan-card.plan-yearly{border-color:var(--gold)}
.plan-popular-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--rose);color:white;font-size:11px;font-weight:700;padding:4px 16px;border-radius:var(--radius-full);white-space:nowrap;box-shadow:0 3px 12px rgba(232,66,106,0.4)}
.plan-save-badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--gold);color:white;font-size:11px;font-weight:700;padding:4px 16px;border-radius:var(--radius-full);white-space:nowrap}
.plan-name{font-size:14px;font-weight:700;color:var(--mid-gray);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.8px}
.plan-price{display:flex;align-items:baseline;gap:4px;margin-bottom:4px}
.plan-amount{font-family:var(--font-serif);font-size:42px;font-weight:700;color:var(--charcoal)}
.plan-period{font-size:15px;color:var(--mid-gray)}
.plan-billed{font-size:12px;color:var(--mid-gray);margin-bottom:8px}
.plan-desc{font-size:14px;color:var(--mid-gray);margin-bottom:22px}
.plan-features{list-style:none;margin-bottom:28px;display:flex;flex-direction:column;gap:9px}
.plan-features li{font-size:13px;display:flex;align-items:center;gap:9px}
.feat-yes{color:var(--charcoal)}
.feat-no{color:var(--light-gray)}
.plan-current{text-align:center;background:var(--success-bg);color:#15803D;padding:11px;border-radius:var(--radius-md);font-size:13px;font-weight:700}

/* NOTIFS */
.notif-section{padding:36px 0 70px}
.notif-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:26px}
.notif-header h1{font-family:var(--font-serif);font-size:30px;color:var(--charcoal)}
.notif-list{background:white;border-radius:var(--radius-xl);border:1.5px solid rgba(232,66,106,0.10);overflow:hidden;max-width:660px;box-shadow:var(--shadow-sm)}
.notif-day-label{padding:10px 22px 7px;font-size:11px;font-weight:700;color:var(--mid-gray);text-transform:uppercase;letter-spacing:0.6px;background:var(--cream-2);border-bottom:1px solid rgba(232,66,106,0.07)}
.notif-item{display:flex;align-items:center;gap:16px;padding:16px 22px;border-bottom:1px solid rgba(232,66,106,0.06);transition:background var(--transition)}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:var(--cream)}
.notif-item.unread{background:var(--rose-light)}
.notif-avatar{position:relative;flex-shrink:0}
.notif-avatar img{width:46px;height:46px;border-radius:50%;object-fit:cover}
.notif-body{flex:1;min-width:0}
.notif-msg{font-size:14px;color:var(--charcoal);line-height:1.45;font-weight:500}
.notif-time{font-size:12px;color:var(--light-gray);margin-top:3px}

/* RESPONSIVE */
@media(max-width:1024px){.hero-split{grid-template-columns:1fr;padding:0 20px}.hero-left{border-right:none;padding:48px 0 40px}.hero-right{display:none}.browse-layout{grid-template-columns:1fr}.filter-sidebar{position:static}.prem-card{grid-template-columns:1fr}.footer-inner{grid-template-columns:1fr 1fr}.admin-two-col{grid-template-columns:1fr}.profile-layout{grid-template-columns:1fr}.profile-left{position:static}.main-photo{max-height:420px}}
@media(max-width:768px){.nav-center,.nav-right{display:none}.hamburger{display:flex;margin-left:auto}.messages-layout{grid-template-columns:1fr}.conv-list{max-height:260px}.footer-inner{grid-template-columns:1fr;gap:32px}.admin-layout{grid-template-columns:1fr}.admin-nav{display:none}.form-row-2{grid-template-columns:1fr}.steps-row{flex-direction:column}.step-arrow{display:none}.hstat-divider{display:none}.hero-stats{flex-wrap:wrap;gap:14px;justify-content:center}.profiles-preview-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.prem-card{padding:32px 24px}}
@media print{.navbar,.site-footer,.pwa-banner,.cookie-bar{display:none}}
