/*
Theme Name: Melbourne's Most Beautiful Man
Theme URI: https://mostbeautifulman.org
Author: MMBM
Description: Custom editorial theme for Melbourne's Most Beautiful Man — a charity pageant for men's health. Black, parchment and firebrick red; Fraunces + Merriweather Sans.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: mmbm
*/

:root{
  --ink:#111111;
  --oxblood:#2A1014;
  --oxblood-2:#1c0b0e;
  --paper:#F2E6D8;
  --paper-2:#FBF4E8;
  --paper-edge:#E3D6C2;
  --smoke:#6E665C;
  --red:#B22222;
  --red-bright:#C9302C;
  --line-dark:rgba(242,230,216,.16);
  --maxw:1240px;
  --serif:'Fraunces',Georgia,serif;
  --sans:'Merriweather Sans',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--paper);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
svg{display:block}
svg.logo{height:auto;aspect-ratio:1878/1958}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
section{padding:clamp(72px,9vw,128px) 0}
h1,h2,h3{font-weight:600;line-height:1.02}

/* type helpers */
.eyebrow{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--red);display:inline-flex;align-items:center;gap:12px}
.eyebrow .num{color:var(--smoke)}
.eyebrow.on-dark .num{color:rgba(242,230,216,.5)}
.serif{font-family:var(--serif)}
.lead{font-family:var(--serif);font-weight:400;font-size:clamp(18px,2vw,22px);line-height:1.45;color:var(--smoke);max-width:56ch}
.lead.on-dark{color:rgba(242,230,216,.82)}
.display{font-family:var(--serif);font-weight:900;letter-spacing:-.025em;line-height:.9}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 30px;border-radius:3px;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;cursor:pointer;border:1.5px solid transparent;transition:.18s background,.18s border-color,.18s color,.18s transform}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--red-bright)}
.btn-ghost{background:transparent;border-color:currentColor;color:inherit;opacity:.92}
.btn-ghost:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.on-dark .btn-ghost,.dark .btn-ghost{color:var(--paper);border-color:var(--line-dark)}
.on-dark .btn-ghost:hover,.dark .btn-ghost:hover{background:var(--paper);color:var(--ink);border-color:var(--paper)}
.btn-lg{padding:18px 36px;font-size:14px}

/* sash device */
.sash{display:inline-flex;align-items:center;gap:10px;background:var(--red);color:#fff;padding:9px 20px 9px 18px;font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;clip-path:polygon(0 0,100% 0,calc(100% - 13px) 100%,13px 100%)}

/* ============ NAV ============ */
header.nav{position:sticky;top:0;z-index:60;background:rgba(242,230,216,.86);backdrop-filter:blur(12px);border-bottom:1px solid var(--paper-edge)}
.nav-in{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand{display:flex;align-items:center;gap:11px}
.brand .logo{width:25px;color:var(--ink)}
.brand .bt{font-family:var(--serif);font-weight:700;font-size:16px;letter-spacing:.01em;line-height:1}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-family:var(--sans);font-weight:600;font-size:13.5px;color:var(--ink);opacity:.78;transition:.18s}
.nav-links a:hover{opacity:1;color:var(--red)}
.nav-cta{padding:11px 22px;font-size:12px}
.burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:24px;position:relative}
.burger span{position:absolute;left:0;width:100%;height:2px;background:var(--ink);transition:.2s}
.burger span:nth-child(1){top:3px}.burger span:nth-child(2){top:11px}.burger span:nth-child(3){top:19px}
@media(max-width:900px){.nav-links{display:none}.burger{display:block}}
#mob{display:none;flex-direction:column;background:var(--paper-2);border-bottom:1px solid var(--paper-edge)}
#mob a{padding:15px 32px;border-top:1px solid var(--paper-edge);font-weight:600;font-size:15px}
#mob.open{display:flex}

