/* ---------- TOKENS ---------- */
:root{
  --ink:#111111;
  --ink-soft:#2a2a2a;
  --paper:#f4f1ea;
  --paper-2:#ebe6d9;
  --rule:#1a1a1a;
  --muted:#5a5a55;
  --accent:#ffcb05;        /* hazard yellow — signature for car-park sector */
  --accent-2:#1a1a1a;
  --red:#b3261e;
  --green:#2f6f3e;
  --amber:#c98410;
  --serif:'Fraunces', 'Times New Roman', Georgia, serif;
  --sans:'Inter Tight','Inter', system-ui, -apple-system, sans-serif;
  --mono:'JetBrains Mono','SF Mono', Menlo, monospace;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-feature-settings:"ss01","cv11";
}
a{color:inherit}
.serif{font-family:var(--serif);font-optical-sizing:auto;letter-spacing:-0.02em}
.mono{font-family:var(--mono)}

/* ---------- TOPBAR ---------- */
.topbar{
  border-bottom:1px solid var(--rule);
  background:var(--ink);
  color:var(--paper);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
}
.topbar-inner{
  max-width:1400px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 32px;
  gap:24px;
}
.topbar a{color:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:8px}
.topbar a:hover{color:var(--accent)}
.topbar-right{display:flex;gap:24px;align-items:center}
.dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}
@media(max-width:760px){.topbar-right span:first-child{display:none}}

/* ---------- NAV ---------- */
nav.primary{
  border-bottom:1px solid var(--rule);
  background:var(--paper);
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(140%) blur(6px);
}
.nav-inner{
  max-width:1400px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 32px;
  gap:24px;
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--ink)}
.brand-mark{
  width:40px;height:40px;
  background:var(--ink);color:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:22px;font-style:italic;
  border:2px solid var(--ink);
  flex-shrink:0;
}
.brand-text{font-family:var(--serif);font-weight:500;font-size:17px;line-height:1.05}
.brand-text em{font-style:italic;font-weight:400}
.brand-text small{display:block;font-family:var(--mono);font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);margin-top:3px;font-style:normal}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:var(--ink);text-decoration:none;font-size:13px;font-weight:500;letter-spacing:0.01em}
.nav-links a:hover{text-decoration:underline;text-underline-offset:6px;text-decoration-thickness:1px}
.cta{
  background:var(--ink);color:var(--paper);
  padding:11px 20px;font-size:11px;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;border:1px solid var(--ink);
  transition:all .2s ease;
  font-weight:500;
}
.cta:hover{background:var(--accent);color:var(--ink)}
@media(max-width:880px){
  .nav-links a:not(.cta){display:none}
}

/* ---------- HERO ---------- */
.hero{
  border-bottom:1px solid var(--rule);
  position:relative;
  overflow:hidden;
}
.hero-grid{
  max-width:1400px;margin:0 auto;
  display:grid;grid-template-columns:1.4fr 1fr;
  min-height:78vh;
}
.hero-left{
  padding:80px 32px 56px;
  border-right:1px solid var(--rule);
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;
}
.eyebrow{
  font-family:var(--mono);
  font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);
  margin-bottom:36px;
  display:flex;align-items:center;gap:14px;
}
.eyebrow::before{content:"";width:36px;height:1px;background:var(--ink)}
h1{
  font-family:var(--serif);
  font-weight:300;
  font-size:clamp(42px,6.4vw,92px);
  line-height:0.96;
  letter-spacing:-0.035em;
  margin-bottom:36px;
}
h1 em{font-style:italic;font-weight:400}
.hero-sub{
  font-size:18px;color:var(--ink-soft);
  max-width:560px;margin-bottom:44px;line-height:1.55;
}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn-primary{
  background:var(--ink);color:var(--paper);
  padding:17px 30px;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;border:1px solid var(--ink);font-weight:500;
  display:inline-flex;align-items:center;gap:10px;
  transition:all .2s ease;
}
.btn-primary:hover{background:var(--accent);color:var(--ink)}
.btn-secondary{
  background:transparent;color:var(--ink);
  padding:17px 30px;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;border:1px solid var(--ink);font-weight:500;
  transition:all .2s ease;
}
.btn-secondary:hover{background:var(--ink);color:var(--paper)}

