
:root{
  --deep-teal:#0F4C45; --teal:#0F6E56; --gold:#C9A227; --gold-light:#E8C766;
  --cream:#F4F1EA; --ink:#1A1A1A; --dark:#16302A;
  --max:1100px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Spectral',Georgia,serif;font-size:1.0625rem;line-height:1.7;color:var(--ink);background:var(--cream)}
h1,h2,h3,.jost{font-family:'Jost',system-ui,sans-serif}
img,svg{display:block}
a{color:var(--teal)}
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}

/* eyebrow labels — board vernacular */
.eyebrow{font-family:'Jost',sans-serif;font-size:.75rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.on-teal .eyebrow{color:var(--gold-light)}

/* nav */
header{background:var(--cream);border-bottom:1px solid rgba(17,76,72,.12)}
nav{max-width:var(--max);margin:0 auto;padding:18px 24px;display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand span{font-family:'Jost',sans-serif;font-weight:400;font-size:1.45rem;letter-spacing:.01em;color:var(--ink)}
.navlinks{display:flex;gap:30px;align-items:center;list-style:none}
.navlinks a{font-family:'Jost',sans-serif;font-weight:400;font-size:.95rem;text-decoration:none;color:var(--ink);white-space:nowrap}
.navlinks a:hover{color:var(--teal)}
.navlinks a.cta{background:var(--deep-teal);color:var(--cream);padding:9px 20px;border-radius:3px}
.navlinks a.cta:hover{background:var(--teal);color:var(--cream)}
#navtoggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
#navtoggle span{display:block;width:24px;height:2px;background:var(--ink);margin:5px 0}

/* hero */
.hero{position:relative;overflow:hidden;background:var(--deep-teal);color:var(--cream);padding:84px 0 0}
.hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(58% 70% at 86% 30%, rgba(232,199,102,.16), transparent 60%),
            radial-gradient(50% 60% at 0% 100%, rgba(15,110,86,.5), transparent 60%)}
.hero>.wrap{position:relative;z-index:1}
.hero-main{display:grid;grid-template-columns:1fr auto;gap:56px;align-items:center;padding-bottom:72px}
.hero-eyebrow{font-family:'Jost',sans-serif;font-size:.74rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-light);margin-bottom:22px}
.hero h1{font-weight:300;font-size:clamp(3.4rem,8.4vw,6rem);letter-spacing:.004em;line-height:1.02;color:var(--cream)}
.hero h1 b{font-weight:400}
.hero .lead{font-style:italic;font-size:clamp(1.18rem,2.4vw,1.5rem);color:var(--gold-light);margin:22px 0 38px;max-width:44ch;line-height:1.45}
.btnrow{display:flex;gap:16px;flex-wrap:wrap}
.hero-mark-wrap{display:flex;align-items:center;justify-content:center}
.cairn-hero{width:min(228px,30vw);height:auto;filter:drop-shadow(0 18px 40px rgba(0,0,0,.28))}
.hero-meta{display:flex;flex-wrap:wrap;gap:14px 48px;padding:24px 24px 26px;border-top:1px solid rgba(232,199,102,.24)}
.hero-meta span{font-family:'Jost',sans-serif;font-size:.92rem;color:rgba(245,241,232,.82);letter-spacing:.01em}
.hero-meta b{font-weight:500;color:var(--gold-light)}
.btn.gold{background:var(--gold);color:var(--ink)}
.btn.gold:hover{background:var(--gold-light)}
.btn.line{border:1px solid rgba(245,241,232,.5);color:var(--cream)}
.btn.line:hover{border-color:var(--cream)}
.btn{font-family:'Jost',sans-serif;font-weight:500;font-size:1rem;text-decoration:none;padding:13px 28px;border-radius:3px;display:inline-block;white-space:nowrap;line-height:1.2}

