/* ==========================================================================
   Andersen Trinidad & Tobago — app.css  (v2: full-width fluid system)
   Modeled on rw.andersen.com's fluid proportions (vw-based type & spacing,
   edge-to-edge sections, wide content measure). Andersen Global brand.
   ========================================================================== */

:root{
  /* Core palette (Andersen Global Brand Standards) */
  --red:#AB0E1E; --red-dark:#8D0C18; --red-deep:#67251a;
  --cta:#F30824;
  --navy:#162D43; --navy-2:#1d3a55; --navy-3:#2F4357;
  --blue:#216993; --blue-light:#1581CE;
  --ink:#15202b; --slate:#717C89; --gray:#A3AAAE; --gray-2:#D0D3D4; --gray-3:#E8E8E8;
  --bg-soft:#F4F6F8; --white:#FFFFFF;

  /* Fluid layout — the "full-screen" feel */
  --maxw:1640px;
  --gutter:clamp(22px, 4.5vw, 80px);
  --sec-y:clamp(60px, 7vw, 130px);
  --sec-y-sm:clamp(44px, 4.4vw, 80px);

  /* Fluid type scale (vw-based, clamped) */
  --fs-h1:clamp(2.35rem, 3.6vw, 4.25rem);
  --fs-h2:clamp(1.75rem, 2.6vw, 3rem);
  --fs-h3:clamp(1.25rem, 1.5vw, 1.62rem);
  --fs-lead:clamp(1.16rem, 1.45vw, 1.6rem);
  --fs-body:clamp(1.02rem, 1.04vw, 1.2rem);
  --fs-sm:clamp(.86rem, .92vw, 1rem);

  --radius:6px; --radius-lg:12px;
  --shadow:0 4px 20px rgba(22,45,67,.10);
  --shadow-lg:0 18px 50px rgba(22,45,67,.20);
  --ff-body:"Roboto","Helvetica Neue",Arial,sans-serif;
  --ff-head:"Roboto Condensed","Helvetica Neue",Arial,sans-serif;
  --ff-serif:Georgia,"Times New Roman",serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--ff-body);color:var(--ink);font-size:var(--fs-body);
  line-height:1.65;background:var(--white);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--cta);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:var(--ff-head);font-weight:700;line-height:1.08;color:var(--navy);margin:0 0 .5em;
  letter-spacing:-.015em}
h1{font-size:var(--fs-h1);letter-spacing:-.022em}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3);letter-spacing:-.01em}
h4{font-size:1.05rem;letter-spacing:0}
p{margin:0 0 1.15em}
.lead{font-size:var(--fs-lead);color:var(--navy-3);line-height:1.5}