/* ============ HERO ============ */
.hero{background:var(--ink);color:var(--paper);padding:clamp(56px,7vw,96px) 0 clamp(72px,9vw,120px)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:center}
.hero .kick{margin-bottom:26px}
.hero h1{font-family:var(--serif);font-weight:900;letter-spacing:-.03em;line-height:.88;margin-bottom:0}
.hero h1 .pre{display:block;font-family:var(--serif);font-style:italic;font-weight:500;font-size:clamp(20px,2.4vw,30px);letter-spacing:-.01em;color:var(--paper);opacity:.92;margin-bottom:10px;line-height:1}
.hero h1 .big{display:block;font-size:clamp(54px,8.4vw,118px)}
.hero h1 .big em{font-style:normal;color:var(--red-bright)}
.hero .tag{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(18px,2.1vw,24px);color:var(--paper);opacity:.9;margin:26px 0 0;max-width:42ch}
.facts{display:flex;flex-wrap:wrap;gap:0;margin:36px 0 34px;border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark)}
.fact{padding:18px 28px 18px 0;margin-right:28px;border-right:1px solid var(--line-dark)}
.fact:last-child{border-right:0;margin-right:0}
.fact b{font-family:var(--serif);font-weight:600;font-size:19px;display:block;line-height:1}
.fact span{font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(242,230,216,.55);margin-top:7px;display:block}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero .tiny{font-family:var(--sans);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(242,230,216,.5);margin-top:22px;font-weight:600}

/* hero mark — logo only (space reserved for a masked video later) */
.hero-mark{display:flex;align-items:center;justify-content:center}
.hero-mark .logo{width:min(380px,82%);color:var(--paper)}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:28px}.hero-mark .logo{width:210px}}

/* ============ MARQUEE ============ */
.marquee{background:var(--red);color:#fff;overflow:hidden;border-top:1px solid rgba(0,0,0,.08)}
.marquee-track{display:flex;white-space:nowrap;will-change:transform;animation:scroll 32s linear infinite}
.marquee-track span{font-family:var(--serif);font-weight:600;font-size:clamp(18px,2vw,24px);padding:16px 0;display:inline-flex;align-items:center}
.marquee-track span::after{content:"✦";font-size:13px;margin:0 30px;opacity:.7}
@keyframes scroll{to{transform:translateX(-50%)}}
.marquee:hover .marquee-track{animation-play-state:paused}

/* ============ SECTION HEADS ============ */
.dark{background:var(--ink);color:var(--paper)}
.ox{background:var(--oxblood);color:var(--paper)}
.sec-head{max-width:62ch;margin-bottom:clamp(44px,6vw,72px)}
.sec-head .kick{margin-bottom:22px}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:clamp(32px,5.2vw,60px);letter-spacing:-.02em;line-height:1.0}
.sec-head h2 em{font-style:italic;font-weight:500}
.sec-head p{margin-top:20px}

/* ============ STEPS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--paper-edge)}
.step{padding:40px 36px;border-right:1px solid var(--paper-edge);position:relative}
.step:first-child{padding-left:0}
.step:last-child{border-right:0;padding-right:0}
.step .n{font-family:var(--serif);font-weight:900;font-size:64px;color:var(--paper);-webkit-text-stroke:1.4px var(--red);line-height:1;display:block;margin-bottom:18px}
.step h3{font-family:var(--serif);font-weight:600;font-size:24px;letter-spacing:-.01em;margin-bottom:12px}
.step p{font-size:15.5px;color:var(--smoke);max-width:34ch}
@media(max-width:820px){.steps{grid-template-columns:1fr}.step{border-right:0;border-bottom:1px solid var(--paper-edge);padding:32px 0}.step:last-child{border-bottom:0}.step .n{-webkit-text-stroke:1.2px var(--red);color:transparent}}

/* ============ CAUSE ============ */
.cause-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.stats{display:flex;gap:0;margin-top:8px;flex-wrap:wrap}
.stat{padding-right:36px;margin-right:36px;border-right:1px solid var(--line-dark)}
.stat:last-child{border-right:0;margin-right:0;padding-right:0}
.stat b{font-family:var(--serif);font-weight:700;font-size:clamp(40px,5vw,58px);color:var(--red-bright);line-height:.95;display:block;letter-spacing:-.02em}
.stat span{font-family:var(--sans);font-size:12.5px;color:rgba(242,230,216,.65);margin-top:12px;display:block;line-height:1.4}
.partner{border:1px solid rgba(242,230,216,.18);padding:40px}
.partner h3{font-family:var(--serif);font-weight:600;font-size:26px;margin-bottom:14px}
.partner p{color:rgba(242,230,216,.78);font-size:15.5px;max-width:46ch}
.partner .pending{display:inline-flex;align-items:center;gap:10px;margin-top:22px;font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red-bright);border:1px dashed rgba(201,48,44,.5);padding:9px 16px}
@media(max-width:900px){.cause-grid{grid-template-columns:1fr;gap:40px}}