/* sections */
section{padding:88px 0}
.band-teal{background:var(--deep-teal);color:var(--cream)}
.band-teal h2,.band-teal h3{color:var(--cream)}
.band-teal .lead-it{color:var(--gold-light)}
h2{font-weight:400;font-size:clamp(1.7rem,3.6vw,2.4rem);color:var(--deep-teal);line-height:1.2;margin-bottom:18px;max-width:24ch}
h3{font-weight:500;font-size:1.25rem;color:var(--deep-teal);margin-bottom:10px}
p{max-width:62ch;margin-bottom:16px}
.lead-it{font-style:italic;font-size:1.2rem;color:var(--teal)}

.cols{display:grid;grid-template-columns:1fr 1fr;gap:56px;margin-top:36px}
.card{background:#fff;border:1px solid rgba(17,76,72,.1);border-radius:4px;padding:36px}
.band-teal .card{background:rgba(245,241,232,.06);border-color:rgba(245,241,232,.18)}
.band-teal .card h3{color:var(--gold-light)}
.band-teal .card p{color:var(--cream)}

.divider{display:flex;justify-content:center;gap:6px;padding:0 0 6px}
.steps{counter-reset:s;margin:28px 0;list-style:none}
.steps li{counter-increment:s;padding:18px 0 18px 64px;position:relative;border-top:1px solid rgba(17,76,72,.12);max-width:62ch}
.steps li::before{content:counter(s,decimal-leading-zero);position:absolute;left:0;top:16px;font-family:'Jost',sans-serif;font-weight:500;color:var(--gold);font-size:1.1rem;letter-spacing:.05em}
.note{font-size:.95rem;color:var(--teal);font-style:italic}

/* footer */
footer{background:var(--dark);color:var(--cream);padding:64px 0 40px;margin-top:0}
footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
footer .brand span{color:var(--cream)}
footer h4{font-family:'Jost',sans-serif;font-weight:500;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-light);margin-bottom:14px}
footer a{color:var(--cream);text-decoration:none;font-family:'Jost',sans-serif;font-size:.95rem}
footer a:hover{color:var(--gold-light)}
footer ul{list-style:none}
footer li{margin-bottom:8px}
.statutory{grid-column:1/-1;border-top:1px solid rgba(245,241,232,.18);margin-top:36px;padding-top:22px;font-family:'Jost',sans-serif;font-size:.82rem;color:var(--gold-light);letter-spacing:.02em}

/* legal pages */
.legal h1{font-weight:400;font-size:2.1rem;color:var(--deep-teal);margin-bottom:8px}
.legal .vmeta{font-family:'Jost',sans-serif;font-size:.85rem;color:var(--teal);margin-bottom:36px}
.legal h2{font-size:1.45rem;margin-top:44px}
.legal h3{margin-top:28px}
.legal ol,.legal ul{margin:0 0 16px 26px;max-width:60ch}
.legal li{margin-bottom:10px}

/* cookie banner */
#cookie{position:fixed;bottom:0;left:0;right:0;background:var(--dark);color:var(--cream);padding:16px 24px;display:none;z-index:50}
#cookie .wrap{display:flex;gap:20px;align-items:center;justify-content:space-between;flex-wrap:wrap}
#cookie p{margin:0;font-family:'Jost',sans-serif;font-size:.92rem;max-width:none}
#cookie button{font-family:'Jost',sans-serif;font-weight:500;padding:9px 20px;border-radius:3px;border:none;cursor:pointer}
#cookie .ok{background:var(--gold);color:var(--ink)}
#cookie .no{background:none;border:1px solid rgba(245,241,232,.5);color:var(--cream)}

/* pull quote */
.pullquote{margin:22px 0 26px;padding:4px 0 4px 26px;border-left:3px solid var(--gold);max-width:46ch}
.pullquote blockquote{margin:0;font-family:'Spectral',serif;font-style:italic;font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1.4;color:var(--cream)}
.band-teal .pullquote blockquote{color:var(--cream)}
.pullquote figcaption{margin-top:14px;font-family:'Jost',sans-serif;font-size:.78rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light)}
.pullquote .fc-org{display:block;margin-top:4px;font-weight:400;letter-spacing:.1em;color:rgba(245,241,232,.6)}
.pullquote-float{float:right;width:330px;max-width:42%;margin:4px 0 18px 52px}
.pullquote-float~.cols{clear:both}
@media (max-width:820px){
  .pullquote-float{float:none;width:auto;max-width:46ch;margin:18px 0 22px}
}

