/* ============================================================
   OLAS — application stylesheet
   Consumes the canonical tokens in olas-theme.css (single source
   of truth). No hard-coded brand colours; no inline styles
   anywhere in the HTML, so the CSP can drop 'unsafe-inline'.
   ============================================================ */

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth}
body{
  font-family:var(--font-sans);
  color:var(--text-primary);
  background:var(--bg);
  line-height:var(--leading-normal);
}
:where(a){color:inherit}
img,svg{display:block}

/* skip link — keyboard / screen-reader */
.skip{
  position:absolute;left:-9999px;top:0;z-index:50;
  background:var(--olas-navy);color:var(--mist-50);
  padding:12px 18px;border-radius:0 0 var(--radius-sm) 0;
  font-size:var(--text-sm);font-weight:var(--weight-medium);letter-spacing:.04em;
}
.skip:focus{left:0}

.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* ---- shared primitives ---- */
.wrap{max-width:1080px;margin:0 auto;padding:0 clamp(22px,5vw,48px)}
.wrap--doc{max-width:760px}
.eyebrow{font-size:11px;font-weight:var(--weight-semibold);letter-spacing:var(--tracking-eyebrow);text-transform:uppercase}
.serif{font-family:var(--font-serif);font-style:italic;font-weight:var(--weight-regular)}

/* the mark, inline; sized by context */
.mark{display:block}
.mark svg{width:100%;height:100%}
.mark--30{width:30px;height:30px}
.mark--26{width:26px;height:26px}
.mark--70{width:70px;height:70px}

/* ---- nav ---- */
.nav{position:absolute;top:0;left:0;right:0;z-index:5}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;align-items:center;gap:12px;color:var(--mist-50);text-decoration:none}
.brand .w{font-size:18px;font-weight:var(--weight-regular);letter-spacing:var(--tracking-wordmark);padding-left:var(--tracking-wordmark)}
.brand--footer{color:var(--mist-300)}
.brand--footer .mark{color:var(--steel-400)}

.req{
  color:var(--mist-50);text-decoration:none;font-size:12px;font-weight:var(--weight-medium);letter-spacing:.1em;
  border:1px solid rgba(174,197,209,.32);padding:9px 18px;border-radius:var(--radius-full);
  transition:background var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out);
}
.req:hover{background:rgba(255,255,255,.06)}
.req:focus-visible{outline:2px solid var(--steel-300);outline-offset:3px}

/* ---- buttons & links ---- */
.btn{
  background:var(--accent);color:var(--text-on-accent);text-decoration:none;border:0;cursor:pointer;
  font-family:inherit;font-size:14px;font-weight:var(--weight-semibold);letter-spacing:.02em;
  padding:15px 28px;border-radius:var(--radius-md);display:inline-block;
  transition:transform var(--dur-base) var(--ease-out),background var(--dur-base) var(--ease-out);
}
.btn:hover{background:var(--petrol-deep)}
.btn:focus-visible{outline:2px solid var(--steel-300);outline-offset:3px}
.btn[disabled]{opacity:.55;cursor:not-allowed}

.link{
  color:var(--mist-50);text-decoration:none;font-size:14px;font-weight:var(--weight-medium);letter-spacing:.04em;
  opacity:.85;border-bottom:1px solid transparent;padding-bottom:2px;
  transition:opacity var(--dur-base) var(--ease-out),border-color var(--dur-base) var(--ease-out);
}
.link:hover{border-bottom-color:var(--steel-400);opacity:1}
.link:focus-visible{outline:2px solid var(--steel-300);outline-offset:3px}