/* ============ TICKETS ============ */
.tickets-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:56px;align-items:center}
.ticket-card{border:1px solid var(--paper-edge);background:var(--paper-2);padding:48px 44px}
.ticket-card .price{font-family:var(--serif);font-weight:900;font-size:clamp(52px,8vw,84px);letter-spacing:-.03em;line-height:1}
.ticket-card .of{font-family:var(--sans);font-weight:600;font-size:13px;letter-spacing:.04em;color:var(--smoke);margin:10px 0 28px}
.ticket-card .embed-note{font-size:12.5px;color:var(--smoke);margin-top:22px;line-height:1.5;max-width:42ch}
@media(max-width:900px){.tickets-grid{grid-template-columns:1fr;gap:36px}}

/* ============ SPONSORS ============ */
.tiers{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:8px}
.tier{border:1px solid var(--paper-edge);background:var(--paper-2);padding:30px 26px;display:flex;flex-direction:column}
.tier.feat{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.tier .tn{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--smoke)}
.tier.feat .tn{color:var(--red-bright)}
.tier .amt{font-family:var(--serif);font-weight:700;font-size:38px;letter-spacing:-.02em;margin:14px 0 20px;line-height:1}
.tier ul{list-style:none;display:flex;flex-direction:column;gap:11px;margin-top:auto}
.tier li{font-size:14px;color:var(--smoke);padding-left:20px;position:relative;line-height:1.4}
.tier.feat li{color:rgba(242,230,216,.78)}
.tier li::before{content:"";position:absolute;left:0;top:8px;width:7px;height:7px;background:var(--red)}
.tier .ribbon{font-family:var(--sans);font-weight:700;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--red-bright);margin-bottom:14px}
@media(max-width:980px){.tiers{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.tiers{grid-template-columns:1fr}}
.sponsor-cta{margin-top:42px;display:flex;gap:16px;align-items:center;flex-wrap:wrap}

/* ============ NOMINATE ============ */
.nom-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:start}
.form{display:grid;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-l{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:rgba(242,230,216,.6);margin-bottom:8px;display:block}
.form input,.form textarea{width:100%;padding:14px 16px;border-radius:3px;border:1.5px solid var(--line-dark);background:var(--oxblood-2);color:var(--paper);font-family:var(--sans);font-size:15px}
.form textarea{min-height:104px;resize:vertical}
.form input::placeholder,.form textarea::placeholder{color:rgba(242,230,216,.4)}
.form input:focus,.form textarea:focus{outline:none;border-color:var(--red-bright)}
.form-note{font-size:12.5px;color:rgba(242,230,216,.55);margin-top:4px}
.msg{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--red-bright);min-height:20px}
@media(max-width:900px){.nom-grid{grid-template-columns:1fr;gap:36px}.form .row{grid-template-columns:1fr}}