/* enquiry form */
.formcard{padding:32px}
.formcard h3{margin-bottom:18px}
.fld{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fld label{font-family:'Jost',sans-serif;font-size:.72rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--teal)}
.fld label .opt{text-transform:none;letter-spacing:0;color:var(--ink);opacity:.5;font-weight:400}
.fld input,.fld select,.fld textarea{font-family:'Jost',sans-serif;font-size:1rem;color:var(--ink);background:var(--cream);border:1px solid rgba(15,76,69,.22);border-radius:4px;padding:11px 13px;width:100%}
.fld textarea{min-height:96px;resize:vertical;line-height:1.55;font-family:'Spectral',serif}
.fld select{appearance:none;cursor:pointer;padding-right:34px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' fill='none' stroke='%230F6E56' stroke-width='1.6'/></svg>");background-repeat:no-repeat;background-position:right 13px center}
.fld input::placeholder,.fld textarea::placeholder{color:rgba(26,26,26,.4)}
.fld input:focus,.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.16)}
.fld .check{display:flex;gap:10px;align-items:flex-start;font-family:'Spectral',serif;font-size:.95rem;color:var(--ink);text-transform:none;letter-spacing:0;line-height:1.45;cursor:pointer}
.fld .check input{width:auto;margin-top:4px;accent-color:var(--teal)}
button.btn{border:none;cursor:pointer;font-family:'Jost',sans-serif}
.formcard button.btn{margin-top:6px}
.form-err{color:#9A2B1E;font-family:'Jost',sans-serif;font-size:.9rem;margin:12px 0 0}
.form-done{text-align:center;padding:18px 0 8px}
.form-done-mark{width:50px;height:auto;margin:0 auto 16px}
.form-done h3{margin-bottom:8px}
.form-done p{margin:0 auto;max-width:36ch}

/* motion */
@media (prefers-reduced-motion:no-preference){
  /* cairn builds from the base up, finishing with the gold capstone */
  .cairn-hero .stone{opacity:0;transform:translateY(-16px) scaleX(.9);transform-box:fill-box;transform-origin:center;animation:settle .52s cubic-bezier(.22,.9,.32,1.25) forwards}
  .cairn-hero .s1{animation-delay:.15s}.cairn-hero .s2{animation-delay:.45s}
  .cairn-hero .s3{animation-delay:.75s}
  .cairn-hero .s4{animation-delay:1.1s}
  .cairn-hero{animation:capglow 1s ease-out 1.25s 1}
  @keyframes settle{55%{opacity:1}to{opacity:1;transform:none}}
  @keyframes capglow{0%,40%{filter:none}58%{filter:drop-shadow(0 0 14px rgba(232,199,102,.85))}to{filter:none}}
}
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:2px}

@media (max-width:820px){
  .hero-main{grid-template-columns:1fr;gap:30px}
  .hero-mark-wrap{order:-1;justify-content:flex-start}
  .cairn-hero{order:-1;width:104px}
  .hero-meta{gap:10px 28px}
  .cols{grid-template-columns:1fr;gap:28px}
  footer .wrap{grid-template-columns:1fr;gap:28px}
  section{padding:60px 0}
  .hero{padding:60px 0 0}
  #navtoggle{display:block}
  .navlinks{display:none;position:absolute;top:64px;left:0;right:0;background:var(--cream);flex-direction:column;padding:18px 24px 26px;gap:16px;border-bottom:1px solid rgba(17,76,72,.15);z-index:40}
  .navlinks.open{display:flex}
  header{position:relative}
}
@media (max-width:560px){
  .fld-row{grid-template-columns:1fr;gap:0}
}
