
:root{--gold:#C9A84C;--gold-light:#E8C96B;--gold-dim:#8A6E2F;--gold-pale:rgba(201,168,76,0.10);--bg:#0A0A0A;--bg2:#111111;--bg3:#1A1A1A;--bg4:#242424;--text:#FAFAF8;--text2:rgba(250,250,248,0.62);--text3:rgba(250,250,248,0.30);--border:rgba(255,255,255,0.07);--border-gold:rgba(201,168,76,0.3);--card-bg:rgba(255,255,255,0.025);--muted:#888;--nav-bg:rgba(10,10,10,0.92);--ticker-text:#0A0A0A;}
[data-theme="light"]{--bg:#F4EFE6;--bg2:#FAFAF8;--bg3:#EDE7D9;--bg4:#E3DDD1;--text:#0A0A0A;--text2:rgba(10,10,10,0.62);--text3:rgba(10,10,10,0.30);--border:rgba(0,0,0,0.07);--border-gold:rgba(201,168,76,0.5);--card-bg:rgba(0,0,0,0.025);--muted:#666;--nav-bg:rgba(244,239,230,0.94);--ticker-text:#0A0A0A;}
*{margin:0;padding:0;box-sizing:border-box;}html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;transition:background 0.4s,color 0.4s;}
.cursor{width:10px;height:10px;background:var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);}
.cursor-ring{width:36px;height:36px;border:1px solid var(--gold);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.18s;opacity:0.55;}
.ticker-wrap{background:var(--gold);overflow:hidden;padding:7px 0;position:sticky;top:0;z-index:300;}
.ticker-track{display:flex;gap:56px;animation:ticker 30s linear infinite;white-space:nowrap;width:max-content;}
.ticker-item{font-size:11px;font-weight:600;color:var(--ticker-text);letter-spacing:0.1em;text-transform:uppercase;display:flex;align-items:center;gap:8px;}
.ticker-item .up{color:#1a5c1a;}.ticker-item .down{color:#8b1a1a;}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
nav{position:fixed;top:27px;left:0;right:0;z-index:200;display:flex;align-items:center;justify-content:space-between;padding:0 60px;transition:all 0.35s;}
nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(24px);top:0;padding:16px 60px;border-bottom:1px solid var(--border);}
.nav-logo{font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:700;color:var(--text);text-decoration:none;}
.nav-logo span{color:var(--gold);}
.nav-links{display:flex;gap:34px;list-style:none;}
.nav-links a{font-size:11px;font-weight:500;letter-spacing:0.14em;text-transform:uppercase;color:var(--text2);text-decoration:none;transition:color 0.25s;cursor:none;}
.nav-links a:hover,.nav-links a.active{color:var(--gold);}
.nav-right{display:flex;align-items:center;gap:18px;}
.theme-toggle{width:46px;height:24px;border-radius:12px;background:var(--bg4);border:1px solid var(--border-gold);cursor:none;position:relative;flex-shrink:0;}
.theme-toggle::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:var(--gold);transition:transform 0.3s;}
[data-theme="light"] .theme-toggle::after{transform:translateX(22px);}
.nav-cta{background:transparent;border:1px solid var(--gold);color:var(--gold);font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;padding:9px 24px;cursor:none;text-decoration:none;transition:all 0.3s;}
.nav-cta:hover{background:var(--gold);color:#000;}

/* PAGE HEADER */
.page-header{
  min-height:55vh;display:flex;flex-direction:column;justify-content:flex-end;
  padding:160px 60px 80px;position:relative;overflow:hidden;
}
.page-header::before{
  content:'CONTACT';
  position:absolute;bottom:-40px;right:-20px;
  font-family:'Bebas Neue',cursive;font-size:clamp(140px,20vw,280px);
  color:rgba(201,168,76,0.03);letter-spacing:0.08em;pointer-events:none;line-height:1;
}
.page-eyebrow{font-size:11px;font-weight:500;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:12px;}
.page-eyebrow::before{content:'';width:38px;height:1px;background:var(--gold);}
.page-title{font-family:'Cormorant Garamond',serif;font-size:clamp(56px,7vw,100px);font-weight:300;line-height:0.95;margin-bottom:24px;}
.page-title em{font-style:italic;color:var(--gold);}
.page-sub{font-size:16px;font-weight:300;color:var(--text2);max-width:520px;line-height:1.8;}

/* CONTACT BODY */
.contact-section{padding:100px 60px;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:flex-start;}

/* FORM */
.form-block{}
.section-label{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:14px;}
.section-label::after{content:'';height:1px;width:44px;background:var(--gold);}
.form-title{font-family:'Cormorant Garamond',serif;font-size:clamp(34px,4vw,48px);font-weight:300;line-height:1.1;color:var(--text);margin-bottom:40px;}
.form-title em{font-style:italic;color:var(--gold);}
.form-row{margin-bottom:24px;}
.form-row.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
label{display:block;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
input,select,textarea{
  width:100%;background:var(--bg3);border:1px solid var(--border);
  color:var(--text);font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;
  padding:14px 18px;outline:none;transition:border-color 0.25s,background 0.3s;
  appearance:none;cursor:none;border-radius:0;
}
input:focus,select:focus,textarea:focus{border-color:var(--gold);background:var(--bg4);}
textarea{resize:vertical;min-height:140px;line-height:1.6;}
select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A84C' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;}
input::placeholder,textarea::placeholder{color:var(--text3);}
.form-submit{margin-top:36px;}
.btn-primary{background:var(--gold);color:#000;font-size:12px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:16px 44px;text-decoration:none;cursor:none;display:inline-block;transition:all 0.3s;border:none;font-family:'DM Sans',sans-serif;}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-2px);box-shadow:0 16px 48px rgba(201,168,76,0.22);}
.form-note{font-size:12px;color:var(--text3);margin-top:16px;line-height:1.6;}

/* SIDEBAR INFO */
.contact-sidebar{position:sticky;top:120px;}
.contact-card{background:var(--bg3);padding:36px 32px;border:1px solid var(--border);margin-bottom:20px;transition:border-color 0.3s;}
.contact-card:hover{border-color:var(--border-gold);}
.card-label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.card-title{font-size:16px;font-weight:500;color:var(--text);margin-bottom:8px;}
.card-desc{font-size:14px;font-weight:300;color:var(--text2);line-height:1.7;}
.card-link{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--gold);text-decoration:none;cursor:none;margin-top:16px;transition:gap 0.25s;}
.card-link:hover{gap:14px;}

/* Social Block */
.social-block{background:var(--bg3);padding:36px 32px;border:1px solid var(--border);}
.social-label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;}
.social-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.social-btn{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border:1px solid var(--border);
  font-size:13px;font-weight:500;color:var(--text2);
  text-decoration:none;cursor:none;transition:all 0.25s;
}
.social-btn:hover{border-color:var(--border-gold);color:var(--gold);}
.social-icon{font-size:16px;}

/* Map-ish location block */
.location-block{
  background:linear-gradient(145deg,var(--bg3),var(--bg4));
  padding:36px 32px;border:1px solid var(--border);
  position:relative;overflow:hidden;margin-top:20px;
}
.location-block::before{
  content:'JHB';font-family:'Bebas Neue',cursive;
  font-size:100px;color:rgba(201,168,76,0.06);
  position:absolute;bottom:-10px;right:-10px;letter-spacing:0.05em;
  pointer-events:none;line-height:1;
}
.location-flag{font-size:28px;margin-bottom:12px;}
.location-name{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;color:var(--text);margin-bottom:6px;}
.location-sub{font-size:13px;color:var(--muted);}
.location-hours{margin-top:20px;display:flex;flex-direction:column;gap:6px;}
.hour-row{display:flex;justify-content:space-between;font-size:13px;font-weight:300;color:var(--text2);padding-bottom:6px;border-bottom:1px solid var(--border);}
.hour-row:last-child{border-bottom:none;}

/* Marquee */
.marquee-section{border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 0;background:var(--bg2);overflow:hidden;}
.marquee-track{display:flex;gap:70px;animation:marquee 26s linear infinite;width:max-content;}
.marquee-item{font-family:'Cormorant Garamond',serif;font-size:20px;font-style:italic;font-weight:300;color:var(--text3);white-space:nowrap;}
.marquee-item span{color:var(--gold);}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Thank you state */
.form-success{display:none;text-align:center;padding:60px 40px;background:var(--bg3);border:1px solid var(--border-gold);}
.form-success.show{display:block;}
.success-icon{font-size:48px;margin-bottom:20px;}
.success-title{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:300;color:var(--text);margin-bottom:12px;}
.success-title em{font-style:italic;color:var(--gold);}
.success-desc{font-size:15px;font-weight:300;color:var(--text2);line-height:1.8;}

/* FOOTER */
footer{background:var(--bg2);border-top:1px solid var(--border);padding:80px 60px 36px;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:52px;margin-bottom:52px;}
.footer-brand{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:700;margin-bottom:14px;color:var(--text);}
.footer-brand span{color:var(--gold);}
.footer-desc{font-size:14px;font-weight:300;line-height:1.8;color:var(--muted);margin-bottom:26px;}
.footer-social{display:flex;gap:10px;}
.soc-link{width:36px;height:36px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted);text-decoration:none;cursor:none;transition:all 0.25s;}
.soc-link:hover{border-color:var(--gold);color:var(--gold);}
.footer-heading{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--text);margin-bottom:20px;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:11px;}
.footer-links a{font-size:13px;font-weight:300;color:var(--muted);text-decoration:none;cursor:none;transition:color 0.2s;}
.footer-links a:hover{color:var(--gold);}
.footer-bottom{border-top:1px solid var(--border);padding-top:26px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.footer-copy{font-size:12px;color:var(--text3);}
.fade-up{opacity:0;transform:translateY(28px);transition:opacity 0.75s ease,transform 0.75s ease;}
.fade-up.visible{opacity:1;transform:translateY(0);}
@media(max-width:900px){
  nav{padding:0 24px;}nav.scrolled{padding:14px 24px;}.nav-links{display:none;}
  .page-header{padding:120px 24px 60px;}
  .contact-section{padding:80px 24px;}
  .contact-grid{grid-template-columns:1fr;}
  .contact-sidebar{position:static;}
  .form-row.two-col{grid-template-columns:1fr;}
  footer{padding:56px 24px 28px;}.footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
