/* =========================================================
   My Sex Hookups, adult dating (multi-geo)
   mysexhookups.com  (bright: red + charcoal on white)
   ========================================================= */
:root{
  --red:#e22338;
  --red-deep:#b9162a;
  --red-bright:#ff2e46;
  --ink:#1a1719;
  --charcoal:#231f22;
  --body:#4b464a;
  --muted:#8a8388;
  --cream:#f8f5f6;
  --paper:#ffffff;
  --line:#ece8ea;

  /* legacy aliases so existing selectors keep working */
  --burgundy:#e22338;
  --burgundy-deep:#b9162a;
  --gold:#231f22;
  --gold-deep:#000000;

  --maxw:1180px;
  --gutter:clamp(18px,5vw,52px);
  --head:'Poppins','Segoe UI',system-ui,-apple-system,sans-serif;
  --sans:'Mulish','Segoe UI',system-ui,-apple-system,sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--paper);color:var(--body);line-height:1.75;font-size:17px;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none;transition:color .2s ease,background .2s ease,border-color .2s ease,transform .2s ease,box-shadow .2s ease}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gutter)}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;z-index:999;background:var(--red);color:#fff;padding:10px 16px;border-radius:6px}

h1,h2,h3,h4{font-family:var(--head);color:var(--ink);line-height:1.15;font-weight:700;letter-spacing:-0.01em}
h2{font-size:clamp(1.7rem,3.4vw,2.5rem)}
h3{font-size:clamp(1.25rem,2.2vw,1.55rem)}
p{color:var(--body)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;white-space:nowrap;font-family:var(--head);font-weight:700;font-size:.95rem;letter-spacing:.01em;padding:14px 30px;border:2px solid transparent;border-radius:6px;transition:transform .2s ease,box-shadow .2s ease,background .2s ease,color .2s ease,border-color .2s ease}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red);box-shadow:0 12px 26px -14px rgba(226,35,56,.85)}
.btn-primary:hover{background:var(--red-deep);border-color:var(--red-deep);transform:translateY(-2px)}
.btn-gold{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-gold:hover{background:#000;border-color:#000;color:#fff;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--red);border-color:var(--red)}
.btn-outline:hover{background:var(--red);color:#fff}
.btn-lg{padding:16px 38px;font-size:1.02rem}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-ghost-light:hover{background:#fff;color:var(--ink)}

.head-right{display:flex;align-items:center;gap:clamp(10px,1.6vw,18px)}
.head-cats{display:none}
.geo-form{display:flex;align-items:center;gap:8px}
.geo-label{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.geo-select{font-family:var(--sans);font-size:.85rem;font-weight:600;color:var(--ink);background:#fff;border:1px solid #d8d2d5;border-radius:8px;padding:9px 32px 9px 13px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--red) 50%),linear-gradient(135deg,var(--red) 50%,transparent 50%);background-position:calc(100% - 15px) 52%,calc(100% - 10px) 52%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;min-width:150px}
.geo-select:hover{border-color:var(--red)}
.geo-select option{color:#1d191b}
.member-login{font-family:var(--head);font-size:.85rem;font-weight:700;letter-spacing:.03em;color:var(--ink);text-transform:uppercase}
.member-login:hover{color:var(--red)}
.head-right .btn{padding:12px 32px;font-size:.92rem;border-radius:999px;box-shadow:0 10px 22px -12px rgba(226,35,56,.6)}
.head-right .btn:hover{box-shadow:0 14px 26px -12px rgba(226,35,56,.7)}

.site-head{position:relative;background:var(--paper);border-bottom:1px solid var(--line)}
.site-head .container{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:11px 0}
.brand img{width:clamp(185px,20vw,230px);height:auto;display:block}

.mainnav{background:var(--ink);position:relative;z-index:40}
.mainnav .container{display:flex;align-items:center;justify-content:flex-start;gap:4px;flex-wrap:wrap}
.mainnav a{display:block;padding:15px 20px;color:rgba(255,255,255,.86);font-weight:600;font-size:.86rem;letter-spacing:.03em;text-transform:uppercase;font-family:var(--head)}
.mainnav a:hover,.mainnav a.active{color:#fff;box-shadow:inset 0 -3px 0 var(--red)}
.nav-toggle{display:none;width:46px;height:42px;align-items:center;justify-content:center;font-size:1.5rem;color:var(--red)}

.hero-home{position:relative;overflow:hidden;background:linear-gradient(90deg,rgba(248,245,246,.97) 0%,rgba(248,245,246,.72) 38%,rgba(248,245,246,.12) 60%,rgba(248,245,246,0) 72%),url('/images/herodesk.jpg?v=2') right center/cover no-repeat,var(--cream)}
.hero-home .container{position:relative;display:flex;align-items:center;min-height:clamp(440px,42vw,560px)}
.hero-copy{max-width:560px;padding:clamp(40px,6vw,72px) 0}
.eyebrow{display:inline-block;font-family:var(--head);font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.eyebrow::before{content:'';display:inline-block;width:26px;height:3px;background:var(--red);vertical-align:middle;margin-right:10px}
.hero-home h1{font-size:clamp(2.2rem,4.8vw,3.5rem);color:var(--ink);margin-bottom:16px;line-height:1.08}
.hero-home h1 em{color:var(--red);font-style:normal}
.hero-sub{font-size:1.12rem;max-width:48ch;margin-bottom:26px;color:var(--body)}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px}
.hero-home .hero-ctas .btn{min-width:300px}

.hero-page{background:linear-gradient(120deg,var(--red) 0%,var(--red-deep) 70%,var(--ink) 100%);color:#fff;position:relative}
.hero-page::after{content:'';position:absolute;left:0;right:0;bottom:0;height:4px;background:linear-gradient(90deg,var(--ink),transparent)}
.hero-page .container{padding:clamp(40px,6vw,72px) 0;text-align:center}
.hero-page .eyebrow{color:#fff}
.hero-page .eyebrow::before{background:rgba(255,255,255,.6)}
.hero-page h1{color:#fff;font-size:clamp(2rem,4.4vw,3rem);margin-bottom:14px;line-height:1.1}
.hero-page h1 em{color:#fff;font-style:normal;text-decoration:underline;text-decoration-color:rgba(255,255,255,.5);text-underline-offset:5px}
.hero-page .hero-sub{color:rgba(255,255,255,.93);margin:0 auto 24px;max-width:54ch}
.hero-page .hero-ctas{justify-content:center}

.feature-band{background:var(--ink);color:#fff;padding:clamp(28px,4vw,46px) 0}
.feature-band .band-head{text-align:center;max-width:720px;margin:0 auto clamp(14px,2.2vw,24px)}
.feature-band h2{color:#fff;margin-bottom:12px}
.feature-band .band-head p{color:rgba(255,255,255,.78)}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,34px)}
.feature{padding:18px 22px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px}
.feature .fnum{display:none}
.feature h3{color:#fff;font-size:1.2rem;margin-bottom:10px}
.feature p{color:rgba(255,255,255,.78);font-size:.98rem;line-height:1.7}

.article{padding:clamp(48px,7vw,92px) 0}
.article .container{display:grid;grid-template-columns:1fr 320px;gap:clamp(30px,5vw,60px);align-items:start}
.article-main h1{color:var(--ink);font-size:clamp(1.9rem,3.6vw,2.6rem);line-height:1.16;margin:0 0 18px}
.article-main h2{color:var(--ink);margin:34px 0 14px;padding-left:16px;border-left:4px solid var(--red)}
.article-main h2:first-child{margin-top:0}
.article-main h3{color:var(--ink);margin:30px 0 12px}
.article-main p{margin-bottom:16px;font-size:1.06rem;line-height:1.85}
.article-main .lead{font-size:1.18rem;line-height:1.8;color:var(--ink)}
.article-main .inline-img{float:right;margin:4px 0 16px 22px;border-radius:10px;width:140px;height:auto}
.article-main strong{color:var(--ink)}
.aside-card{position:sticky;top:24px;background:var(--cream);border:1px solid var(--line);border-radius:10px;padding:28px 26px;box-shadow:0 20px 40px -28px rgba(30,20,25,.4)}
.aside-card h4{font-size:1.3rem;color:var(--ink);margin-bottom:8px}
.aside-card p{font-size:.96rem;margin-bottom:16px}
.aside-card ul{list-style:none;margin:0 0 20px}
.aside-card li{position:relative;padding:7px 0 7px 26px;font-size:.95rem;color:var(--ink);border-bottom:1px dashed var(--line)}
.aside-card li:last-child{border-bottom:none}
.aside-card li::before{content:'\2713';position:absolute;left:0;top:7px;color:var(--red);font-weight:800}
.aside-card .btn{width:100%}

.cta{background:linear-gradient(120deg,var(--red) 0%,var(--red-deep) 70%,var(--ink) 150%);color:#fff;text-align:center;padding:clamp(48px,7vw,86px) 0}
.cta h2{color:#fff;margin-bottom:12px}
.cta p{color:rgba(255,255,255,.92);max-width:50ch;margin:0 auto 26px;font-size:1.1rem}
.cta .btn-gold{background:#fff;color:var(--red);border-color:#fff}
.cta .btn-gold:hover{background:#fff;color:var(--red-deep);transform:translateY(-2px)}

.site-foot{background:var(--ink);color:#fff;text-align:center;padding:44px 0 32px}
.foot-logo img{width:210px;height:auto;margin:0 auto 22px;filter:brightness(0) invert(1);opacity:.92}
.foot-links{display:flex;flex-wrap:wrap;justify-content:center;gap:10px 26px;padding:18px 0;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16);max-width:760px;margin:0 auto}
.foot-links a{color:rgba(255,255,255,.82);font-size:.9rem;text-decoration:underline}
.foot-links a:hover{color:var(--red-bright)}
.foot-copy{margin-top:18px;font-size:.82rem;color:rgba(255,255,255,.55);line-height:1.7}

.cookie{position:fixed;left:0;right:0;bottom:0;z-index:60;background:var(--ink);color:#fff;padding:15px var(--gutter);transform:translateY(120%);transition:transform .4s ease;border-top:2px solid var(--red)}
.cookie.show{transform:translateY(0)}
.cookie-inner{max-width:var(--maxw);margin:0 auto;display:flex;gap:18px;align-items:center;justify-content:space-between;flex-wrap:wrap}
.cookie p{font-size:.92rem;color:rgba(255,255,255,.9);margin:0;flex:1;min-width:240px}
.cookie a{color:var(--red-bright);text-decoration:underline}
.cookie .btn{padding:10px 24px}

.reveal{animation:reveal-in .7s ease both}
@keyframes reveal-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.reveal{animation:none}}

@media (max-width:900px){
  .article .container{grid-template-columns:1fr}
  .aside-card{position:static;order:2;margin-top:8px}
  .features{grid-template-columns:1fr;gap:16px}
  .hero-home{background:linear-gradient(to top,var(--cream) 8%,rgba(248,245,246,.86) 30%,rgba(248,245,246,.2) 58%,rgba(248,245,246,0) 76%),url('/images/hero-bg-mobile.jpg?v=2') center top/cover no-repeat,var(--cream)}
  .hero-home .container{display:flex;flex-direction:column;justify-content:flex-end;text-align:center;min-height:calc(100vh - 72px);min-height:calc(100svh - 72px);padding:0 0 26px}
  .hero-copy{max-width:100%;padding:0}
  .eyebrow{margin-bottom:8px}
  .hero-home h1{font-size:clamp(1.6rem,6vw,2.1rem);line-height:1.1;margin-bottom:10px}
  .hero-sub{font-size:1rem;max-width:42ch;margin:0 auto 16px}
  .hero-ctas{justify-content:center}
  .hero-home .hero-ctas .btn{width:100%;max-width:440px;min-width:0}
}
@media (max-width:768px){
  .nav-toggle{display:inline-flex}
  .head-right{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:14px;background:#fff;border-top:1px solid var(--line);box-shadow:0 20px 32px -18px rgba(30,20,25,.35);padding:18px var(--gutter);z-index:60}
  .head-right.open{display:flex}
  .head-cats{display:flex;flex-direction:column;gap:2px}
  .head-cats a{font-family:var(--head);font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.03em;font-size:.95rem;padding:8px 2px}
  .head-cats a.active{color:var(--red)}
  .geo-form{width:100%}
  .geo-label{display:none}
  .geo-select{width:100%;min-width:0}
  .member-login{padding:6px 2px}
  .head-right .btn{width:100%}
  .mainnav{display:none}
}
@media (max-width:480px){
  .hero-ctas{width:100%}
  .hero-ctas .btn{flex:1}
  .geo-label{display:none}
}

/* hero heading rendered as a styled div (not an h1) */
.hero-home .hero-heading,.hero-page .hero-heading{font-family:var(--head);font-weight:700;letter-spacing:-0.01em}
.hero-home .hero-heading{font-size:clamp(2.2rem,4.8vw,3.5rem);color:var(--ink);margin-bottom:16px;line-height:1.08}
.hero-home .hero-heading em{color:var(--red);font-style:normal}
.hero-page .hero-heading{color:#fff;font-size:clamp(2rem,4.4vw,3rem);margin-bottom:14px;line-height:1.1}
.hero-page .hero-heading em{color:#fff;font-style:normal}
@media (max-width:900px){.hero-home .hero-heading{font-size:clamp(1.6rem,6vw,2.1rem);line-height:1.1;margin-bottom:10px}}