/* ---- hero (navy field, mark infused as watermark) ---- */
.hero{
  position:relative;overflow:hidden;min-height:100svh;display:flex;align-items:center;color:var(--mist-50);
  background:linear-gradient(157deg,#143049 0%,var(--olas-navy) 48%,var(--olas-navy-deep) 100%);
}
.fieldmark{position:absolute;pointer-events:none;color:var(--steel-300)}
.hero .fieldmark{right:-12%;top:50%;transform:translateY(-50%);width:min(880px,108%);opacity:.07}
.hero .wrap{position:relative;z-index:1;padding-top:84px;padding-bottom:64px}
.hero .eyebrow{color:var(--steel-400);margin-bottom:30px}
.hero h1{font-size:clamp(2.6rem,7vw,5rem);font-weight:var(--weight-light);line-height:1.04;letter-spacing:var(--tracking-display);max-width:16ch;color:#fff}
.hero h1 .serif{color:var(--mist-300)}
.hero .sub{font-size:clamp(1.05rem,2.4vw,1.3rem);color:var(--mist-300);max-width:46ch;margin-top:30px;font-weight:var(--weight-light);line-height:1.55}
.cta-row{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-top:44px}
.hero .marker{position:absolute;bottom:34px;left:0;right:0}
.hero .marker .wrap{padding-top:0;padding-bottom:0}
.hero .marker span{font-size:11px;letter-spacing:var(--tracking-eyebrow);color:var(--steel-400);text-transform:uppercase}

/* ---- light sections ---- */
.section{padding:clamp(72px,11vw,150px) 0}
.section--tight{padding-top:0}
.section .eyebrow{color:var(--steel-600);margin-bottom:26px}
.lede{font-size:clamp(1.5rem,3.6vw,2.5rem);font-weight:var(--weight-light);line-height:1.22;letter-spacing:-.02em;color:var(--olas-navy);max-width:20ch}
.lede .serif{color:var(--steel-600)}
.note{font-size:var(--text-base);color:var(--text-secondary);max-width:46ch;margin-top:26px;line-height:1.7}

/* the three — hairline separated, never boxed */
.trio{display:grid;grid-template-columns:1fr;gap:0;margin-top:56px;border-top:1px solid var(--border)}
.trio .col{padding:34px 0;border-bottom:1px solid var(--border)}
.trio .num{font-size:12px;letter-spacing:.18em;color:var(--accent);font-weight:var(--weight-semibold)}
.trio h3{font-size:1.35rem;font-weight:var(--weight-regular);color:var(--olas-navy);margin:14px 0 10px;letter-spacing:-.01em}
.trio p{font-size:.98rem;color:var(--text-secondary);line-height:1.65;max-width:34ch}
@media(min-width:760px){
  .trio{grid-template-columns:repeat(3,1fr)}
  .trio .col{padding:8px 38px 8px 0;border-bottom:0;border-right:1px solid var(--border)}
  .trio .col:last-child{border-right:0;padding-right:0}
}

/* convened — category row, no names */
.convened{background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.cats{display:flex;flex-wrap:wrap;gap:10px 0;margin-top:40px;align-items:center}
.cats span{font-family:var(--font-serif);font-style:italic;font-size:clamp(1.25rem,3vw,1.9rem);color:var(--steel-700)}
.cats i{color:var(--mist-300);font-style:normal;margin:0 16px}
.confidential{font-size:13px;letter-spacing:.04em;color:var(--mist-500);margin-top:34px}

/* how it works */
.steps{display:grid;grid-template-columns:1fr;gap:2px;margin-top:54px}
.step{padding:30px 0;border-top:1px solid var(--frame-hairline)}
.step .n{font-family:var(--font-serif);font-style:italic;font-size:1.6rem;color:var(--accent)}
.step h4{font-size:1.1rem;font-weight:var(--weight-medium);color:var(--olas-navy);margin:12px 0 8px}
.step p{font-size:.95rem;color:var(--text-secondary);line-height:1.6;max-width:32ch}
@media(min-width:760px){.steps{grid-template-columns:repeat(3,1fr);gap:28px}}

/* closing invitation — navy bookend */
.close{position:relative;overflow:hidden;color:var(--mist-50);text-align:center;background:linear-gradient(155deg,#143049,var(--olas-navy-deep))}
.close .fieldmark{left:50%;top:50%;transform:translate(-50%,-50%);width:min(720px,130%);opacity:.06}
.close .wrap{position:relative;z-index:1;padding:clamp(80px,12vw,160px) clamp(22px,5vw,48px);display:flex;flex-direction:column;align-items:center}
.close .crest{color:var(--steel-300);margin-bottom:34px;opacity:.9}
.close h2{font-size:clamp(1.9rem,5vw,3.2rem);font-weight:var(--weight-light);line-height:1.15;letter-spacing:-.02em;color:#fff;max-width:18ch}
.close h2 .serif{color:var(--mist-300)}
.close p{color:var(--mist-300);font-size:1.05rem;margin-top:24px;font-weight:var(--weight-light)}
.close .btn{margin-top:40px}

/* footer */
.foot{background:var(--olas-navy-deep);color:var(--mist-500);padding:54px 0}
.foot .wrap{display:flex;flex-direction:column;gap:24px}
.foot .meta{font-size:12px;letter-spacing:.06em;line-height:2.1;text-align:left}
.foot .meta a{color:var(--mist-500);text-decoration:none;border-bottom:1px solid transparent;transition:border-color var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out)}
.foot .meta a:hover{color:var(--mist-300);border-bottom-color:var(--steel-600)}
.foot .meta a:focus-visible{outline:2px solid var(--steel-500);outline-offset:2px}
.foot .svc{color:var(--steel-400)}
.foot .legal{margin-top:6px}
@media(min-width:680px){
  .foot .wrap{flex-direction:row;justify-content:space-between;align-items:flex-end}
  .foot .meta{text-align:right}
}

/* ============================================================
   REQUEST / ENQUIRY PAGE
   Luxe-light form on the room-to-breathe field; navy masthead
   ties it to the landing. Restrained asymmetry, hairline rules.
   ============================================================ */
.masthead{background:var(--olas-navy);position:relative;z-index:5}
.masthead .wrap{display:flex;align-items:center;justify-content:space-between;height:84px}
.masthead .back{color:var(--mist-300);text-decoration:none;font-size:13px;letter-spacing:.04em;border-bottom:1px solid transparent;transition:border-color var(--dur-base) var(--ease-out),color var(--dur-base) var(--ease-out)}
.masthead .back:hover{color:var(--mist-50);border-bottom-color:var(--steel-400)}
.masthead .back:focus-visible{outline:2px solid var(--steel-300);outline-offset:3px}

.request{position:relative;overflow:hidden;padding:clamp(56px,9vw,120px) 0}
.request .fieldmark{right:-22%;top:8%;width:min(720px,90%);opacity:.05;color:var(--steel-500)}
.request .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:clamp(40px,6vw,80px);align-items:start}
@media(min-width:900px){.request .wrap{grid-template-columns:0.85fr 1.15fr}}

.request .intro .eyebrow{color:var(--steel-600);margin-bottom:24px}
.request .intro h1{font-size:clamp(2rem,4.6vw,3.2rem);font-weight:var(--weight-light);line-height:1.12;letter-spacing:-.02em;color:var(--olas-navy);max-width:14ch}
.request .intro h1 .serif{color:var(--steel-600)}
.request .intro p{font-size:var(--text-base);color:var(--text-secondary);max-width:42ch;margin-top:24px;line-height:1.7}
.request .intro .reassure{margin-top:32px;padding-top:24px;border-top:1px solid var(--border);font-size:.95rem;color:var(--text-muted);max-width:40ch;line-height:1.65}
.enquiry-email{display:flex;flex-direction:column;align-items:flex-start;gap:20px}
.enquiry-email .note{margin-top:0;max-width:44ch}
.enquiry-email .formnote{margin-top:8px}

/* form card — paper-cool, hairline framed */
.card{background:var(--card-luxe);border:1px solid var(--frame-luxe);border-radius:var(--radius-lg);padding:clamp(28px,4vw,44px);box-shadow:var(--shadow-2)}

.form{display:flex;flex-direction:column;gap:22px}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-size:13px;font-weight:var(--weight-medium);letter-spacing:.02em;color:var(--olas-navy)}
.field .opt{color:var(--text-subtle);font-weight:var(--weight-regular);letter-spacing:.02em}
.field input,.field textarea{
  font-family:inherit;font-size:var(--text-base);color:var(--text-primary);
  background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-sm);
  padding:13px 15px;width:100%;line-height:1.5;
  transition:border-color var(--dur-base) var(--ease-out),box-shadow var(--dur-base) var(--ease-out);
}
.field textarea{min-height:108px;resize:vertical}
.field input::placeholder,.field textarea::placeholder{color:var(--text-subtle)}
.field input:hover,.field textarea:hover{border-color:var(--steel-400)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px var(--petrol-soft)}
.field input:focus-visible,.field textarea:focus-visible{outline:2px solid transparent}
.field input[aria-invalid="true"],.field textarea[aria-invalid="true"]{border-color:var(--danger);box-shadow:0 0 0 3px rgba(155,59,59,.12)}
.field .err{font-size:12px;color:var(--danger);min-height:0;letter-spacing:.01em}
.field-row{display:grid;grid-template-columns:1fr;gap:22px}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr}}

