/* =========================================================
   AURUM — pole sport championship
   Design language: engraved gold medal on black lacquer.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600;700;800&family=Marcellus&family=Cormorant+Garamond:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --bg:#0a0908;
  --bg-raised:#141210;
  --bg-raised-2:#1c1814;
  --gold:#c9a227;
  --gold-bright:#e8c766;
  --gold-dim:#7d6526;
  --ivory:#ede6d6;
  --muted:#9b9286;
  --line: rgba(201,162,39,.28);
  --line-soft: rgba(201,162,39,.14);
  --danger:#b3543f;
  --radius: 2px;
  --maxw: 1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(201,162,39,.08), transparent 60%),
    radial-gradient(700px 500px at -10% 20%, rgba(201,162,39,.05), transparent 60%),
    var(--bg);
  color:var(--ivory);
  font-family:'Manrope', sans-serif;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:'Cormorant Garamond', serif;font-weight:600;letter-spacing:.01em;margin:0;color:var(--ivory);}
p{margin:0;color:var(--muted);}
ul{margin:0;padding:0;}
button{font-family:inherit;}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;}

.eyebrow{
  font-family:'Manrope',sans-serif;
  font-size:11.5px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:700;
}

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:40;
  background:rgba(10,9,8,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.site-header .wrap{
  display:flex; align-items:center; justify-content:space-between;
  height:78px;
}
.logo{
  display:flex; align-items:center; gap:12px;
}
.logo .mark{
  width:40px; height:40px;
  border-radius:50%;
  object-fit:cover;
  object-position:50% 35%;
  border:1px solid var(--line);
  background:#000;
}
.logo .brand{display:flex; flex-direction:column; gap:3px;}
.logo .wordmark{height:24px; width:auto; display:block;}
.logo small{
  display:block;
  font-family:'Manrope', sans-serif;
  font-size:9.5px;
  letter-spacing:.24em;
  color:var(--muted);
  font-weight:700;
}
nav.main-nav{display:flex; gap:34px; align-items:center;}
nav.main-nav a{
  font-size:13.5px;
  letter-spacing:.04em;
  color:var(--muted);
  position:relative;
  padding:6px 0;
  white-space:nowrap;
}
nav.main-nav a:hover{color:var(--ivory);}
nav.main-nav a.active{color:var(--gold-bright);}
nav.main-nav a.active::after{
  content:'';
  position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--gold);
}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:1px solid var(--gold);
  color:var(--gold-bright);
  background:transparent;
  padding:12px 24px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
  border-radius:var(--radius);
  cursor:pointer;
  transition:background .2s ease, color .2s ease, transform .15s ease;
}
.btn:hover{background:var(--gold); color:#0a0908;}
.btn:active{transform:translateY(1px);}
.btn.solid{background:var(--gold); color:#0a0908;}
.btn.solid:hover{background:var(--gold-bright); border-color:var(--gold-bright);}
.btn.ghost{border-color:var(--line); color:var(--muted);}
.btn.ghost:hover{border-color:var(--gold); color:var(--gold-bright); background:transparent;}
.btn.small{padding:9px 16px; font-size:11.5px;}
.btn.block{width:100%;}
.header-cta{display:flex; gap:12px; align-items:center;}
.nav-toggle{display:none; background:none; border:1px solid var(--line); color:var(--gold); width:42px;height:42px; border-radius:var(--radius); cursor:pointer;}

/* ---------- hero & medallion ---------- */
.hero{
  position:relative;
  padding:96px 0 70px;
  overflow:hidden;
  border-bottom:1px solid var(--line-soft);
}
.hero::before{
  content:'';
  position:absolute; inset:-10%;
  background:url('assets/hero-art.png') center 30%/cover;
  opacity:.16;
  filter:blur(2px) saturate(1.1);
  z-index:0;
}
.hero::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(180deg, var(--bg) 0%, rgba(10,9,8,.55) 35%, var(--bg) 100%);
  z-index:0;
}
.hero .wrap{
  position:relative; z-index:1;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:48px;
  align-items:center;
}
.hero h1{
  font-family:'Cinzel', serif;
  font-weight:700;
  font-size:clamp(40px, 5.6vw, 72px);
  line-height:1.04;
  letter-spacing:.01em;
  margin:18px 0 22px;
}
.hero h1 em{font-style:normal; color:var(--gold);}
.hero p.lede{font-size:17.5px; max-width:480px; color:var(--muted);}
.hero-meta{display:flex; gap:30px; margin-top:34px; flex-wrap:wrap;}
.hero-meta div{border-left:1px solid var(--line); padding-left:14px;}
.hero-meta .v{font-family:'Cormorant Garamond',serif; font-size:21px; color:var(--ivory);}
.hero-meta .k{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); margin-top:2px;}
.hero-actions{display:flex; gap:14px; margin-top:38px; flex-wrap:wrap;}

