@import url('https://fonts.googleapis.com/css2?family=Newsreader:opsz,wght@6..72,400;6..72,500;6..72,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

/* ============================================================
   A&O — bermudastructures.com  |  shared design system
   ============================================================ */

:root{
  /* navy scale */
  --ink:#15283f;          /* deepest — dark fields, primary text */
  --ink-2:#1d3553;
  --navy:#1F497D;         /* brief primary CTA navy */
  --navy-hover:#163961;
  --muted:#5a6a7c;        /* secondary text */
  --muted-2:#8493a2;

  /* warm paper neutrals */
  --paper:#FBFAF7;        /* page background */
  --paper-2:#F3EFE8;      /* tinted section */
  --card:#FFFFFF;
  --line:#E7E1D6;
  --line-soft:#F0EBE1;

  /* accent — muted Bermuda coral (default) */
  --accent:#C0654F;
  --accent-soft:#F3E3DD;
  --on-accent:#ffffff;

  /* type */
  --serif:'Newsreader', Georgia, 'Times New Roman', serif;
  --sans:'Hanken Grotesk', system-ui, -apple-system, sans-serif;
  --head:var(--serif);   /* headline family — toggleable */

  /* metrics */
  --maxw:1180px;
  --gut:clamp(20px,5vw,64px);
  --radius:4px;
  --shadow-sm:0 1px 2px rgba(21,40,63,.05), 0 2px 8px rgba(21,40,63,.04);
  --shadow:0 4px 14px rgba(21,40,63,.07), 0 18px 50px rgba(21,40,63,.06);
}

[data-accent="gold"]{ --accent:#A8853F; --accent-soft:#F1E9D6; }
[data-accent="teal"]{ --accent:#2E7C72; --accent-soft:#DCEAE7; }
[data-head="sans"]{ --head:var(--sans); }

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--sans); font-size:17px; line-height:1.6;
  font-weight:400; letter-spacing:.005em;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit;}

/* ---- typography ---- */
h1,h2,h3,h4{font-family:var(--head); font-weight:500; line-height:1.08; margin:0; letter-spacing:-.01em;}
[data-head="sans"] h1,[data-head="sans"] h2,[data-head="sans"] h3,[data-head="sans"] h4{font-weight:600; letter-spacing:-.02em;}
.display{font-size:clamp(40px,6vw,76px); line-height:1.02; letter-spacing:-.02em;}
h1{font-size:clamp(34px,4.6vw,58px);}
h2{font-size:clamp(28px,3.4vw,42px);}
h3{font-size:clamp(21px,2vw,27px);}
p{margin:0 0 1em;}
.lead{font-size:clamp(18px,1.5vw,21px); line-height:1.62; color:var(--ink-2);}
.eyebrow{font-family:var(--sans); font-weight:600; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent);}
.eyebrow.on-dark{color:#cdb4a9;}
em.cred{font-style:italic; font-family:var(--serif); color:var(--muted); font-size:15.5px;}

/* ---- layout ---- */
.wrap{max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut);}
.wrap-wide{max-width:1340px; margin:0 auto; padding-inline:var(--gut);}
section{position:relative;}
.pad{padding-block:clamp(64px,8vw,120px);}
.pad-sm{padding-block:clamp(44px,5vw,72px);}
.tint{background:var(--paper-2);}
.dark{background:var(--ink); color:#e8eaee;}
.dark h1,.dark h2,.dark h3{color:#fff;}
.dark .lead{color:#b9c2cd;}
.rule{height:1px; background:var(--line); border:0; margin:0;}

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:.6em; cursor:pointer;
  font-family:var(--sans); font-weight:600; font-size:16px; letter-spacing:.01em;
  padding:15px 26px; border-radius:var(--radius); border:1px solid transparent; white-space:nowrap;
  transition:transform .15s ease, background .2s ease, box-shadow .2s ease, color .2s; line-height:1;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--navy); color:#fff; box-shadow:0 1px 1px rgba(0,0,0,.12);}
.btn-primary:hover{background:var(--navy-hover);}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line);}
.btn-ghost:hover{border-color:var(--ink); }
.btn-ghost.on-dark{color:#fff; border-color:rgba(255,255,255,.32);}
.btn-ghost.on-dark:hover{border-color:#fff; background:rgba(255,255,255,.06);}
.btn-lg{padding:18px 32px; font-size:17px;}
.cal-ic{width:17px;height:17px;flex:none;}
.textlink{display:inline-flex; align-items:center; gap:.4em; color:var(--accent); font-weight:600; font-size:15px; border-bottom:1px solid transparent; transition:border-color .2s;}
.textlink:hover{border-color:var(--accent);}
.textlink .arr{transition:transform .2s;}
.textlink:hover .arr{transform:translateX(3px);}

/* ---- header / nav ---- */
.site-head{position:sticky; top:0; z-index:60; background:rgba(251,250,247,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line-soft);}
.nav{display:flex; align-items:center; justify-content:space-between; height:74px;}
.brand{display:flex; align-items:center; gap:12px;}
.brand img{height:38px; width:auto;}
.nav-links{display:flex; align-items:center; gap:34px; list-style:none; margin:0; padding:0;}
.nav-links a{font-size:15px; font-weight:500; color:var(--ink-2); letter-spacing:.01em; padding:6px 0; position:relative; transition:color .2s; white-space:nowrap;}
.nav-links a:hover{color:var(--ink);}
.nav-links a.active{color:var(--accent);}
.nav-links a.active::after{content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--accent);}
.nav-cta{display:flex; align-items:center; gap:18px;}
.nav-toggle{display:none; background:none; border:0; cursor:pointer; padding:8px; color:var(--ink);}
.nav-toggle svg{width:26px;height:26px;}
@media(max-width:980px){
  .nav-links{position:fixed; inset:74px 0 auto 0; flex-direction:column; align-items:flex-start; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:8px var(--gut) 20px; transform:translateY(-120%); transition:transform .32s cubic-bezier(.4,0,.1,1); box-shadow:var(--shadow);}
  .nav-links.open{transform:translateY(0);}
  .nav-links a{width:100%; padding:15px 0; border-bottom:1px solid var(--line-soft); font-size:17px;}
  .nav-links a.active::after{display:none;}
  .nav-toggle{display:block;}
  .nav-cta .btn-desktop{display:none;}
}

/* ---- footer ---- */
.site-foot{background:var(--ink); color:#aeb8c4; padding-block:64px 30px; font-size:14.5px;}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.1);}
.site-foot img.flogo{height:40px; margin-bottom:20px;}
.site-foot h4{font-family:var(--sans); font-weight:600; font-size:13px; letter-spacing:.14em; text-transform:uppercase; color:#7f8b99; margin-bottom:18px;}
.site-foot a:hover{color:#fff;}
.foot-links{list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px;}
.foot-bottom{display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; padding-top:24px; color:#73808e; font-size:13px;}
.foot-bottom a{color:#73808e;}
@media(max-width:760px){ .foot-grid{grid-template-columns:1fr; gap:36px;} }

/* ---- floating book button ---- */
.fab{position:fixed; right:22px; bottom:22px; z-index:80; display:inline-flex; align-items:center; gap:10px;
  background:var(--navy); color:#fff; font-family:var(--sans); font-weight:600; font-size:15.5px;
  padding:15px 22px; border-radius:50px; box-shadow:0 6px 22px rgba(21,40,63,.28), 0 2px 6px rgba(21,40,63,.2);
  transition:transform .2s ease, background .2s; cursor:pointer; border:0;}
.fab:hover{background:var(--navy-hover); transform:translateY(-2px);}
.fab svg{width:18px;height:18px;flex:none;}
@media(max-width:520px){ .fab{right:14px; bottom:14px; padding:14px 18px; font-size:14.5px;} .fab .fab-txt{display:inline;} }

/* ---- credibility bar ---- */
.credbar{background:var(--ink); color:#c5cdd8;}
.credbar .wrap{display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:10px 30px; padding-block:16px; font-size:13.5px; letter-spacing:.02em;}
.credbar b{color:#fff; font-weight:600;}
.credbar .sep{color:rgba(255,255,255,.28);}

/* ---- generic grid helpers ---- */
.grid{display:grid; gap:24px;}
.g-2{grid-template-columns:repeat(2,1fr);}
.g-3{grid-template-columns:repeat(3,1fr);}
@media(max-width:860px){ .g-3{grid-template-columns:1fr;} .g-2{grid-template-columns:1fr;} }

/* ---- cards ---- */
.card{background:var(--card); border:1px solid var(--line); border-radius:8px; padding:32px; box-shadow:var(--shadow-sm); transition:box-shadow .25s ease, transform .25s ease, border-color .25s;}
.card:hover{box-shadow:var(--shadow); transform:translateY(-3px); border-color:var(--line-soft);}

/* problem cards */
.pcard{display:flex; flex-direction:column; gap:18px; min-height:230px;}
.pcard .prob{font-family:var(--serif); font-size:20px; line-height:1.32; color:var(--ink);}
.pcard .ans{display:flex; align-items:flex-start; gap:10px; color:var(--muted); font-size:15.5px;}
.pcard .ans .tick{color:var(--accent); font-weight:700; flex:none;}
.pcard .textlink{margin-top:auto;}

/* pillar cards */
.pillar{display:flex; flex-direction:column; gap:14px;}
.pillar .pnum{font-family:var(--serif); font-size:15px; font-weight:500; color:var(--accent); letter-spacing:.04em; display:flex; align-items:center; gap:10px;}
.pillar .pnum::before{content:""; width:26px; height:1px; background:var(--accent);}
.pillar h3{margin-top:2px;}

/* ---- photo placeholders ---- */
.ph{position:relative; overflow:hidden; background:
  repeating-linear-gradient(135deg, #e9e3d8 0 14px, #efe9df 14px 28px);
  border:1px solid var(--line); border-radius:8px; display:flex; align-items:center; justify-content:center; color:#9a8f7d;}
.ph.dark-ph{background:repeating-linear-gradient(135deg,#1a3050 0 14px,#21385a 14px 28px); border-color:rgba(255,255,255,.12); color:#9fb0c6;}
.ph .ph-tag{font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; letter-spacing:.04em; text-transform:uppercase; text-align:center; padding:8px 14px; background:rgba(255,255,255,.6); border-radius:3px; backdrop-filter:blur(2px);}
.ph.dark-ph .ph-tag{background:rgba(10,22,40,.5); color:#bcccde;}

/* ---- forms ---- */
.field{display:flex; flex-direction:column; gap:7px; margin-bottom:18px;}
.field label{font-size:13px; font-weight:600; letter-spacing:.03em; color:var(--ink-2);}
.field label .req{color:var(--accent);}
.field input,.field select,.field textarea{
  font-family:var(--sans); font-size:16px; color:var(--ink); background:#fff;
  border:1px solid var(--line); border-radius:var(--radius); padding:13px 14px; transition:border-color .2s, box-shadow .2s;}
.field textarea{resize:vertical; min-height:110px;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none; border-color:var(--navy); box-shadow:0 0 0 3px rgba(31,73,125,.12);}
.field.err input,.field.err select{border-color:var(--accent); box-shadow:0 0 0 3px rgba(192,101,79,.12);}
.field .msg{font-size:12.5px; color:var(--accent); display:none;}
.field.err .msg{display:block;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px;}
@media(max-width:620px){ .form-row{grid-template-columns:1fr;} }

/* ---- form success ---- */
.form-success{background:var(--accent-soft); border:1px solid var(--accent); border-radius:8px; padding:34px 30px; text-align:center;}
.form-success .fs-tick{width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;}
.form-success h3{margin-bottom:8px;}
.form-success p{margin:0;color:var(--muted);}

/* ---- PDF lead-gate modal ---- */
#gate-modal{position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center; padding:24px; background:rgba(13,24,40,.55); backdrop-filter:blur(4px);}
#gate-modal.open{display:flex;}
.gate-card{background:#fff; border-radius:12px; max-width:480px; width:100%; box-shadow:var(--shadow); overflow:hidden; position:relative; animation:popin .28s cubic-bezier(.2,.8,.2,1);}
@keyframes popin{from{transform:translateY(12px) scale(.985);}to{transform:none;}}
.gate-card .gate-top{display:flex; gap:16px; align-items:flex-start; padding:28px 30px 18px;}
.gate-card .gate-ic{width:42px;height:54px;border-radius:3px;flex:none;background:linear-gradient(160deg,var(--accent),#9c4f3d);position:relative;box-shadow:var(--shadow-sm);}
.gate-card .gate-ic::after{content:"PDF";position:absolute;bottom:6px;left:0;right:0;text-align:center;color:#fff;font-family:ui-monospace,monospace;font-size:9px;letter-spacing:.1em;}
.gate-card h3{font-size:21px; line-height:1.2;}
.gate-card .gate-sub{font-size:14px;color:var(--muted);margin-top:5px;}
.gate-card form{padding:6px 30px 28px;}
.gate-x{position:absolute; top:14px; right:14px; background:none; border:0; font-size:18px; color:var(--muted-2); cursor:pointer; width:32px;height:32px;border-radius:50%;}
.gate-x:hover{background:var(--paper-2); color:var(--ink);}

/* ---- mock calendly ---- */
.cal-embed{background:#fff; border:1px solid var(--line); border-radius:12px; box-shadow:var(--shadow); overflow:hidden;}
.cal-top{display:flex; gap:16px; align-items:center; padding:22px 26px; border-bottom:1px solid var(--line-soft);}
.cal-avatar{width:54px;height:54px;border-radius:50%;flex:none;background:repeating-linear-gradient(135deg,#e9e3d8 0 8px,#efe9df 8px 16px);border:1px solid var(--line);}
.cal-top .cal-who b{display:block;font-family:var(--serif);font-size:18px;color:var(--ink);}
.cal-top .cal-who span{font-size:13.5px;color:var(--muted);}
.cal-top .cal-dur{margin-left:auto;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:7px;}
.cal-grid{display:grid; grid-template-columns:1.1fr 1fr; gap:0;}
@media(max-width:640px){ .cal-grid{grid-template-columns:1fr;} }
.cal-cal{padding:22px 26px; border-right:1px solid var(--line-soft);}
@media(max-width:640px){ .cal-cal{border-right:0; border-bottom:1px solid var(--line-soft);} }
.cal-month{display:flex; justify-content:space-between; align-items:center; margin-bottom:16px; font-weight:600; font-size:15px; white-space:nowrap; gap:10px;}
.cal-month button{background:none;border:1px solid var(--line);border-radius:6px;width:30px;height:30px;cursor:pointer;color:var(--ink);}
.cal-days{display:grid; grid-template-columns:repeat(7,1fr); gap:5px; font-size:13.5px;}
.cal-days .dow{color:var(--muted-2); font-size:11px; text-align:center; font-weight:600; letter-spacing:.04em; padding-bottom:4px;}
.cal-days .d{aspect-ratio:1; display:flex;align-items:center;justify-content:center;border-radius:50%; color:var(--muted-2);}
.cal-days .d.avail{color:var(--navy); font-weight:600; cursor:pointer; background:rgba(31,73,125,.07);}
.cal-days .d.avail:hover{background:rgba(31,73,125,.16);}
.cal-days .d.today{outline:2px solid var(--accent); outline-offset:-2px;}
.cal-days .d.avail.day-sel{background:var(--navy); color:#fff;}
.cal-booked{padding:48px 30px; text-align:center;}
.cal-booked h3{margin-bottom:8px;}
.cal-booked p{margin:0; color:var(--ink); font-family:var(--serif); font-size:18px;}
.cal-booked .cb-sub{font-family:var(--sans); font-size:14px; color:var(--muted); margin-top:10px; max-width:320px; margin-inline:auto;}
.cal-slots{padding:22px 26px;}
.cal-slots .cal-date{font-weight:600; font-size:14px; margin-bottom:14px;}
.cal-slots .cal-list{display:flex; flex-direction:column; gap:10px; max-height:230px; overflow:auto;}
.cal-slot{border:1px solid var(--navy); color:var(--navy); background:#fff; border-radius:6px; padding:12px; font-weight:600; font-size:15px; cursor:pointer; text-align:center; transition:background .15s,color .15s;}
.cal-slot:hover{background:rgba(31,73,125,.07);}
.cal-slot.sel{background:var(--navy); color:#fff;}
.cal-tz{font-size:12px;color:var(--muted-2); margin-top:14px; text-align:center;}
.cal-confirm{margin-top:18px; padding:16px 20px; background:var(--accent-soft); border:1px solid var(--accent); border-radius:8px; display:none; align-items:center; gap:14px;}
.cal-confirm.show{display:flex;}
.cal-confirm .btn{margin-left:auto;}

/* ---- stat band ---- */
.statband{display:grid; grid-template-columns:repeat(4,1fr);}
.statband .stat{padding:8px 24px; border-left:1px solid var(--line);}
.statband .stat:first-child{border-left:0; padding-left:0;}
.statband .stat b{font-family:var(--serif); font-size:clamp(38px,4.4vw,58px); color:var(--ink); display:block; line-height:1; letter-spacing:-.01em; white-space:nowrap;}
.statband .stat b .u{display:inline; color:var(--accent); font-size:.5em; vertical-align:.5em; margin-left:.04em;}
.statband .stat span{display:block; margin-top:12px; color:var(--muted); font-size:14px; line-height:1.4;}
@media(max-width:760px){ .statband{grid-template-columns:1fr 1fr; gap:32px 0;} .statband .stat:nth-child(3){border-left:0; padding-left:0;} }

/* ---- how it works ---- */
.how{display:grid; grid-template-columns:repeat(3,1fr); gap:0;}
.how-step{position:relative; padding:0 36px;}
.how-step:first-child{padding-left:0;}
.how-step:not(:first-child){border-left:1px solid var(--line);}
.how-num{display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:50%; border:1.5px solid var(--accent); color:var(--accent); font-family:var(--serif); font-size:20px; margin-bottom:20px;}
.how-step h3{font-size:21px; margin-bottom:10px;}
.how-step p{color:var(--muted); font-size:15.5px; margin:0;}
@media(max-width:760px){ .how{grid-template-columns:1fr; gap:32px;} .how-step{padding:0 0 0 0;} .how-step:not(:first-child){border-left:0; border-top:1px solid var(--line); padding-top:32px;} }

/* ---- location card ---- */
.loc{display:grid; grid-template-columns:1.1fr .9fr; gap:0; background:var(--card); border:1px solid var(--line); border-radius:12px; overflow:hidden; box-shadow:var(--shadow-sm);}
.loc-map{position:relative; min-height:280px; background:
  linear-gradient(rgba(31,73,125,.06),rgba(31,73,125,.06)),
  repeating-linear-gradient(0deg,#eef1f5 0 38px,#e7ecf2 38px 39px),
  repeating-linear-gradient(90deg,#eef1f5 0 38px,#e7ecf2 38px 39px);}
.loc-map::before{content:""; position:absolute; left:18%; top:0; bottom:0; width:14px; background:linear-gradient(90deg,#dfe6ee,#cdd8e4); transform:skewX(-12deg);}
.loc-map::after{content:""; position:absolute; right:0; top:32%; left:0; height:30%; background:linear-gradient(180deg,#cfe0ea,#bcd3e0);}
.loc-pin{position:absolute; left:46%; top:42%; z-index:2; width:24px; height:24px; background:var(--accent); border:3px solid #fff; border-radius:50% 50% 50% 0; transform:rotate(-45deg); box-shadow:0 4px 10px rgba(0,0,0,.2);}
.loc-maptag{position:absolute; z-index:2; left:14px; bottom:14px; font-family:ui-monospace,monospace; font-size:11px; color:#5c6b7d; background:rgba(255,255,255,.8); padding:5px 9px; border-radius:3px;}
.loc-body{padding:34px;}
.loc-body .eyebrow{margin-bottom:14px;}
.loc-body h3{font-size:24px; margin-bottom:8px;}
.loc-body .loc-addr{font-family:var(--serif); font-size:18px; color:var(--ink-2); line-height:1.45; margin:0 0 6px;}
.loc-meta{list-style:none; padding:0; margin:18px 0 22px; display:flex; flex-direction:column; gap:10px; font-size:15px; color:var(--ink-2);}
.loc-meta a:hover{color:var(--navy);}
.loc-meta li{display:flex; gap:10px; align-items:center; white-space:nowrap;}
.loc-meta svg{width:16px; height:16px; color:var(--accent); flex:none;}
@media(max-width:680px){ .loc{grid-template-columns:1fr;} .loc-map{min-height:200px;} }

/* utility */
.center{text-align:center;}
.mx-auto{margin-inline:auto;}
.maxw-prose{max-width:680px;}
.maxw-mid{max-width:860px;}
.mt-s{margin-top:14px;} .mt-m{margin-top:26px;} .mt-l{margin-top:44px;}
.fadeup{opacity:0; transform:translateY(18px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1);}
.fadeup.in{opacity:1; transform:none;}
@media(prefers-reduced-motion:reduce){ .fadeup{opacity:1; transform:none; transition:none;} }