/* honeypot — visually & programmatically removed from real users */
.gotcha{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* consent — single, unticked, privacy notice beside it */
.consent{display:flex;gap:12px;align-items:flex-start;padding:18px;background:var(--surface-sunken);border:1px solid var(--border);border-radius:var(--radius-sm)}
.consent input[type="checkbox"]{
  appearance:none;-webkit-appearance:none;flex:0 0 auto;width:20px;height:20px;margin-top:1px;
  border:1.5px solid var(--steel-600);border-radius:5px;background:var(--surface);cursor:pointer;position:relative;
  transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out);
}
.consent input[type="checkbox"]:checked{background:var(--primary);border-color:var(--primary)}
.consent input[type="checkbox"]:checked::after{content:"";position:absolute;left:6px;top:2px;width:5px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.consent input[type="checkbox"]:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
.consent input[type="checkbox"][aria-invalid="true"]{border-color:var(--danger)}
.consent label{font-size:13.5px;color:var(--text-secondary);line-height:1.6;letter-spacing:.01em;cursor:pointer}
.consent a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}
.consent a:focus-visible{outline:2px solid var(--focus);outline-offset:2px}

.turnstile{min-height:0}

.submit-row{display:flex;flex-direction:column;gap:14px;margin-top:2px}
.formnote{font-size:12px;color:var(--text-muted);line-height:1.6;letter-spacing:.01em}
.formnote a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}