.medallion-wrap{display:flex; justify-content:center; align-items:center; position:relative;}
.medallion-wrap::before{
  content:'';
  position:absolute; width:130%; height:130%;
  background:radial-gradient(circle, rgba(201,162,39,.20), transparent 62%);
  filter:blur(14px);
  z-index:0;
}
.hero-art{
  position:relative;
  width:min(480px, 92%);
  border:1px solid var(--line);
  padding:10px;
  background:#000;
  box-shadow:0 0 0 1px rgba(201,162,39,.08), 0 30px 70px -20px rgba(0,0,0,.7);
}
.hero-art video, .hero-art img{
  display:block; width:100%; aspect-ratio:1152/928; object-fit:cover;
}
.hero-art .corner{
  position:absolute; width:18px; height:18px;
  border:1px solid var(--gold);
  opacity:.85;
}
.hero-art .corner.tl{top:-1px; left:-1px; border-right:none; border-bottom:none;}
.hero-art .corner.tr{top:-1px; right:-1px; border-left:none; border-bottom:none;}
.hero-art .corner.bl{bottom:-1px; left:-1px; border-right:none; border-top:none;}
.hero-art .corner.br{bottom:-1px; right:-1px; border-left:none; border-top:none;}
.hero-art .cap{
  position:absolute; left:10px; right:10px; bottom:10px;
  display:flex; justify-content:space-between; align-items:baseline;
  padding:10px 14px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.65) 40%);
  font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-bright);
}

/* ---------- sections ---------- */
section{padding:88px 0;}
.section-head{max-width:640px; margin-bottom:48px;}
.section-head h2{font-size:clamp(30px,3.6vw,44px); margin-top:14px;}
.section-head p{margin-top:14px; font-size:15.5px;}
.divider{height:1px; background:linear-gradient(90deg, transparent, var(--line), transparent); margin:0 0 64px;}

/* ---------- about ---------- */
.about-grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start;}
.about-grid p{font-size:15.5px; margin-bottom:16px;}
.stat-row{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:30px;}
.stat-row .stat{border-top:1px solid var(--line); padding-top:14px;}
.stat .num{font-family:'Cormorant Garamond',serif; font-size:38px; color:var(--gold-bright);}
.stat .label{font-size:12px; color:var(--muted); letter-spacing:.05em; margin-top:4px;}

/* ---------- categories ---------- */
.cat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line-soft); border:1px solid var(--line-soft);}
.cat-card{
  background:var(--bg-raised);
  padding:30px 26px;
  position:relative;
  transition:background .2s ease;
}
.cat-card:hover{background:var(--bg-raised-2);}
.cat-num{font-family:'Cormorant Garamond',serif; color:var(--gold-dim); font-size:14px; letter-spacing:.1em;}
.cat-card h3{font-size:23px; margin:14px 0 8px;}
.cat-card p{font-size:13.5px; line-height:1.55;}
.cat-card .tag{
  display:inline-block; margin-top:14px;
  font-size:10.5px; letter-spacing:.1em; text-transform:uppercase;
  color:var(--gold); border:1px solid var(--line); padding:4px 10px; border-radius:var(--radius);
}

/* ---------- services / pricing ---------- */
.svc-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:18px;}
.svc-card{
  border:1px solid var(--line-soft);
  background:var(--bg-raised);
  padding:26px 26px 22px;
}
.svc-card h3{font-size:19px; display:flex; justify-content:space-between; align-items:baseline; gap:10px;}
.svc-card .price{font-family:'Manrope',sans-serif; font-weight:800; color:var(--gold-bright); font-size:17px; white-space:nowrap;}
.svc-card p{font-size:13.5px; margin-top:8px;}
.svc-card ul{margin-top:12px; font-size:13px; color:var(--muted);}
.svc-card ul li{padding-left:14px; position:relative; margin-top:6px;}
.svc-card ul li::before{content:'—'; position:absolute; left:0; color:var(--gold-dim);}