.hero-meta{
  margin-top:60px;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:24px;
  border-top:1px solid var(--rule);
  padding-top:28px;
}
.hero-meta div{font-size:13px}
.hero-meta strong{
  font-family:var(--serif);font-weight:400;
  font-size:34px;display:block;line-height:1;margin-bottom:8px;letter-spacing:-0.02em;
}
.hero-meta span{color:var(--muted);font-size:10px;letter-spacing:0.14em;text-transform:uppercase}

/* hero right — schematic */
.hero-right{
  background:var(--paper-2);
  position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:40px;
}
.hero-right svg{width:100%;max-width:460px;height:auto}
.hero-tag{
  position:absolute;top:24px;right:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted);
}
.hero-tag-bottom{
  position:absolute;bottom:24px;left:24px;right:24px;
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--muted);
  display:flex;justify-content:space-between;
}

@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;min-height:auto}
  .hero-left{border-right:0;border-bottom:1px solid var(--rule);padding:56px 24px 48px}
  .hero-right{padding:40px 24px;min-height:300px}
  .hero-meta{grid-template-columns:1fr 1fr}
}

/* ---------- SECTIONS ---------- */
section{border-bottom:1px solid var(--rule)}
.wrap{max-width:1400px;margin:0 auto;padding:96px 32px}
.section-head{
  display:grid;grid-template-columns:200px 1fr;
  gap:48px;margin-bottom:64px;
  align-items:end;
}
.section-num{
  font-family:var(--mono);font-size:11px;letter-spacing:0.22em;text-transform:uppercase;
  color:var(--muted);
}
.section-num span{display:block;color:var(--ink);margin-top:8px;font-size:10px}
h2{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(34px,4.6vw,64px);
  line-height:1.02;letter-spacing:-0.025em;
  max-width:900px;
}
h2 em{font-style:italic;font-weight:400}
.lede{
  font-size:18px;color:var(--ink-soft);max-width:760px;line-height:1.55;
  margin-top:24px;
}
@media(max-width:880px){
  .section-head{grid-template-columns:1fr;gap:24px}
  .wrap{padding:72px 24px}
}

/* ---------- ABOUT BLOCK ---------- */
#about .about-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
}
.about-list{display:flex;flex-direction:column;gap:0}
.about-list li{
  list-style:none;
  display:grid;grid-template-columns:32px 1fr;gap:20px;
  padding:24px 0;
  border-top:1px solid var(--rule);
}
.about-list li:last-child{border-bottom:1px solid var(--rule)}
.about-list .num{font-family:var(--mono);font-size:11px;color:var(--muted);padding-top:4px;letter-spacing:0.1em}
.about-list strong{font-family:var(--serif);font-weight:500;font-size:20px;display:block;margin-bottom:6px;letter-spacing:-0.01em}
.about-list p{color:var(--ink-soft);font-size:15px;line-height:1.55}
.badge-block{
  background:var(--ink);color:var(--paper);
  padding:48px;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:380px;position:relative;overflow:hidden;
}
.badge-block::after{
  content:"";position:absolute;right:-80px;bottom:-80px;
  width:300px;height:300px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,203,5,.18), transparent 70%);
}
.badge-block .accent-tag{
  display:inline-block;padding:6px 12px;border:1px solid var(--accent);color:var(--accent);
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  width:fit-content;
}
.badge-block h3{
  font-family:var(--serif);font-weight:300;
  font-size:42px;line-height:1.05;letter-spacing:-0.02em;
  margin:32px 0 16px;
}
.badge-block h3 em{font-style:italic;color:var(--accent)}
.badge-block p{color:#cfcdc4;font-size:15px;max-width:380px;line-height:1.55}
.badge-block .stamp{
  margin-top:auto;display:flex;align-items:center;gap:14px;
  padding-top:32px;border-top:1px solid #333;
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:#a8a59c;
}
.stamp-mark{
  width:42px;height:42px;border:1px solid var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-size:18px;color:var(--accent);font-style:italic;
}
@media(max-width:880px){
  #about .about-grid{grid-template-columns:1fr;gap:40px}
  .badge-block{padding:36px;min-height:auto}
}

/* ---------- SURFACES ---------- */
.surfaces{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-top:1px solid var(--rule)}
.surface-item{
  padding:36px 32px;border-bottom:1px solid var(--rule);
  display:grid;grid-template-columns:80px 1fr;gap:20px;
  position:relative;transition:background .25s;
}
.surface-item:nth-child(odd){border-right:1px solid var(--rule)}
.surface-item:hover{background:var(--paper-2)}
.surface-num{
  font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:0.14em;
  padding-top:6px;
}
.surface-num strong{display:block;color:var(--ink);font-size:10px;margin-top:4px;letter-spacing:0.18em}
.surface-item h4{
  font-family:var(--serif);font-weight:500;font-size:22px;margin-bottom:10px;letter-spacing:-0.01em;
}
.surface-item p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}
@media(max-width:880px){
  .surfaces{grid-template-columns:1fr}
  .surface-item:nth-child(odd){border-right:0}
}

