/* Aspect Global Art - prototype build v1.0 */
:root{
  --ground:#FBFAF7;
  --band:#F1EFEA;
  --wall:#ECE9E2;
  --ink:#171511;
  --mid:#6E6A62;
  --rule:#DDD9D1;
  --orange:#F85120;
  --mount:#FDFCFA;
  --max:1080px;
  --measure:64ch;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}}
body{
  background:var(--ground);
  color:var(--ink);
  font-family:"Public Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--ink)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--ink);outline-offset:3px;
}
.skip{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:.5rem 1rem;z-index:50}
.skip:focus{left:0}

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

/* ---------- header ---------- */
header.site{
  border-bottom:1px solid var(--rule);
  background:var(--ground);
}
.bar{display:flex;align-items:center;justify-content:space-between;min-height:76px;gap:24px}
.wordmark{font-family:"Public Sans";font-weight:600;font-size:15px;letter-spacing:.32em;text-decoration:none;white-space:nowrap}
.wordmark .g{color:var(--mid);font-weight:500}
.wordmark .dot{color:var(--orange)}
h1 .dot,h2 .dot{color:var(--orange)}
nav.main{display:flex;align-items:center;gap:26px}
nav.main a{font-size:13.5px;letter-spacing:.02em;text-decoration:none;color:var(--ink);padding:6px 0;border-bottom:1.5px solid transparent}
nav.main a:hover{border-bottom-color:var(--rule)}
nav.main a[aria-current="page"]{border-bottom-color:var(--ink)}
nav.main a.navbtn{border:1px solid var(--ink);padding:9px 18px;border-bottom-width:1px}
nav.main a.navbtn:hover{background:var(--ink);color:#fff;border-bottom-color:var(--ink)}
.menu-toggle{display:none;background:none;border:1px solid var(--ink);padding:8px 14px;font:inherit;font-size:13px;letter-spacing:.08em;cursor:pointer}
@media (max-width:900px){
  .menu-toggle{display:block}
  nav.main{display:none;position:absolute;left:0;right:0;top:76px;background:var(--ground);
    border-bottom:1px solid var(--rule);flex-direction:column;align-items:stretch;gap:0;z-index:40;padding:8px 28px 20px}
  nav.main.open{display:flex}
  nav.main a{padding:13px 0;border-bottom:1px solid var(--rule);font-size:15px}
  nav.main a.navbtn{margin-top:14px;text-align:center}
  header.site{position:relative}
}

/* ---------- type ---------- */
h1,h2,h3,.display{font-family:"Libre Caslon Display","Libre Caslon Text",Georgia,serif;font-weight:400;line-height:1.12;letter-spacing:.002em}
h1{font-size:clamp(2.3rem,4.6vw,3.7rem)}
h2{font-size:clamp(1.7rem,3vw,2.35rem);line-height:1.18}
h3{font-size:1.32rem;line-height:1.3}
.sub{font-size:1.16rem;color:var(--mid);max-width:var(--measure);margin-top:18px;line-height:1.6}
p{max-width:var(--measure)}
.eyebrow{display:flex;align-items:center;gap:10px;font-size:11.5px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);margin-bottom:22px}
.eyebrow::before{content:"";width:10px;height:10px;border-left:1.5px solid var(--ink);border-top:1.5px solid var(--ink);transform:translateY(2px)}
.caption{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);margin-top:12px}