/* ---------- teaser video banner ---------- */
.teaser{padding:0 0 90px;}
.teaser-frame{
  position:relative;
  border:1px solid var(--line);
  padding:8px;
  background:#000;
  max-width:980px;
  margin:0 auto;
}
.teaser-frame video{display:block; width:100%; aspect-ratio:1604/1292; object-fit:cover;}
.teaser-frame .tf-tag{
  position:absolute; top:24px; left:24px;
  font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--gold-bright);
  background:rgba(10,9,8,.55); padding:6px 12px; border:1px solid var(--line);
}
.teaser-head{text-align:center; max-width:560px; margin:0 auto 36px;}
.teaser-head h2{font-size:clamp(26px,3vw,36px); margin-top:14px;}

/* ---------- brand watermark divider ---------- */
.brand-divider{
  display:flex; justify-content:center; padding:30px 0 10px;
  opacity:.9; position:relative;
}
.brand-divider img{height:64px; width:auto;}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line-soft); padding:50px 0 36px; margin-top:40px;}
footer .wrap{display:flex; justify-content:space-between; gap:30px; flex-wrap:wrap;}
footer .f-logo{height:30px; width:auto; display:block;}
footer .f-cols{display:flex; gap:60px; flex-wrap:wrap;}
footer .f-col h4{font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-bottom:14px; font-family:'Manrope',sans-serif;}
footer .f-col a, footer .f-col p{display:block; font-size:13.5px; color:var(--muted); margin-bottom:8px;}
footer .f-col a:hover{color:var(--gold-bright);}
footer .copyright{font-size:11.5px; color:var(--muted); margin-top:40px; opacity:.7;}

/* ---------- page header (rules/register/tickets) ---------- */
.page-hero{padding:60px 0 40px; border-bottom:1px solid var(--line-soft); position:relative; overflow:hidden;}
.page-hero::after{
  content:'';
  position:absolute; top:-40%; right:-6%; width:420px; height:420px;
  background:url('assets/logo-emblem.png') center/cover;
  border-radius:50%;
  opacity:.08;
  filter:saturate(1.1);
  pointer-events:none;
}
.page-hero .wrap{position:relative; z-index:1;}
.page-hero h1{font-size:clamp(36px,4.6vw,58px); margin-top:14px;}
.page-hero p{margin-top:14px; max-width:560px; font-size:15.5px;}
.breadcrumb{font-size:12px; color:var(--muted); letter-spacing:.04em;}