/* ---- Fluid container: wide, with vw gutters (near edge-to-edge) ---- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:1180px}
.section{padding-block:var(--sec-y)}
.section--tight{padding-block:var(--sec-y-sm)}
.bg-soft{background:var(--bg-soft)}
.bg-navy{background:var(--navy);color:#fff}
.bg-navy h1,.bg-navy h2,.bg-navy h3{color:#fff}
.center{text-align:center}
.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.eyebrow{font-family:var(--ff-head);text-transform:uppercase;letter-spacing:.18em;font-size:var(--fs-sm);
  font-weight:700;color:var(--red);margin:0 0 .8em}

/* Grid */
.grid{display:grid;gap:clamp(20px,2vw,34px)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-5{grid-template-columns:repeat(5,1fr)}
@media(max-width:1080px){.grid-5{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid-2,.grid-3,.grid-4,.grid-5{grid-template-columns:1fr}}

/* Buttons */
.btn{display:inline-block;font-family:var(--ff-head);font-weight:700;letter-spacing:.03em;
  background:var(--cta);color:#fff;padding:15px 30px;border-radius:var(--radius);text-transform:uppercase;
  font-size:var(--fs-sm);border:2px solid var(--cta);transition:.18s;cursor:pointer;line-height:1.1}
.btn:hover{background:var(--red-dark);border-color:var(--red-dark);text-decoration:none;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn--ghost:hover{background:#fff;color:var(--navy)}
.btn--navy{background:var(--navy);border-color:var(--navy)}
.btn--navy:hover{background:var(--navy-3);border-color:var(--navy-3)}
.btn--lg{padding:18px 40px;font-size:clamp(.92rem,1vw,1.05rem)}

/* ===== Top utility bar ===== */
.top-nav-bar{background:var(--navy);color:#cfd8de;font-size:clamp(.74rem,.8vw,.86rem)}
.top-nav-bar .container{display:flex;justify-content:space-between;align-items:center;min-height:42px;flex-wrap:wrap}
.top-nav-bar a{color:#cfd8de}.top-nav-bar a:hover{color:#fff}
.top-links{display:flex;gap:22px;flex-wrap:wrap}
.top-links .sep{color:var(--slate)}
@media(max-width:680px){.top-links:first-child{display:none}}

/* ===== Header / primary nav ===== */
.site-header{background:#fff;border-bottom:1px solid var(--gray-3);position:sticky;top:0;z-index:60}
.site-header .container{display:flex;align-items:center;justify-content:space-between;
  min-height:clamp(74px,6vw,98px);gap:24px}
.brand{display:flex;flex-direction:column;justify-content:center}
.brand img{height:clamp(40px,3.4vw,54px);width:auto}
.brand .brand-sub{font-family:var(--ff-head);font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--slate);margin-top:4px;padding-left:2px}
.primary-nav{display:flex;align-items:center;gap:2px}
.primary-nav a{font-family:var(--ff-head);font-weight:600;text-transform:uppercase;letter-spacing:.05em;
  font-size:clamp(.78rem,.86vw,.92rem);color:var(--navy);padding:10px 13px;border-radius:var(--radius);white-space:nowrap}
.primary-nav a:hover{color:var(--red);text-decoration:none;background:var(--bg-soft)}
.primary-nav .active{color:var(--red)}
.has-mega{position:relative}
.has-mega>a::after{content:"▾";font-size:.7em;margin-left:6px;color:var(--slate)}
.mega{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);background:#fff;
  box-shadow:var(--shadow-lg);border-top:3px solid var(--red);border-radius:0 0 8px 8px;
  width:min(880px,92vw);padding:30px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  opacity:0;visibility:hidden;transition:.18s;z-index:70}
.has-mega:hover .mega,.has-mega:focus-within .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega h4{color:var(--red);font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;margin:0 0 12px;
  padding-bottom:9px;border-bottom:1px solid var(--gray-3)}
.mega a{display:block;padding:7px 0;font-size:.95rem;text-transform:none;letter-spacing:0;
  font-family:var(--ff-body);font-weight:400;color:var(--navy-3)}
.mega a:hover{color:var(--red);background:none}
.nav-toggle{display:none;background:none;border:0;font-size:1.7rem;color:var(--navy);cursor:pointer;padding:6px}
@media(max-width:1100px){
  .primary-nav{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--gray-3);padding:0 var(--gutter);gap:0;
    max-height:0;overflow:hidden;box-shadow:var(--shadow-lg);transition:max-height .3s ease,padding .3s ease}
  .primary-nav.open{max-height:88vh;overflow:auto;padding:10px var(--gutter) 24px}
  .primary-nav a{padding:14px 4px;border-bottom:1px solid var(--gray-3);border-radius:0}
  .mega{position:static;transform:none;width:auto;opacity:1;visibility:visible;box-shadow:none;display:block;
    padding:4px 0 8px 14px;border-top:0}
  .has-mega>a::after{content:"+"}
  .nav-toggle{display:block}
}

/* ===== Hero — full-bleed background image ===== */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;isolation:isolate}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.hero::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(105deg,rgba(13,28,43,.93) 0%,rgba(16,33,50,.82) 40%,rgba(135,12,24,.55) 100%)}
.hero .container{display:grid;grid-template-columns:1.45fr .85fr;gap:clamp(32px,4vw,64px);align-items:center;
  min-height:clamp(540px,52vw,820px);padding-block:clamp(70px,7vw,120px)}
.hero h1{color:#fff;margin-bottom:.35em}
.hero p{font-size:var(--fs-lead);color:#e7eef4;max-width:42ch;line-height:1.5}
.hero-cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:32px}
.hero-card{background:rgba(255,255,255,.09);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-lg);
  padding:clamp(24px,2vw,34px);backdrop-filter:blur(7px)}
.hero-card .tag{display:inline-block;background:var(--red);color:#fff;font-family:var(--ff-head);font-size:.72rem;
  text-transform:uppercase;letter-spacing:.12em;padding:5px 12px;border-radius:3px;margin-bottom:14px;font-weight:700}
.hero-card h3{color:#fff;margin-bottom:10px}
.hero-card a{color:#fff;font-weight:700;font-family:var(--ff-head);text-transform:uppercase;font-size:.84rem;letter-spacing:.06em}
@media(max-width:900px){.hero .container{grid-template-columns:1fr;min-height:0}}

/* page hero (service/article) — shorter, image optional */
.hero--page .container{grid-template-columns:1.5fr .8fr;min-height:clamp(380px,34vw,520px)}

/* ===== Section heads ===== */
.section-head{max-width:820px;margin:0 0 clamp(30px,3vw,52px)}
.section-head.center{margin-inline:auto;text-align:center}

/* ===== Cards ===== */
.card{background:#fff;border:1px solid var(--gray-3);border-radius:var(--radius-lg);
  padding:clamp(24px,2vw,38px);height:100%;transition:.2s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px);border-color:transparent}
.card .ico{width:54px;height:54px;border-radius:50%;background:var(--bg-soft);display:flex;align-items:center;
  justify-content:center;margin-bottom:18px;color:var(--red)}
.card .ico svg{width:28px;height:28px}
.card p{color:var(--navy-3);flex:1}
.card .more{font-family:var(--ff-head);text-transform:uppercase;font-size:.84rem;font-weight:700;
  letter-spacing:.05em;color:var(--cta);margin-top:12px}
.card .more::after{content:" »"}
.value .ico{background:var(--red);color:#fff}

/* ===== Image cluster blocks (services overview) ===== */
.svc-block{position:relative;border-radius:var(--radius-lg);overflow:hidden;color:#fff;
  min-height:clamp(300px,26vw,400px);display:flex;flex-direction:column;justify-content:flex-end;
  padding:clamp(26px,2vw,38px);background:var(--navy);isolation:isolate}
.svc-block img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:.5s}
.svc-block::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(22,45,67,.15) 0%,rgba(22,45,67,.55) 55%,rgba(13,24,37,.93) 100%)}
.svc-block:hover img{transform:scale(1.05)}
.svc-block h3{color:#fff;font-size:clamp(1.4rem,1.8vw,2rem)}
.svc-block p{color:#e3e9ef}
.svc-block .more{color:#fff;font-family:var(--ff-head);text-transform:uppercase;font-weight:700;
  font-size:.84rem;letter-spacing:.05em}

/* ===== Banner (full-bleed image band) ===== */
.banner{position:relative;color:#fff;background:var(--navy);overflow:hidden;isolation:isolate}
.banner img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2}
.banner::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(13,24,37,.92),rgba(22,45,67,.78) 55%,rgba(135,12,24,.55))}
.banner .container{padding-block:clamp(64px,7vw,128px);text-align:center;max-width:920px}
.banner h2{color:#fff}.banner p{font-size:var(--fs-lead);color:#e7eef4}

/* ===== Culture split strip ===== */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.split .media{position:relative;min-height:clamp(320px,32vw,560px)}
.split .media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.split .body{padding:var(--sec-y) clamp(28px,4vw,80px);display:flex;flex-direction:column;justify-content:center}
.split.bg-navy .body{color:#fff}
@media(max-width:860px){.split{grid-template-columns:1fr}.split .media{min-height:300px}}

/* ===== Stats ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(18px,2vw,32px);text-align:center}
.stat .num{font-family:var(--ff-head);font-weight:700;font-size:clamp(2.2rem,3.4vw,3.4rem);color:var(--red);line-height:1}
.stat .lbl{color:var(--navy-3);margin-top:8px;font-size:var(--fs-sm)}
@media(max-width:620px){.stats{grid-template-columns:repeat(2,1fr)}}

/* ===== Breadcrumb ===== */
.crumb{background:var(--bg-soft);border-bottom:1px solid var(--gray-3);font-size:var(--fs-sm)}
.crumb .container{padding-block:13px}
.crumb a{color:var(--slate)}.crumb .sep{color:var(--gray);margin:0 9px}.crumb .cur{color:var(--navy)}

/* ===== Prose ===== */
.prose{max-width:none}
.prose h2{margin-top:1.7em}
.prose h3{margin-top:1.3em;color:var(--red-dark)}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.4em}
.prose li{margin-bottom:.55em}
.prose blockquote{border-left:4px solid var(--red);margin:1.6em 0;padding:.5em 0 .5em 1.3em;
  font-family:var(--ff-serif);font-style:italic;color:var(--navy-3);font-size:clamp(1.15rem,1.5vw,1.5rem);line-height:1.45}
.callout{background:var(--bg-soft);border-left:4px solid var(--blue);border-radius:0 8px 8px 0;
  padding:22px 26px;margin:1.7em 0}
.callout strong{color:var(--navy)}

/* layout with sidebar */
.with-aside{display:grid;grid-template-columns:minmax(0,1fr) clamp(300px,24vw,360px);gap:clamp(36px,4vw,72px);align-items:start}
@media(max-width:1000px){.with-aside{grid-template-columns:1fr}}
.aside-card{background:var(--navy);color:#fff;border-radius:var(--radius-lg);padding:clamp(24px,2vw,32px);position:sticky;top:clamp(90px,8vw,116px)}
.aside-card h3{color:#fff}
.aside-card ul{list-style:none;padding:0;margin:0 0 20px}
.aside-card li{border-bottom:1px solid rgba(255,255,255,.15);padding:10px 0}
.aside-card a{color:#dbe3ea}.aside-card a:hover{color:#fff}
.aside-card .btn{width:100%;text-align:center}

/* ===== FAQ ===== */
.faq details{border:1px solid var(--gray-3);border-radius:8px;margin-bottom:14px;background:#fff}
.faq summary{cursor:pointer;padding:20px 24px;font-family:var(--ff-head);font-weight:700;color:var(--navy);
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px;font-size:clamp(1rem,1.15vw,1.18rem)}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--red);font-size:1.5rem;font-weight:400;flex:none}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--gray-3)}
.faq .ans{padding:18px 24px;color:var(--navy-3)}.faq .ans p:last-child{margin-bottom:0}

/* ===== Chips ===== */
.chips{display:flex;flex-wrap:wrap;gap:13px}
.chip{background:#fff;border:1px solid var(--gray-2);border-radius:30px;padding:10px 20px;
  font-family:var(--ff-head);font-weight:600;font-size:.9rem;color:var(--navy)}
.chip:hover{border-color:var(--red);color:var(--red);text-decoration:none}

/* ===== Forms ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:620px){.form-grid{grid-template-columns:1fr}}
label{display:block;font-family:var(--ff-head);font-weight:600;font-size:.86rem;color:var(--navy);margin-bottom:7px}
input,select,textarea{width:100%;padding:13px 15px;border:1px solid var(--gray-2);border-radius:var(--radius);
  font-family:var(--ff-body);font-size:1rem;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid var(--blue);border-color:var(--blue)}
.full{grid-column:1/-1}

/* ===== Footer ===== */
.site-footer{background:var(--navy);color:#aebdca;font-size:var(--fs-sm)}
.site-footer .container{padding-block:clamp(48px,5vw,80px) 0}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:clamp(28px,3vw,52px)}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px}
.site-footer ul{list-style:none;padding:0;margin:0}.site-footer li{margin-bottom:10px}
.site-footer a{color:#aebdca}.site-footer a:hover{color:#fff}
.footer-logo img{height:44px;background:#fff;padding:9px 13px;border-radius:5px;margin-bottom:18px}
.footer-contact p{margin-bottom:9px}
.footer-social{display:flex;gap:14px;margin-top:18px}
.footer-social a{width:38px;height:38px;border:1px solid rgba(255,255,255,.28);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:#fff}
.footer-social a:hover{background:var(--red);border-color:var(--red)}
.footer-social svg{width:18px;height:18px;fill:currentColor}
.footer-legal{border-top:1px solid rgba(255,255,255,.14);margin-top:clamp(36px,4vw,56px);padding-block:26px;
  font-size:.76rem;color:#8a99a8;line-height:1.65}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  border-top:1px solid rgba(255,255,255,.14);padding-block:18px;font-size:.82rem}

/* utility */
.mt0{margin-top:0}.mb0{margin-bottom:0}
.tag-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px}
.pill{background:rgba(171,14,30,.09);color:var(--red);font-family:var(--ff-head);font-weight:700;font-size:.74rem;
  text-transform:uppercase;letter-spacing:.09em;padding:6px 13px;border-radius:30px}
.hublist{list-style:none;padding:0;margin:0;display:grid;gap:20px}
.hub-item{display:grid;grid-template-columns:200px 1fr;gap:26px;border:1px solid var(--gray-3);
  border-radius:var(--radius-lg);overflow:hidden;background:#fff;transition:.2s}
.hub-item:hover{box-shadow:var(--shadow)}
.hub-item .thumb{background:var(--navy);min-height:140px;display:flex;align-items:flex-end;padding:16px;color:#fff}
.hub-item .body{padding:24px 26px 24px 0}.hub-item h3{margin-bottom:7px}
@media(max-width:560px){.hub-item{grid-template-columns:1fr}}

/* ===== Our People — row list, matching rw.andersen.com ===== */
.people-intro{max-width:900px;margin:0 0 clamp(28px,3vw,44px)}
.people-list{border-top:1px solid var(--gray-3)}
.people-list .item{display:flex;align-items:center;flex-wrap:wrap;gap:0;text-decoration:none;
  border-bottom:1px solid var(--gray-3);transition:background .15s}
.people-list .item:nth-child(2n+1){background:rgba(247,247,247,.8)}
.people-list .item:hover{background:#eef2f5}
.people-list .item-img{flex:0 0 clamp(150px,9vw,170px);height:96px;position:relative;overflow:hidden}
.people-list .item-img>span{position:absolute;inset:0}
.people-list .item-img>span img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center}
.people-list .item-name{flex:0 0 24%;font-family:var(--ff-head);font-weight:700;font-size:1.15rem;color:var(--navy);padding:0 18px}
.people-list .item-location{flex:0 0 20%;color:var(--slate);padding:0 12px}
.people-list .item-position{flex:1 1 22%;color:var(--navy-3);padding:0 12px}
.people-list .item-more{flex:0 0 auto;margin-left:auto;padding:0 24px;font-family:var(--ff-head);font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;color:var(--cta)}
.people-list .item-more::after{content:" →"}
@media(max-width:820px){
  .people-list .item{padding-bottom:14px;text-align:center;justify-content:center}
  .people-list .item-img{flex:0 0 100%;height:200px}
  .people-list .item-name,.people-list .item-location,.people-list .item-position{flex:0 0 100%;margin-top:8px;padding:0 16px}
  .people-list .item-more{margin:8px auto 0}
}

/* Profile modal — matching rw .profile-card */
.person-modal{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:24px;background:rgba(13,24,37,.74);backdrop-filter:blur(3px)}
.person-modal.open{display:flex}
.profile-card{background:#fff;border:1px solid #ddd;border-radius:5px;overflow:hidden;max-width:760px;width:100%;
  max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg)}
.profile-header{background:#e6e9ec;padding:12px 22px;display:flex;justify-content:space-between;align-items:center}
.profile-header img{height:38px;width:auto}
.profile-header .modal-close{cursor:pointer;font-size:26px;line-height:1;color:#000;background:none;border:0}
.profile-header .modal-close:hover{color:var(--red)}
.profile-image{width:100%;background:#f7f7f7;max-height:420px;overflow:hidden;display:flex;justify-content:center}
.profile-image img{width:100%;height:auto;object-fit:cover;object-position:top center;display:block}
.profile-content{padding:24px 28px 38px}
.profile-content h2{margin:0 0 2px}
.profile-content .role{color:var(--red);font-family:var(--ff-head);font-weight:600;margin:0 0 16px}
.profile-content p{margin:12px 0;line-height:1.7;color:#333}
.profile-content a{color:var(--cta)}