/* ============ MERCH ============ */
.merch-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:8px}
.merch{border:1px solid var(--paper-edge);background:var(--paper-2);overflow:hidden}
.merch .ph{aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;background:var(--paper);border-bottom:1px solid var(--paper-edge);position:relative}
.merch .ph .logo{width:64px;color:var(--paper-edge)}
.merch .ph .tagm{position:absolute;top:14px;left:14px;font-family:var(--sans);font-weight:700;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--red)}
.merch .info{padding:18px 20px;display:flex;justify-content:space-between;align-items:baseline;gap:12px}
.merch .info h3{font-family:var(--serif);font-weight:600;font-size:17px}
.merch .info span{font-family:var(--sans);font-weight:700;font-size:12px;letter-spacing:.04em;color:var(--smoke);white-space:nowrap}
@media(max-width:820px){.merch-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.merch-grid{grid-template-columns:1fr}}

/* ============ RAFFLE ============ */
.raffle{background:var(--red);color:#fff;text-align:center}
.raffle h2{font-family:var(--serif);font-weight:600;font-size:clamp(30px,5vw,52px);letter-spacing:-.02em;line-height:1.0}
.raffle p{max-width:54ch;margin:18px auto 26px;color:rgba(255,255,255,.9);font-family:var(--serif);font-size:18px}
.raffle .btn-ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.raffle .btn-ghost:hover{background:#fff;color:var(--red);border-color:#fff}

/* ============ FAQ ============ */
.faq{max-width:860px;margin:0 auto;border-top:1px solid var(--paper-edge)}
details{border-bottom:1px solid var(--paper-edge)}
summary{cursor:pointer;list-style:none;padding:24px 4px;font-family:var(--serif);font-weight:600;font-size:clamp(18px,2.4vw,23px);display:flex;justify-content:space-between;align-items:center;gap:18px;letter-spacing:-.01em}
summary::-webkit-details-marker{display:none}
summary .ico{flex:none;width:24px;height:24px;position:relative}
summary .ico::before,summary .ico::after{content:"";position:absolute;background:var(--red);transition:.2s}
summary .ico::before{top:11px;left:3px;width:18px;height:2px}
summary .ico::after{top:3px;left:11px;width:2px;height:18px}
details[open] summary .ico::after{transform:rotate(90deg);opacity:0}
details p{padding:0 4px 24px;color:var(--smoke);font-size:16px;max-width:70ch}

/* ============ SIGNUP ============ */
.signup-wrap{text-align:center;max-width:680px;margin:0 auto}
.signup-wrap h2{font-family:var(--serif);font-weight:900;font-size:clamp(40px,8vw,92px);letter-spacing:-.03em;line-height:.9}
.signup-wrap h2 em{font-style:italic;font-weight:500;color:var(--red-bright)}
.signup{display:flex;gap:12px;max-width:480px;margin:34px auto 0;flex-wrap:wrap;justify-content:center}
.signup input{flex:1;min-width:230px;padding:16px 20px;border-radius:3px;border:1.5px solid var(--line-dark);background:var(--oxblood-2);color:var(--paper);font-family:var(--sans);font-size:15px}
.signup input:focus{outline:none;border-color:var(--red-bright)}

/* ============ FOOTER ============ */
footer{background:var(--oxblood-2);color:var(--paper);padding:80px 0 40px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid rgba(242,230,216,.14)}
.foot-brand .logo{width:40px;color:var(--paper);margin-bottom:18px}
.foot-brand .bt{font-family:var(--serif);font-weight:700;font-size:20px}
.foot-brand p{color:rgba(242,230,216,.6);font-size:14px;margin-top:12px;max-width:34ch}
.foot-col h4{font-family:var(--sans);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--red-bright);margin-bottom:18px}
.foot-col a{display:block;color:rgba(242,230,216,.72);font-size:14.5px;padding:7px 0;transition:.18s}
.foot-col a:hover{color:var(--paper)}
.foot-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;padding-top:28px;font-size:12px;letter-spacing:.04em;color:rgba(242,230,216,.5)}
.foot-bottom .cities{text-transform:uppercase;letter-spacing:.14em}
@media(max-width:820px){.foot-top{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .marquee-track{animation:none}
  html{scroll-behavior:auto}
}