/* ---------- ambient gold sparkle (light catching the engraving) ---------- */
.sparkle{
  position:absolute;
  pointer-events:none;
  opacity:0;
  z-index:0;
  border-radius:50%;
  background:radial-gradient(circle, #fff 0%, var(--gold-bright) 28%, rgba(201,162,39,.4) 60%, transparent 78%);
  animation:sparkle-twinkle 4s ease-in-out infinite;
}
.sparkle::before,
.sparkle::after{
  content:'';
  position:absolute;
  top:50%; left:50%;
  background:linear-gradient(to bottom, transparent, var(--gold-bright) 45%, transparent);
}
.sparkle::before{width:1.5px; height:340%; transform:translate(-50%,-50%);}
.sparkle::after{width:340%; height:1.5px; transform:translate(-50%,-50%);}
@keyframes sparkle-twinkle{
  0%, 100%  { opacity:0;    transform:scale(.2) rotate(0deg); }
  46%       { opacity:0;    transform:scale(.2) rotate(36deg); }
  50%       { opacity:.9;   transform:scale(1) rotate(45deg); }
  54%       { opacity:0;    transform:scale(.2) rotate(54deg); }
}
@media (prefers-reduced-motion: reduce){
  .sparkle{ animation:none; opacity:.35; transform:scale(.7) rotate(45deg); }
}
.breadcrumb a{color:var(--gold-dim);}
.breadcrumb a:hover{color:var(--gold-bright);}

/* ---------- rules page ---------- */
.rules-layout{display:grid; grid-template-columns:260px 1fr; gap:60px; align-items:start;}
.toc{position:sticky; top:100px; border-left:1px solid var(--line); padding-left:18px;}
.toc .eyebrow{display:block; margin-bottom:14px;}
.toc a{display:block; font-size:13px; color:var(--muted); padding:7px 0; border-bottom:1px solid transparent;}
.toc a:hover{color:var(--gold-bright);}
.rule-block{margin-bottom:46px; scroll-margin-top:100px;}
.rule-block .rn{font-family:'Cormorant Garamond',serif; color:var(--gold); font-size:15px; letter-spacing:.06em;}
.rule-block h2{font-size:26px; margin:8px 0 16px;}
.rule-block p{font-size:14.5px; margin-bottom:12px;}
.rule-block ul{margin:14px 0; padding-left:0;}
.rule-block ul li{
  font-size:14.5px; color:var(--ivory); opacity:.92;
  padding:10px 0 10px 22px; border-top:1px solid var(--line-soft); position:relative;
}
.rule-block ul li:first-child{border-top:none;}
.rule-block ul li::before{content:'§'; position:absolute; left:0; color:var(--gold-dim); font-size:12px;}
.note-box{
  border:1px solid var(--line); background:var(--bg-raised);
  padding:18px 20px; font-size:13.5px; color:var(--muted); margin-top:18px;
}
.note-box b{color:var(--gold-bright); font-weight:700;}

/* ---------- forms (register / tickets) ---------- */
.form-layout{display:grid; grid-template-columns:1.3fr .9fr; gap:56px; align-items:start;}
.form-card{border:1px solid var(--line-soft); background:var(--bg-raised); padding:36px;}
.form-step{margin-bottom:38px;}
.form-step:last-child{margin-bottom:0;}
.form-step .step-head{display:flex; align-items:center; gap:12px; margin-bottom:18px;}
.step-num{
  width:30px; height:30px; border:1px solid var(--gold); color:var(--gold-bright);
  display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif; font-size:14px; border-radius:50%;
  flex:none;
}
.form-step h3{font-size:19px; font-family:'Manrope',sans-serif; font-weight:700; letter-spacing:.01em; color:var(--ivory);}
.field-row{display:grid; grid-template-columns:1fr 1fr; gap:16px;}
.field{margin-bottom:16px;}
.field label{display:block; font-size:12px; letter-spacing:.05em; text-transform:uppercase; color:var(--muted); margin-bottom:8px;}
.field input[type=text],
.field input[type=email],
.field input[type=tel],
.field input[type=number],
.field input[type=date],
.field input[type=url],
.field select,
.field textarea{
  width:100%;
  background:var(--bg);
  border:1px solid var(--line);
  color:var(--ivory);
  padding:12px 14px;
  font-family:'Manrope',sans-serif;
  font-size:14px;
  border-radius:var(--radius);
  outline:none;
}
.field textarea{resize:vertical; min-height:90px;}
.field input:focus, .field select:focus, .field textarea:focus{border-color:var(--gold);}
.field input::placeholder, .field textarea::placeholder{color:#5c564a;}
.hint{font-size:12px; color:var(--muted); margin-top:6px;}

.video-toggle{display:flex; gap:10px; margin-bottom:16px;}
.video-toggle button{
  flex:1; padding:11px; border:1px solid var(--line); background:transparent; color:var(--muted);
  font-size:12.5px; letter-spacing:.04em; cursor:pointer; border-radius:var(--radius);
}
.video-toggle button.active{border-color:var(--gold); color:var(--gold-bright); background:rgba(201,162,39,.08);}
.video-pane{display:none;}
.video-pane.active{display:block;}

.stage-toggle{display:flex; gap:12px; margin-bottom:8px;}
.stage-toggle-btn{
  flex:1; padding:14px; border:1px solid var(--line); background:transparent; color:var(--muted);
  font-size:13.5px; letter-spacing:.03em; cursor:pointer; border-radius:var(--radius);
  font-family:'Manrope',sans-serif; font-weight:600;
}
.stage-toggle-btn.active{border-color:var(--gold); color:var(--gold-bright); background:rgba(201,162,39,.08);}
.stage-toggle-btn:disabled{opacity:.45; cursor:not-allowed;}
.stage-pane{display:none;}
.stage-pane.active{display:grid; grid-template-columns:1.3fr .9fr; gap:56px; align-items:start;}
.upload-box{
  border:1px dashed var(--line); padding:26px; text-align:center; cursor:pointer; border-radius:var(--radius);
  font-size:13px; color:var(--muted);
}
.upload-box:hover{border-color:var(--gold);}
.upload-box .fname{margin-top:8px; color:var(--gold-bright); font-size:12.5px;}

.svc-option{
  display:flex; gap:14px; align-items:flex-start; padding:16px 0; border-top:1px solid var(--line-soft); cursor:pointer;
}
.svc-option:first-child{border-top:none;}
.svc-option input{margin-top:3px; accent-color:#c9a227;}
.svc-option .so-body{flex:1;}
.svc-option .so-title{display:flex; justify-content:space-between; gap:10px; font-size:14.5px; color:var(--ivory); font-weight:600;}
.svc-option .so-title span.p{color:var(--gold-bright); font-weight:800; white-space:nowrap;}
.svc-option .so-desc{font-size:12.5px; color:var(--muted); margin-top:4px;}

.qty{display:flex; align-items:center; gap:0; border:1px solid var(--line); width:fit-content; border-radius:var(--radius);}
.qty button{width:38px;height:38px; background:transparent; border:none; color:var(--gold-bright); cursor:pointer; font-size:16px;}
.qty input{width:50px; text-align:center; border:none; background:transparent; color:var(--ivory); font-size:15px;}

.summary{border:1px solid var(--line); background:var(--bg-raised-2); padding:30px; position:sticky; top:100px;}
.summary h3{font-size:17px; font-family:'Manrope',sans-serif; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--gold); margin-bottom:20px;}
.summary-line{display:flex; justify-content:space-between; font-size:13.5px; padding:10px 0; border-top:1px solid var(--line-soft); color:var(--muted);}
.summary-line:first-child{border-top:none;}
.summary-line.empty{font-style:italic; opacity:.7;}
.summary-total{display:flex; justify-content:space-between; align-items:baseline; margin-top:18px; padding-top:18px; border-top:1px solid var(--line);}
.summary-total .label{font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted);}
.summary-total .amount{font-family:'Cormorant Garamond',serif; font-size:32px; color:var(--gold-bright);}
.summary .pay-note{font-size:11.5px; color:var(--muted); margin-top:16px; line-height:1.5;}
.payment-methods{display:flex; gap:10px; margin-top:18px; flex-wrap:wrap;}
.payment-methods span{
  font-size:10.5px; letter-spacing:.06em; text-transform:uppercase; border:1px solid var(--line); color:var(--muted);
  padding:5px 9px; border-radius:var(--radius);
}
.consent{display:flex; gap:10px; margin-top:18px; font-size:12px; color:var(--muted); align-items:flex-start;}
.consent input{margin-top:3px; accent-color:#c9a227;}
.success-box{display:none; border:1px solid var(--gold); background:rgba(201,162,39,.07); padding:22px; margin-top:20px; font-size:13.5px; color:var(--ivory);}
.success-box.show{display:block;}
.error-box{display:none; border:1px solid var(--danger); background:rgba(179,84,63,.08); padding:18px 20px; margin-top:16px; font-size:13px; color:var(--ivory);}

/* ---------- responsive ---------- */
@media (max-width: 980px){
  nav.main-nav{display:none;}
  .nav-toggle{display:block;}
  .hero .wrap{grid-template-columns:1fr;}
  .medallion-wrap{order:-1;}
  .about-grid{grid-template-columns:1fr;}
  .cat-grid{grid-template-columns:repeat(2,1fr);}
  .svc-grid{grid-template-columns:1fr;}
  .rules-layout{grid-template-columns:1fr;}
  .toc{display:none;}
  .form-layout{grid-template-columns:1fr;}
  .field-row{grid-template-columns:1fr;}
  .summary{position:static;}
}
@media (max-width: 560px){
  .cat-grid{grid-template-columns:1fr;}
  .hero-meta{gap:18px;}
}