/* ---------- RISK GRID ---------- */
.risk-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.risk-card{
  padding:32px 28px;
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--paper);position:relative;
}
.risk-card::before{
  content:"";position:absolute;top:0;left:0;height:3px;width:0;background:var(--accent);
  transition:width .35s ease;
}
.risk-card:hover::before{width:100%}
.risk-card h4{
  font-family:var(--serif);font-weight:500;font-size:20px;margin-bottom:14px;letter-spacing:-0.01em;
  padding-right:10px;
}
.risk-card p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}
.risk-card .risk-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);
  margin-bottom:14px;display:block;
}
@media(max-width:980px){.risk-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.risk-grid{grid-template-columns:1fr}}

/* ---------- PROCESS ---------- */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:0;border-top:1px solid var(--rule)}
.step{
  padding:36px 28px;
  border-right:1px solid var(--rule);
  position:relative;min-height:280px;
  display:flex;flex-direction:column;
}
.step:last-child{border-right:0}
.step-num{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:64px;line-height:1;letter-spacing:-0.04em;
  margin-bottom:24px;color:var(--ink);
}
.step-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--muted);margin-bottom:14px;
}
.step h4{font-family:var(--serif);font-weight:500;font-size:19px;margin-bottom:12px;letter-spacing:-0.01em}
.step p{font-size:14px;color:var(--ink-soft);line-height:1.55}
@media(max-width:1100px){
  .process{grid-template-columns:repeat(2,1fr)}
  .step{border-right:1px solid var(--rule);border-bottom:1px solid var(--rule)}
  .step:nth-child(2n){border-right:0}
}
@media(max-width:520px){.process{grid-template-columns:1fr}.step{border-right:0!important}}

