/* Grande Love — современный dating, тёплая палитра, живой фон */
:root{
  --bg:#0c0816;
  --bg-2:#160e24;
  --bg-3:#221534;
  --surface:#22152e;
  --surface-2:#2c1a3a;
  --line:rgba(255,180,210,0.10);
  --line-2:rgba(255,180,210,0.18);
  --pink:#ff5b8a;
  --pink-2:#ff7aa6;
  --rose:#ff3d7f;
  --plum:#a855f7;
  --lav:#c084fc;
  --coral:#ff8a65;
  --peach:#ffd1b8;
  --cream:#fff4ea;
  --txt:#fdf2f8;
  --txt-mute:#e0c3da;
  --txt-dim:#a48cb8;
  --r-sm:10px;
  --r-md:18px;
  --r-lg:28px;
  --r-xl:36px;
  --shadow-sm:0 4px 14px rgba(0,0,0,0.3);
  --shadow:0 12px 36px rgba(168,85,247,0.18), 0 6px 16px rgba(255,91,138,0.12);
  --shadow-lg:0 24px 60px rgba(168,85,247,0.30), 0 8px 24px rgba(255,61,127,0.16);
  --grad-hero:linear-gradient(135deg,#ff5b8a 0%,#a855f7 100%);
  --grad-warm:linear-gradient(135deg,#ff8a65 0%,#ff5b8a 100%);
  --grad-soft:linear-gradient(135deg,#a855f7 0%,#7c3aed 100%);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--txt);font-family:'Plus Jakarta Sans','Inter',system-ui,sans-serif;font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased}
body{min-height:100vh;display:flex;flex-direction:column;position:relative;overflow-x:hidden}

/* живой фон — плавающие blob-ы */
.bg-blobs{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.bg-blobs::before,.bg-blobs::after,.bg-blobs span{position:absolute;border-radius:50%;filter:blur(80px);opacity:0.55;animation:float 22s ease-in-out infinite}
.bg-blobs::before{content:"";width:520px;height:520px;background:radial-gradient(circle,#ff5b8a 0%,transparent 70%);top:-160px;right:-120px}
.bg-blobs::after{content:"";width:600px;height:600px;background:radial-gradient(circle,#a855f7 0%,transparent 70%);bottom:-200px;left:-180px;animation-delay:-7s}
.bg-blobs span:nth-child(1){width:380px;height:380px;background:radial-gradient(circle,#ff8a65 0%,transparent 70%);top:30%;left:42%;animation-delay:-3s;opacity:0.35}
.bg-blobs span:nth-child(2){width:300px;height:300px;background:radial-gradient(circle,#c084fc 0%,transparent 70%);top:60%;right:10%;animation-delay:-12s;opacity:0.30}
.bg-blobs span:nth-child(3){width:240px;height:240px;background:radial-gradient(circle,#ff3d7f 0%,transparent 70%);top:8%;left:5%;animation-delay:-18s;opacity:0.30}
@keyframes float{
  0%,100%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.08)}
  66%{transform:translate(-30px,40px) scale(0.94)}
}
.bg-grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:0.04;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9'/><feColorMatrix values='0 0 0 0 1 0 0 0 0 1 0 0 0 0 1 0 0 0 0.5 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

main, header, footer{position:relative;z-index:2}
img{max-width:100%;display:block}
a{color:var(--pink-2);text-decoration:none;transition:color .15s}
a:hover{color:var(--pink)}
button,input,select,textarea{font:inherit;color:inherit}

h1,h2,h3,h4{font-family:'Fraunces','Playfair Display',Georgia,serif;font-weight:600;letter-spacing:-0.015em;margin:0 0 0.5em;color:var(--txt)}
h1{font-size:68px;line-height:1.02;font-weight:600}
h2{font-size:44px;line-height:1.1}
h3{font-size:22px;line-height:1.3}
@media(max-width:760px){h1{font-size:44px} h2{font-size:30px}}
p{margin:0 0 1em}

.container{width:100%;max-width:1200px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
.sec{padding:96px 0;position:relative;z-index:2}
.sec-tight{padding:60px 0}

/* HEADER */
.app-header{position:sticky;top:0;z-index:50;background:rgba(12,8,22,0.72);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-bottom:1px solid var(--line)}
.app-header .inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:13px;color:var(--txt)}
.brand-logo{position:relative;width:44px;height:44px;display:grid;place-items:center;background:var(--grad-hero);border-radius:14px;box-shadow:var(--shadow);color:#fff}
.brand-logo svg{width:22px;height:22px;fill:#fff;filter:drop-shadow(0 1px 2px rgba(0,0,0,0.25))}
.brand-text{font-family:'Fraunces',serif;font-weight:600;font-size:22px;letter-spacing:-0.02em;line-height:1}
.brand-text small{display:block;font-family:'Plus Jakarta Sans',sans-serif;font-size:10.5px;letter-spacing:0.18em;color:var(--pink-2);font-weight:600;text-transform:uppercase;margin-top:4px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{padding:9px 14px;border-radius:10px;color:var(--txt-mute);font-size:14.5px;font-weight:500}
.nav a:hover{color:var(--txt);background:rgba(255,91,138,0.10)}
.nav .age-tag{margin-right:6px;padding:5px 10px;background:rgba(255,138,101,0.12);border:1px solid var(--coral);border-radius:8px;color:var(--coral);font-size:11px;font-weight:700;letter-spacing:0.05em}
.nav .ghost{color:var(--txt);border:1px solid var(--line-2)}
.nav .ghost:hover{border-color:var(--pink-2)}
.nav .cta{background:var(--grad-hero);color:#fff;padding:10px 22px;font-weight:600;border-radius:12px;box-shadow:var(--shadow-sm)}
.nav .cta:hover{transform:translateY(-1px);color:#fff}
.burger{display:none;background:none;border:0;color:var(--txt);cursor:pointer;padding:8px;font-size:24px}
@media(max-width:920px){
  .nav .menu-links{display:none;position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--bg-2);border-bottom:1px solid var(--line);padding:14px;gap:8px}
  .nav.open .menu-links{display:flex}
  .burger{display:block}
}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 26px;border-radius:14px;border:0;cursor:pointer;font-weight:600;font-size:15px;transition:transform .15s, box-shadow .15s, background .15s;font-family:'Plus Jakarta Sans',sans-serif;text-decoration:none}
.btn-primary{background:var(--grad-hero);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);color:#fff}
.btn-secondary{background:var(--surface-2);color:var(--txt);border:1px solid var(--line-2)}
.btn-secondary:hover{background:var(--surface);border-color:var(--pink-2);color:var(--txt)}
.btn-ghost{background:transparent;color:var(--txt);border:1px solid var(--line-2)}
.btn-ghost:hover{border-color:var(--pink-2)}
.btn-lg{padding:17px 32px;font-size:15.5px;border-radius:16px}
.btn-block{width:100%}

/* HERO */
.hero{padding:90px 0 60px;position:relative;z-index:2}
.hero .grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
@media(max-width:980px){.hero .grid{grid-template-columns:1fr;gap:50px}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:12.5px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;color:var(--pink-2);margin-bottom:18px}
.eyebrow::before{content:"";width:24px;height:1.5px;background:var(--pink)}
.hero h1{margin-bottom:18px}
.hero h1 em{font-style:italic;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero .lead{font-size:19px;color:var(--txt-mute);max-width:560px;margin:18px 0 30px;line-height:1.65}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.hero-actions .or{color:var(--txt-dim);font-size:13.5px;padding:0 4px}
.hero-stats{display:flex;gap:32px;margin-top:42px;padding-top:28px;border-top:1px dashed var(--line-2)}
.hero-stats .st{flex:0 0 auto}
.hero-stats .num{font-family:'Fraunces',serif;font-weight:600;font-size:36px;line-height:1;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:6px}
.hero-stats .lbl{font-size:13px;color:var(--txt-mute)}

/* HERO showcase — карточки с силуэтами и стеклянным эффектом */
.showcase{position:relative;height:580px}
@media(max-width:980px){.showcase{height:auto;display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:520px;margin:0 auto}}
@media(max-width:520px){.showcase{grid-template-columns:1fr}}
.scard{position:absolute;width:250px;background:var(--surface);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);transition:transform .25s ease}
.scard:hover{transform:translateY(-8px) rotate(0deg) !important;z-index:9}
.scard .pic{height:280px;position:relative;overflow:hidden}
.scard .pic::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,10,24,0.92));pointer-events:none}
.scard .silhouette{position:absolute;inset:0;display:grid;place-items:center}
.scard .silhouette svg{width:62%;height:auto;filter:drop-shadow(0 8px 24px rgba(0,0,0,0.4))}
.scard .meta{padding:18px 20px 22px;position:relative}
.scard .like-pill{position:absolute;top:-22px;right:18px;width:42px;height:42px;border-radius:50%;background:#fff;display:grid;place-items:center;box-shadow:var(--shadow)}
.scard .like-pill svg{width:20px;height:20px;fill:var(--rose)}
.scard .nm{font-family:'Fraunces',serif;font-weight:600;font-size:21px;color:var(--txt);margin:0 0 4px}
.scard .city-row{font-size:13.5px;color:var(--txt-mute);display:flex;align-items:center;gap:6px;margin-bottom:8px}
.scard .city-row svg{width:13px;height:13px;fill:var(--pink-2);flex:0 0 auto}
.scard .bio{font-size:13px;color:var(--txt-dim);line-height:1.5}
.scard .tag{position:absolute;top:14px;left:14px;padding:5px 11px;background:rgba(15,10,24,0.7);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.08);border-radius:99px;font-size:11.5px;color:#fff;font-weight:600;z-index:3;display:inline-flex;align-items:center;gap:5px}
.scard .tag .dot{width:6px;height:6px;border-radius:50%;background:#3ddc84;box-shadow:0 0 8px #3ddc84}
.scard.s1{top:0;left:6%;transform:rotate(-5deg);z-index:4}
.scard.s1 .pic{background:linear-gradient(135deg,#ff5b8a,#a855f7)}
.scard.s2{top:40px;right:0;transform:rotate(5deg);z-index:3}
.scard.s2 .pic{background:linear-gradient(135deg,#ff8a65,#ff3d7f)}
.scard.s3{bottom:20px;left:0;transform:rotate(-2deg);z-index:2}
.scard.s3 .pic{background:linear-gradient(135deg,#7c3aed,#ff5b8a)}
.scard.s4{bottom:0;right:8%;transform:rotate(3deg);z-index:1}
.scard.s4 .pic{background:linear-gradient(135deg,#a855f7,#ff8a65)}
@media(max-width:980px){.scard{position:relative;width:100%;transform:none!important;top:auto;left:auto;right:auto;bottom:auto}}

/* TRUST STRIP */
.trust{display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:24px;background:rgba(34,21,46,0.5);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:24px;margin-top:40px}
@media(max-width:760px){.trust{grid-template-columns:repeat(2,1fr);gap:18px}}
.trust .it{padding:8px 18px;border-right:1px solid var(--line);text-align:center}
.trust .it:last-child{border-right:0}
@media(max-width:760px){.trust .it{border-right:0}}
.trust .it .t{font-family:'Fraunces',serif;font-weight:600;font-size:24px;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px;line-height:1}
.trust .it .l{font-size:12.5px;color:var(--txt-mute);letter-spacing:0.02em}

/* MISSION/STORY block */
.mission{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
@media(max-width:920px){.mission{grid-template-columns:1fr;gap:40px}}
.mission-pic{position:relative;aspect-ratio:1.05/1;border-radius:32px;overflow:hidden;background:var(--grad-hero);box-shadow:var(--shadow-lg)}
.mission-pic .silbig{position:absolute;inset:0;display:grid;place-items:center}
.mission-pic .silbig svg{width:78%;height:auto;opacity:0.96;filter:drop-shadow(0 18px 40px rgba(0,0,0,0.4))}
.mission-pic::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,10,24,0.4));pointer-events:none}
.mission-pic .quote-pill{position:absolute;left:24px;bottom:24px;padding:14px 18px;background:rgba(15,10,24,0.65);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,0.08);border-radius:18px;color:#fff;max-width:300px;font-size:14px;line-height:1.5}
.mission-pic .quote-pill em{font-family:'Fraunces',serif;font-style:italic;color:var(--peach)}
.mission-text h2{margin-bottom:18px}
.mission-text .lead{color:var(--txt-mute);font-size:17px;line-height:1.7;margin-bottom:18px}
.mission-text p{color:var(--txt-mute);font-size:15.5px}

/* FEATURES — большие блоки */
.features-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:920px){.features-row{grid-template-columns:1fr}}
.fcard{padding:34px 30px;background:linear-gradient(180deg,rgba(34,21,46,0.7) 0%,rgba(20,12,30,0.7) 100%);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:24px;position:relative;overflow:hidden;transition:transform .2s, border-color .2s}
.fcard:hover{transform:translateY(-4px);border-color:var(--line-2)}
.fcard::before{content:"";position:absolute;top:-40px;right:-40px;width:160px;height:160px;border-radius:50%;background:var(--grad-hero);opacity:0.10;filter:blur(20px)}
.fcard .ic{position:relative;width:56px;height:56px;border-radius:16px;background:var(--grad-hero);display:grid;place-items:center;margin-bottom:18px;box-shadow:var(--shadow-sm)}
.fcard .ic svg{width:28px;height:28px;fill:#fff}
.fcard:nth-child(2) .ic{background:var(--grad-warm)}
.fcard:nth-child(3) .ic{background:var(--grad-soft)}
.fcard h3{font-size:21px;margin-bottom:10px}
.fcard p{color:var(--txt-mute);font-size:15px;margin:0;line-height:1.6}

/* SECTION HEAD */
.sec-head{text-align:center;max-width:780px;margin:0 auto 56px}
.sec-head .eyebrow{justify-content:center}
.sec-head .eyebrow::before{display:none}
.sec-head .eyebrow{padding:6px 14px;border:1px solid var(--line-2);border-radius:99px}
.sec-head h2{margin-bottom:14px}
.sec-head p{color:var(--txt-mute);font-size:17px;line-height:1.7}

/* PROFILES — каталог анкет с силуэтами */
.profiles{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:980px){.profiles{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.profiles{grid-template-columns:repeat(2,1fr);gap:14px}}
@media(max-width:420px){.profiles{grid-template-columns:1fr}}
.pcard{background:var(--surface);border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:transform .2s,border-color .2s,box-shadow .2s;cursor:pointer;position:relative}
.pcard:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:var(--shadow)}
.pcard .pp{height:280px;position:relative;display:grid;place-items:center;overflow:hidden}
.pcard .pp::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,10,24,0.85));pointer-events:none}
.pcard .pp svg.silhouette-svg{width:62%;height:auto;filter:drop-shadow(0 8px 20px rgba(0,0,0,0.35));position:relative;z-index:1}
.pcard .pp .city-pin{position:absolute;top:14px;left:14px;padding:6px 12px;background:rgba(15,10,24,0.7);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.08);border-radius:99px;font-size:11.5px;color:#fff;font-weight:500;z-index:2;display:inline-flex;align-items:center;gap:5px}
.pcard .pp .city-pin svg{width:11px;height:11px;fill:var(--pink-2)}
.pcard .pp .heart-btn{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:#fff;display:grid;place-items:center;z-index:2;box-shadow:var(--shadow-sm);border:0;cursor:pointer}
.pcard .pp .heart-btn svg{width:17px;height:17px;fill:var(--rose)}
.pcard .pp .badge-online{position:absolute;bottom:14px;left:14px;padding:5px 10px;background:rgba(15,10,24,0.7);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,0.08);border-radius:99px;font-size:11px;color:#fff;font-weight:500;z-index:2;display:inline-flex;align-items:center;gap:5px}
.pcard .pp .badge-online .dot{width:6px;height:6px;border-radius:50%;background:#3ddc84;box-shadow:0 0 8px #3ddc84}
.pcard .info{padding:18px 20px 20px}
.pcard .nm{font-family:'Fraunces',serif;font-weight:600;font-size:20px;margin-bottom:5px;color:var(--txt)}
.pcard .age{color:var(--txt-mute);font-size:13.5px;margin-bottom:9px}
.pcard .bio{color:var(--txt-dim);font-size:13.5px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard.g1 .pp{background:linear-gradient(135deg,#ff5b8a,#a855f7)}
.pcard.g2 .pp{background:linear-gradient(135deg,#ff8a65,#ff3d7f)}
.pcard.g3 .pp{background:linear-gradient(135deg,#7c3aed,#ff5b8a)}
.pcard.g4 .pp{background:linear-gradient(135deg,#a855f7,#ff8a65)}
.pcard.g5 .pp{background:linear-gradient(135deg,#ff3d7f,#7c3aed)}
.pcard.g6 .pp{background:linear-gradient(135deg,#ff8a65,#a855f7)}
.pcard.g7 .pp{background:linear-gradient(135deg,#a855f7,#ff3d7f)}
.pcard.g8 .pp{background:linear-gradient(135deg,#ff5b8a,#ff8a65)}

/* HOW-IT-WORKS */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative}
@media(max-width:920px){.steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.steps{grid-template-columns:1fr}}
.step{padding:34px 26px;background:rgba(34,21,46,0.55);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:22px;text-align:center}
.step .n{width:54px;height:54px;border-radius:18px;background:var(--grad-hero);color:#fff;font-family:'Fraunces',serif;font-size:24px;font-weight:600;display:grid;place-items:center;margin:0 auto 18px;box-shadow:var(--shadow-sm)}
.step:nth-child(2) .n{background:var(--grad-warm)}
.step:nth-child(3) .n{background:var(--grad-soft)}
.step:nth-child(4) .n{background:linear-gradient(135deg,#ff3d7f,#ff8a65)}
.step h3{font-size:19px;margin-bottom:8px}
.step p{font-size:14.5px;color:var(--txt-mute);margin:0;line-height:1.6}

/* VALUES — три большие колонки с обоснованием */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
@media(max-width:920px){.values{grid-template-columns:1fr}}
.val{padding:0 4px}
.val .ic{width:54px;height:54px;border-radius:50%;background:rgba(255,91,138,0.10);border:1px solid var(--line-2);display:grid;place-items:center;margin-bottom:18px}
.val .ic svg{width:24px;height:24px;fill:var(--pink-2)}
.val h3{font-size:22px;margin-bottom:10px}
.val p{color:var(--txt-mute);font-size:15.5px;line-height:1.7}

/* TESTS */
.tests{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:920px){.tests{grid-template-columns:1fr}}
.testcard{padding:32px 30px;background:rgba(34,21,46,0.6);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:22px;position:relative}
.testcard::before{content:"\201C";position:absolute;top:8px;left:22px;font-family:'Fraunces',serif;font-size:88px;color:var(--pink);opacity:0.18;line-height:1}
.testcard p{font-size:15.5px;line-height:1.7;color:var(--txt);margin-bottom:18px;position:relative;z-index:1}
.testcard .who{display:flex;align-items:center;gap:12px;border-top:1px solid var(--line);padding-top:16px}
.testcard .av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;overflow:hidden}
.testcard .av svg{width:100%;height:100%}
.testcard:nth-child(1) .av{background:linear-gradient(135deg,#ff5b8a,#a855f7)}
.testcard:nth-child(2) .av{background:linear-gradient(135deg,#ff8a65,#ff3d7f)}
.testcard:nth-child(3) .av{background:linear-gradient(135deg,#7c3aed,#ff5b8a)}
.testcard .who .nn{font-weight:600;font-size:14px;color:var(--txt)}
.testcard .who .cc{font-size:12.5px;color:var(--txt-mute)}

/* SAFETY block */
.safety{display:grid;grid-template-columns:1fr 1fr;gap:24px;padding:48px;background:linear-gradient(135deg,rgba(255,91,138,0.10),rgba(168,85,247,0.10));border:1px solid var(--line-2);border-radius:32px}
@media(max-width:920px){.safety{grid-template-columns:1fr;padding:36px 28px}}
.safety h3{font-size:24px;margin-bottom:10px}
.safety p{color:var(--txt-mute);margin:0}
.safety ul{list-style:none;padding:0;margin:0;display:grid;gap:12px}
.safety ul li{display:flex;gap:12px;color:var(--txt-mute);font-size:15px;align-items:flex-start}
.safety ul li::before{content:"";flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--grad-hero) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'><path d='M9 16.17l-3.88-3.88L3.7 13.7 9 19l11-11-1.41-1.41z'/></svg>") center/14px no-repeat;margin-top:1px}

/* CITIES */
.cities{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:920px;margin:0 auto}
.city-tag{padding:11px 20px;border:1px solid var(--line-2);border-radius:99px;color:var(--txt-mute);font-size:14px;background:rgba(34,21,46,0.4);backdrop-filter:blur(8px);font-weight:500}
.city-tag.x{background:var(--grad-hero);color:#fff;border-color:transparent}

/* FAQ */
.faq{max-width:880px;margin:0 auto}
.faq details{background:rgba(34,21,46,0.5);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:18px;margin-bottom:12px;overflow:hidden;transition:border-color .15s}
.faq details[open]{border-color:var(--pink-2)}
.faq summary{cursor:pointer;list-style:none;padding:22px 26px;font-weight:600;color:var(--txt);display:flex;align-items:center;justify-content:space-between;font-size:16.5px;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:26px;color:var(--pink-2);font-weight:300;flex:0 0 auto;transition:transform .15s}
.faq details[open] summary::after{content:"−"}
.faq .answer{padding:0 26px 22px;color:var(--txt-mute);font-size:15px;line-height:1.75}

/* CTA banner */
.cta-banner{position:relative;padding:72px 36px;text-align:center;background:linear-gradient(135deg,rgba(255,91,138,0.18) 0%,rgba(168,85,247,0.18) 100%);border:1px solid var(--line-2);border-radius:32px;overflow:hidden}
.cta-banner::before{content:"";position:absolute;top:-100px;left:-50px;width:340px;height:340px;border-radius:50%;background:var(--grad-hero);opacity:0.15;filter:blur(40px)}
.cta-banner::after{content:"";position:absolute;bottom:-100px;right:-50px;width:300px;height:300px;border-radius:50%;background:var(--grad-warm);opacity:0.15;filter:blur(40px)}
.cta-banner h2{margin-bottom:14px;position:relative;z-index:1}
.cta-banner p{color:var(--txt-mute);max-width:600px;margin:0 auto 30px;font-size:17px;position:relative;z-index:1}
.cta-banner .actions{position:relative;z-index:1;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
.app-footer{margin-top:80px;background:rgba(22,14,36,0.85);backdrop-filter:blur(20px);border-top:1px solid var(--line);padding:60px 0 32px;color:var(--txt-mute);font-size:14.5px;position:relative;z-index:2}
.app-footer .grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;margin-bottom:32px}
@media(max-width:920px){.app-footer .grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.app-footer .grid{grid-template-columns:1fr}}
.app-footer h4{font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;color:var(--txt);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:16px}
.app-footer ul{list-style:none;margin:0;padding:0}
.app-footer ul li{margin-bottom:10px}
.app-footer a{color:var(--txt-mute)}
.app-footer a:hover{color:var(--pink-2)}
.legal{border-top:1px solid var(--line);padding-top:24px;font-size:12.5px;color:var(--txt-dim);line-height:1.75}
.legal strong{color:var(--txt-mute)}

/* AGE MODAL */
#age-modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,4,14,0.92);backdrop-filter:blur(12px);z-index:9999;padding:18px}
#age-modal.show{display:flex}
.age-card{max-width:480px;background:var(--surface);border:1px solid var(--line-2);border-radius:28px;padding:48px 40px;text-align:center;position:relative;overflow:hidden}
.age-card::before{content:"";position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:280px;height:280px;border-radius:50%;background:var(--grad-hero);opacity:0.20;filter:blur(40px)}
.age-card .heart{position:relative;width:72px;height:72px;margin:0 auto 18px;display:grid;place-items:center;background:var(--grad-hero);border-radius:50%;box-shadow:var(--shadow)}
.age-card .heart svg{width:32px;height:32px;fill:#fff}
.age-card .badge{position:relative;font-size:32px;font-family:'Fraunces',serif;font-weight:600;font-style:italic;background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:8px}
.age-card h2{position:relative;margin-bottom:14px;font-size:28px}
.age-card p{position:relative;color:var(--txt-mute);margin-bottom:28px;font-size:15px}
.age-actions{position:relative;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* COOKIE */
#cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;display:none;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--line-2);border-radius:18px;padding:16px 22px;box-shadow:var(--shadow);z-index:9990;max-width:780px;margin:0 auto}
#cookie-banner.show{display:flex}
#cookie-banner p{margin:0;font-size:13.5px;color:var(--txt-mute);flex:1}
#cookie-banner button{padding:9px 20px;border-radius:10px;background:var(--grad-hero);color:#fff;border:0;cursor:pointer;font-weight:600;font-size:13px}
@media(max-width:560px){#cookie-banner{flex-direction:column;align-items:stretch;text-align:center}}

/* FORMS */
.form-card{max-width:500px;margin:48px auto;background:rgba(34,21,46,0.7);backdrop-filter:blur(20px);border:1px solid var(--line-2);border-radius:28px;padding:42px 40px;position:relative;overflow:hidden}
.form-card::before{content:"";position:absolute;top:-60px;right:-60px;width:240px;height:240px;border-radius:50%;background:var(--grad-hero);opacity:0.12;filter:blur(30px)}
.form-card h1{font-size:36px;margin-bottom:8px;position:relative}
.form-card .sub{color:var(--txt-mute);margin-bottom:28px;position:relative}
.field{margin-bottom:18px;position:relative}
.field label{display:block;font-size:12.5px;color:var(--txt-mute);margin-bottom:7px;font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;background:var(--bg-3);border:1px solid var(--line);border-radius:12px;padding:13px 16px;color:var(--txt);outline:none;transition:border-color .15s,box-shadow .15s;font-size:15px}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,91,138,0.18)}
.field select{appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--pink-2) 50%),linear-gradient(135deg,var(--pink-2) 50%,transparent 50%);background-position:calc(100% - 17px) 19px,calc(100% - 12px) 19px;background-size:5px 5px;background-repeat:no-repeat;padding-right:36px}
.field select option{background:var(--bg-3);color:var(--txt)}
.check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--txt-mute);margin-bottom:18px;line-height:1.55}
.check input{margin-top:3px;flex:0 0 auto;accent-color:var(--pink)}
.form-foot{margin-top:20px;text-align:center;color:var(--txt-mute);font-size:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.grid-2{grid-template-columns:1fr}}

/* DOC pages */
.doc{max-width:820px;margin:0 auto}
.doc h1{font-size:48px;margin-bottom:14px}
.doc .meta{color:var(--txt-mute);font-size:14px;margin-bottom:36px}
.doc h2{margin-top:42px;font-size:30px;color:var(--txt)}
.doc h3{margin-top:26px;font-size:18px;font-family:'Plus Jakarta Sans',sans-serif;font-weight:700}
.doc p,.doc li{font-size:16px;color:var(--txt-mute);line-height:1.8}
.doc ul,.doc ol{padding-left:22px}
.doc strong{color:var(--txt)}
.doc table{width:100%;border-collapse:collapse;margin:18px 0;font-size:15px}
.doc table td{padding:12px 0;border-bottom:1px solid var(--line)}
.doc table td:first-child{color:var(--txt-mute);width:38%}
.doc table td:last-child{color:var(--txt)}

/* utility */
.tcenter{text-align:center}
.muted{color:var(--txt-mute)}
.small{font-size:13px}
.mt-12{margin-top:12px}
.mt-24{margin-top:24px}
.mt-48{margin-top:48px}
::selection{background:rgba(255,91,138,0.4);color:#fff}


/* ==== Дополнительные классы под эталонные шаблоны ==== */

/* alert (форма ошибок) */
.alert{background:rgba(232,90,106,0.10);color:#ff6b6b;border:1px solid rgba(232,90,106,0.35);border-radius:12px;padding:11px 14px;margin-bottom:14px;font-size:14px}
.alert.success{background:rgba(91,224,179,0.10);color:#5be0b3;border-color:rgba(91,224,179,0.35)}

/* check-чекбоксы */
.check{display:flex;gap:10px;align-items:flex-start;font-size:13.5px;color:var(--txt-mute);margin-bottom:14px;line-height:1.55}
.check input{margin-top:3px;flex:0 0 auto;accent-color:var(--pink)}
.checks{display:flex;flex-direction:column;gap:0}

/* age-modal под id="age-modal" + дочерние из эталона */
.age-modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:9999;padding:18px}
.age-modal[hidden]{display:none!important}
.age-modal-backdrop{position:absolute;inset:0;background:rgba(8,4,14,0.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}
.age-modal-card{position:relative;max-width:480px;background:var(--surface);border:1px solid var(--line-2);border-radius:28px;padding:48px 40px;text-align:center;overflow:hidden;z-index:1}
.age-modal-card::before{content:"";position:absolute;top:-80px;left:50%;transform:translateX(-50%);width:280px;height:280px;border-radius:50%;background:var(--grad-hero);opacity:0.20;filter:blur(40px)}
.age-modal-mark{position:relative;width:78px;height:78px;border-radius:50%;background:var(--grad-hero);color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:26px;display:grid;place-items:center;margin:0 auto 18px;box-shadow:var(--shadow)}
.age-modal-title{position:relative;font-size:28px;margin-bottom:10px}
.age-modal-text{position:relative;color:var(--txt-mute);margin-bottom:14px;font-size:15px}
.age-modal-question{position:relative;color:var(--txt);font-weight:600;font-size:16px;margin-bottom:22px}
.age-modal-actions{position:relative;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.age-modal-note{position:relative;margin-top:18px;font-size:12.5px;color:var(--txt-dim);line-height:1.5}

/* form-page (если эталон где-то ещё использует) */
.form-page{max-width:560px;margin:48px auto;padding:0 24px}
.form-page h1{font-size:36px;margin-bottom:8px}
.form-page .lead{color:var(--txt-mute);font-size:15.5px;margin-bottom:22px}
.form-page .hint{color:var(--txt-dim);font-size:12.5px;margin:5px 0 0}
.form-page .form-foot{margin-top:18px;text-align:center;color:var(--txt-mute);font-size:14px}

/* кабинет (cab-side / cab-main) */
.cab{display:grid;grid-template-columns:280px 1fr;gap:22px;align-items:flex-start}
@media(max-width:920px){.cab{grid-template-columns:1fr}}
.cab-side{background:rgba(34,21,46,0.6);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:20px;padding:14px}
.cab-side-head{display:flex;align-items:center;justify-content:space-between;padding:6px 8px 14px;border-bottom:1px solid var(--line);margin-bottom:10px}
.cab-side-head h3{font-family:'Fraunces',serif;font-size:18px;margin:0}
.cab-main{min-width:0}

/* conv-list — список диалогов */
.conv-list{max-height:520px;overflow:auto}
.conv-item{display:flex;gap:12px;padding:12px;border-radius:12px;cursor:pointer;align-items:center;margin-bottom:4px;transition:background .15s}
.conv-item:hover{background:rgba(255,91,138,0.10)}
.conv-item.active{background:linear-gradient(135deg,rgba(255,91,138,0.18),rgba(168,85,247,0.18))}
.conv-av{width:40px;height:40px;border-radius:50%;background:var(--grad-hero);display:grid;place-items:center;flex:0 0 auto;color:#fff;font-family:'Fraunces',serif;font-weight:600;font-size:15px;overflow:hidden}
.conv-av img,.conv-av svg{width:100%;height:100%;object-fit:cover}
.conv-name{font-weight:600;color:var(--txt);font-size:14px;line-height:1.2}
.conv-snippet{color:var(--txt-mute);font-size:12.5px;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}

/* bio-card — биография в кабинете */
.bio-card{background:rgba(34,21,46,0.6);backdrop-filter:blur(16px);border:1px solid var(--line);border-radius:20px;padding:24px}
.bio-head{margin-bottom:14px}
.bio-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:560px){.bio-grid{grid-template-columns:1fr}}
.bio-row{display:flex;flex-direction:column;gap:6px}
.bio-row-full{grid-column:1/-1}
.bio-row label{font-size:12.5px;color:var(--txt-mute);font-weight:600;letter-spacing:0.04em;text-transform:uppercase}
.bio-row input,.bio-row textarea{background:var(--bg-3);border:1px solid var(--line);border-radius:10px;padding:11px 14px;color:var(--txt);outline:none;font-size:14.5px;font-family:'Plus Jakarta Sans',sans-serif;transition:border-color .15s,box-shadow .15s}
.bio-row input:focus,.bio-row textarea:focus{border-color:var(--pink);box-shadow:0 0 0 3px rgba(255,91,138,0.18)}
.bio-row textarea{resize:vertical;min-height:86px}

/* rule-card — подсказка про лайки */
.rule-card{display:flex;gap:12px;padding:14px 16px;background:rgba(168,85,247,0.10);border:1px solid var(--line-2);border-radius:14px;margin-bottom:18px;color:var(--txt-mute);font-size:14px;line-height:1.55}
.rule-card .rule-icon{flex:0 0 auto;color:var(--pink-2);margin-top:1px}
.rule-card b{color:var(--txt)}

/* girls-grid — каталог анкет в кабинете */
.girls-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:980px){.girls-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.girls-grid{grid-template-columns:1fr}}
.girl-card{background:var(--surface);border:1px solid var(--line);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s,border-color .2s,box-shadow .2s}
.girl-card:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:var(--shadow)}
.girl-card .gp{height:200px;position:relative;display:grid;place-items:center;overflow:hidden}
.girl-card .gp::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(15,10,24,0.65));pointer-events:none}
.girl-card .gp svg.silhouette,.girl-card .gp svg{width:55%;height:auto;position:relative;z-index:1}
.girl-card .gp .heart{position:absolute;top:10px;right:10px;width:32px;height:32px;border-radius:50%;background:#fff;display:grid;place-items:center;z-index:2;border:0;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .12s}
.girl-card .gp .heart svg{width:15px;height:15px;fill:var(--rose)}
.girl-card .gp .heart.on{background:var(--rose)}
.girl-card .gp .heart.on svg{fill:#fff}
.girl-card .gp .heart:hover{transform:scale(1.08)}
.girl-card .gp .city-pin{position:absolute;top:10px;left:10px;padding:5px 10px;background:rgba(15,10,24,0.7);backdrop-filter:blur(8px);border-radius:99px;font-size:11.5px;color:#fff;font-weight:500;z-index:2}
.girl-card .gi{padding:14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.girl-card .gi .gn{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--txt)}
.girl-card .gi .ga{font-size:12.5px;color:var(--txt-mute)}
.girl-card .gi .gb{font-size:13px;color:var(--txt-dim);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.girl-card .gi .ga-actions{display:flex;gap:8px;margin-top:8px}
.girl-card .gi .ga-actions .btn{padding:9px 12px;font-size:13px;border-radius:10px}
.girl-card .gi .btn-write{flex:1}

/* btn-link / btn-sm для эталонных HTML */
.btn-link{color:var(--txt-mute);font-size:14px;text-decoration:none;padding:8px 12px;border-radius:8px}
.btn-link:hover{color:var(--pink-2)}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:10px}

/* классы эталонного header (.hdr) на случай старых файлов */
.hdr{position:sticky;top:0;z-index:50;background:rgba(12,8,22,0.78);backdrop-filter:blur(20px);border-bottom:1px solid var(--line)}
.hdr-row{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:1200px;margin:0 auto;padding:0 28px}
.logo{display:flex;align-items:baseline;gap:6px;color:var(--txt);text-decoration:none}
.logo-name{font-family:'Fraunces',serif;font-weight:600;font-size:24px}
.logo-tag{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--pink-2);font-weight:700}
.hdr-row .nav{display:flex;gap:14px}
.hdr-row .nav a{padding:8px 12px;color:var(--txt-mute);font-size:14.5px;border-radius:8px;text-decoration:none}
.hdr-row .nav a:hover{color:var(--txt);background:rgba(255,91,138,0.10)}
.hdr-actions{display:flex;align-items:center;gap:10px}

/* footer mini */
.ftr-mini{margin-top:48px;padding:18px 0;border-top:1px solid var(--line);background:rgba(22,14,36,0.6)}
.ftr-mini .ftr-req{max-width:1200px;margin:0 auto;padding:0 28px;color:var(--txt-dim);font-size:12.5px}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