/* form status (aria-live) */
.status{font-size:13.5px;line-height:1.6;border-radius:var(--radius-sm);padding:0;letter-spacing:.01em}
.status[data-state="error"]{padding:14px 16px;background:rgba(155,59,59,.08);border:1px solid rgba(155,59,59,.3);color:#7d2f2f}
.status[data-state="sending"]{padding:14px 16px;background:var(--surface-sunken);border:1px solid var(--border);color:var(--text-secondary)}

/* success state — replaces the form in place */
.sent{display:flex;flex-direction:column;align-items:flex-start;gap:18px}
.sent .seal{color:var(--steel-500);opacity:.9}
.sent h2{font-size:clamp(1.5rem,3vw,2rem);font-weight:var(--weight-light);color:var(--olas-navy);letter-spacing:-.01em;line-height:1.2}
.sent h2 .serif{color:var(--steel-600)}
.sent p{font-size:var(--text-base);color:var(--text-secondary);line-height:1.7;max-width:40ch}
.is-hidden{display:none !important}

/* ============================================================
   DOCUMENT / LEGAL PAGES (privacy, terms, cookies, thank-you)
   ============================================================ */
.doc{padding:clamp(56px,8vw,110px) 0 clamp(64px,9vw,120px)}
.doc .draft{
  display:inline-block;font-size:11px;font-weight:var(--weight-semibold);letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--petrol-soft);background:var(--petrol-soft);
  padding:6px 12px;border-radius:var(--radius-full);margin-bottom:26px;
}
.doc .eyebrow{color:var(--steel-600);margin-bottom:18px}
.doc h1{font-size:clamp(2rem,4.4vw,3rem);font-weight:var(--weight-light);letter-spacing:-.02em;color:var(--olas-navy);line-height:1.12}
.doc .updated{font-size:13px;color:var(--text-muted);margin-top:16px;letter-spacing:.02em}
.doc .lead{font-size:var(--text-lg);color:var(--text-secondary);line-height:1.6;margin-top:28px;font-weight:var(--weight-light);max-width:60ch}
.doc h2{font-size:1.3rem;font-weight:var(--weight-medium);color:var(--olas-navy);margin:48px 0 14px;letter-spacing:-.01em}
.doc h3{font-size:1.05rem;font-weight:var(--weight-semibold);color:var(--olas-navy);margin:28px 0 8px}
.doc p,.doc li{font-size:var(--text-base);color:var(--text-secondary);line-height:1.75;max-width:66ch}
.doc p{margin-top:14px}
.doc ul,.doc ol{margin:12px 0 0 22px;display:flex;flex-direction:column;gap:8px}
.doc a{color:var(--primary);text-decoration:underline;text-underline-offset:2px}
.doc a:focus-visible{outline:2px solid var(--focus);outline-offset:2px}
.doc .hr{height:1px;background:var(--border);border:0;margin:44px 0}
.doc .rights{border-top:1px solid var(--border);padding-top:8px;margin-top:10px}
.doc dl{margin-top:14px;display:flex;flex-direction:column;gap:16px}
.doc dt{font-weight:var(--weight-semibold);color:var(--olas-navy);font-size:var(--text-base)}
.doc dd{color:var(--text-secondary);font-size:var(--text-base);line-height:1.7;margin-top:4px;max-width:62ch}

/* thank-you specific */
.thanks{min-height:62svh;display:flex;align-items:center}
.thanks .seal{color:var(--steel-500);opacity:.9;margin-bottom:30px}
.thanks h1{max-width:18ch}
.thanks .home{margin-top:36px;display:inline-block;font-size:14px;letter-spacing:.04em;color:var(--primary);text-decoration:none;border-bottom:1px solid var(--steel-300);padding-bottom:2px}
.thanks .home:hover{border-bottom-color:var(--primary)}
.thanks .home:focus-visible{outline:2px solid var(--focus);outline-offset:3px}