/* ---------- LOCATIONS ---------- */
.location-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.loc-card{
  padding:28px 24px;
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  text-decoration:none;color:var(--ink);
  background:var(--paper);
  transition:background .2s;
  display:flex;flex-direction:column;justify-content:space-between;
  min-height:180px;
}
.loc-card:hover{background:var(--ink);color:var(--paper)}
.loc-card .loc-name{font-family:var(--serif);font-weight:500;font-size:24px;letter-spacing:-0.01em;margin-bottom:6px}
.loc-card .loc-name em{font-style:italic;font-weight:400}
.loc-card .loc-sub{font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.loc-card:hover .loc-sub{color:var(--accent)}
.loc-card .loc-arrow{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase}
@media(max-width:980px){.location-grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- FAQ ---------- */
.faq-grid{display:grid;grid-template-columns:1fr 2fr;gap:64px}
.faq-toc{position:sticky;top:120px;align-self:start}
.faq-toc h5{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.faq-toc ul{list-style:none}
.faq-toc li{padding:10px 0;border-bottom:1px solid var(--rule)}
.faq-toc li:first-child{border-top:1px solid var(--rule)}
.faq-toc a{font-family:var(--serif);font-style:italic;font-size:18px;text-decoration:none;color:var(--ink)}
.faq-toc a:hover{color:var(--muted)}
.faq-list{display:flex;flex-direction:column;gap:0}
.faq-item{padding:36px 0;border-bottom:1px solid var(--rule)}
.faq-item:first-child{border-top:1px solid var(--rule)}
.faq-item h4{font-family:var(--serif);font-weight:500;font-size:26px;line-height:1.15;margin-bottom:18px;letter-spacing:-0.01em}
.faq-item h4 em{font-style:italic;font-weight:400}
.faq-item p{font-size:16px;color:var(--ink-soft);line-height:1.6;max-width:680px}
.faq-item p strong{color:var(--ink);font-weight:600}
@media(max-width:880px){.faq-grid{grid-template-columns:1fr;gap:32px}.faq-toc{position:static}}

/* ---------- ENQUIRY ---------- */
.enquiry{background:var(--ink);color:var(--paper);border-bottom:0}
.enquiry .wrap{padding-top:96px;padding-bottom:96px}
.enquiry h2{color:var(--paper)}
.enquiry h2 em{color:var(--accent)}
.enquiry .lede{color:#cfcdc4}
.enquiry-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;margin-top:48px}
.form-block{display:flex;flex-direction:column;gap:18px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-block label{display:flex;flex-direction:column;gap:8px;font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:#a8a59c}
.form-block input,.form-block textarea,.form-block select{
  background:transparent;border:0;border-bottom:1px solid #444;color:var(--paper);
  font-family:var(--sans);font-size:16px;padding:10px 0;
  outline:none;transition:border-color .2s;
}
.form-block input:focus,.form-block textarea:focus,.form-block select:focus{border-bottom-color:var(--accent)}
.form-block textarea{resize:vertical;min-height:90px}
.form-block select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--accent) 50%),linear-gradient(135deg, var(--accent) 50%, transparent 50%);background-position:calc(100% - 18px) center,calc(100% - 12px) center;background-size:6px 6px,6px 6px;background-repeat:no-repeat;cursor:pointer}
.form-block select option{background:var(--ink);color:var(--paper)}
.submit-row{margin-top:14px}
.submit-row button{
  background:var(--accent);color:var(--ink);border:0;padding:18px 32px;
  font-family:var(--sans);font-size:12px;letter-spacing:0.16em;text-transform:uppercase;font-weight:600;
  cursor:pointer;transition:background .2s;
}
.submit-row button:hover{background:var(--paper)}
.contact-card{display:flex;flex-direction:column;gap:32px}
.contact-card h5{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:#a8a59c;margin-bottom:10px}
.contact-card a{color:var(--paper);font-family:var(--serif);font-size:24px;text-decoration:none;letter-spacing:-0.01em}
.contact-card a:hover{color:var(--accent)}
.contact-card p{color:#cfcdc4;font-size:14px;line-height:1.55;max-width:320px}
@media(max-width:880px){
  .enquiry-grid{grid-template-columns:1fr;gap:48px}
  .form-row{grid-template-columns:1fr}
}

/* ---------- FOOTER ---------- */
footer{background:var(--paper-2);border-top:1px solid var(--rule)}
.foot-inner{max-width:1400px;margin:0 auto;padding:64px 32px 32px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.foot-brand{max-width:380px}
.foot-brand p{color:var(--muted);font-size:14px;margin-top:18px;line-height:1.55}
footer h6{font-family:var(--mono);font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
footer ul{list-style:none}
footer ul li{padding:6px 0}
footer ul a{color:var(--ink);text-decoration:none;font-size:14px}
footer ul a:hover{text-decoration:underline;text-underline-offset:4px}
.foot-bottom{
  border-top:1px solid var(--rule);max-width:1400px;margin:0 auto;
  padding:24px 32px;display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);
  flex-wrap:wrap;gap:14px;
}
.foot-bottom em{font-style:italic;font-family:var(--serif);text-transform:none;letter-spacing:0;color:var(--ink-soft)}
@media(max-width:880px){
  .foot-inner{grid-template-columns:1fr 1fr;gap:36px}
}
@media(max-width:520px){
  .foot-inner{grid-template-columns:1fr}
}

/* ---------- LOCATION DETAIL PAGE ---------- */
.crumb{
  font-family:var(--mono);font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);
  display:block;margin-bottom:36px;text-decoration:none;
}
.crumb strong{color:var(--ink)}
.facts{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  margin-top:48px;
}
.fact{
  padding:24px 28px;border-right:1px solid var(--rule);
}
.fact:last-child{border-right:0}
.fact .k{font-family:var(--mono);font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.fact .v{font-family:var(--serif);font-weight:400;font-size:24px;letter-spacing:-0.01em}
@media(max-width:880px){.facts{grid-template-columns:1fr 1fr}}


/* ---------- ZOHO FORM WRAPPER ---------- */
.zoho-frame{
  background:var(--paper);
  padding:8px;
  border:1px solid #333;
  position:relative;
  overflow:hidden;
}
.zoho-frame::before{
  content:"FORM · ZOHO SECURE";
  position:absolute;top:-10px;left:16px;
  background:var(--ink);color:var(--accent);
  padding:2px 10px;font-family:var(--mono);font-size:9px;letter-spacing:0.18em;
}
.zoho-frame iframe{
  display:block;width:100%;
  border-radius:0;
}
@media(max-width:880px){
  .zoho-frame iframe{height:640px !important}
}