/* ---------- sections ---------- */
section{padding:92px 0}
section + section{border-top:1px solid var(--rule)}
section.band{background:var(--band);border-top:1px solid var(--rule)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
@media (max-width:820px){.split{grid-template-columns:1fr;gap:36px}}
.stack > * + *{margin-top:16px}
.lede{font-size:1.12rem}

/* hero */
.hero{padding:110px 0 118px}
.hero .split{grid-template-columns:1.15fr .85fr}
@media (max-width:820px){.hero{padding:72px 0}.hero .split{grid-template-columns:1fr}}
.hero-actions{display:flex;align-items:center;gap:26px;margin-top:38px;flex-wrap:wrap}

/* buttons */
.btn{display:inline-block;text-decoration:none;font-size:13.5px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  padding:16px 30px;border:1px solid transparent;cursor:pointer;font-family:inherit}
.btn-orange{background:var(--orange);color:#fff}
.btn-orange:hover{background:#D94315}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#000}
.btn-line{background:none;border-color:var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff}
.textlink{font-size:14px;font-weight:600;letter-spacing:.04em;text-decoration:none;border-bottom:1.5px solid var(--ink);padding-bottom:2px}
.textlink:hover{border-bottom-color:var(--orange)}
@media (max-width:600px){.btn{display:block;text-align:center}}

/* process */
.stages{margin-top:8px}
.stage{display:grid;grid-template-columns:96px 1fr;gap:28px;padding:34px 0;border-top:1px solid var(--rule);align-items:baseline}
.stage:last-child{border-bottom:1px solid var(--rule)}
.roman{font-family:"Libre Caslon Display",Georgia,serif;font-size:2rem;line-height:1}
.roman.accent{color:var(--orange)}
.stage h3{margin-bottom:6px}
@media (max-width:600px){.stage{grid-template-columns:56px 1fr;gap:18px}}
.stripfive{display:flex;gap:0;flex-wrap:wrap;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-top:34px}
.stripfive div{flex:1 1 120px;padding:22px 8px;text-align:center;border-right:1px solid var(--rule)}
.stripfive div:last-child{border-right:none}
.stripfive .roman{font-size:1.4rem;display:block;margin-bottom:6px}
.stripfive span{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid)}

/* inclusions list */
.inclusions{display:grid;grid-template-columns:1fr 1fr;gap:0 56px;max-width:820px;margin-top:8px;list-style:none}
.inclusions li{padding:15px 0;border-bottom:1px solid var(--rule);font-size:15.5px}
@media (max-width:680px){.inclusions{grid-template-columns:1fr}}

/* routes */
.route{padding:72px 0 40px}
.route + .route{border-top:1px solid var(--rule)}
.routes-3{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:44px}
@media (max-width:820px){.routes-3{grid-template-columns:1fr}}
.routes-3 h3{margin-top:18px}
.routes-3 p{font-size:15px;color:var(--mid);margin-top:6px}

/* composition figures */
figure.comp{margin:0}
figure.comp svg{width:100%;height:auto;display:block;border:1px solid var(--rule)}
figure.comp.hero{max-width:60%;margin:0 auto}
figure.comp.hero img{margin:0 auto;width:100%;display:block}

/* footer */
footer.site{border-top:1px solid var(--rule);background:var(--band);padding:64px 0 40px;margin-top:0}
.fcols{display:grid;grid-template-columns:1fr 1fr 1.4fr;gap:40px}
@media (max-width:820px){.fcols{grid-template-columns:1fr}}
.fcols h4{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mid);margin-bottom:16px;font-weight:600}
.fcols ul{list-style:none}
.fcols li{margin-bottom:9px}
.fcols a{font-size:14px;text-decoration:none}
.fcols a:hover{border-bottom:1px solid var(--ink)}
.fcols p{font-size:14px;color:var(--mid)}
.legal{margin-top:48px;padding-top:22px;border-top:1px solid var(--rule);font-size:12.5px;color:var(--mid)}

/* tables (notices / sponsorship) */
table.rates{border-collapse:collapse;width:100%;max-width:760px;margin:10px 0 6px;font-size:15px}
table.rates th,table.rates td{border:1px solid var(--rule);padding:12px 16px;text-align:left;vertical-align:top}
table.rates th{background:var(--band);font-weight:600;font-size:13px;letter-spacing:.06em;text-transform:uppercase}
.smallnote{font-size:13.5px;color:var(--mid);font-style:italic}

/* prose pages */
.prose h2{margin:54px 0 16px;font-size:1.55rem}
.prose h2:first-of-type{margin-top:0}
.prose p{margin-bottom:16px}
.prose ul{margin:0 0 16px 22px;max-width:var(--measure)}
.prose li{margin-bottom:8px}

/* contact form */
form.enquiry{max-width:620px;margin-top:8px}
.field{margin-bottom:22px}
.field label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);margin-bottom:8px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 14px;border:1px solid var(--ink);background:#fff;font:inherit;font-size:15.5px;border-radius:0;color:var(--ink)}
.field textarea{min-height:140px;resize:vertical}
.form-note{font-size:13.5px;color:var(--mid);margin-top:18px}
.received{border:1px solid var(--ink);padding:28px;max-width:620px;font-size:1.05rem;display:none}

/* hero line drawing */
.framedraw{justify-self:end;width:100%;max-width:420px}
@media (max-width:820px){.framedraw{max-width:300px;justify-self:start}}
