/* ============================================================
   AZURE SHORE — Sint Maarten Property Concierge
   Design System — Light Coastal Luxury
   Ocean blues, sunset warmth, white canvas
   ============================================================ */

:root {
  --clr-bg:#ffffff;--clr-bg-alt:#f4f9fc;--clr-bg-warm:#fdf8f3;--clr-bg-card:#ffffff;--clr-bg-hover:#f0f7fb;--clr-surface:#eef6fa;
  --clr-ocean:#0a6e8a;--clr-ocean-deep:#044d5f;--clr-ocean-light:#1ab8cc;--clr-ocean-pale:#c4ebf4;--clr-ocean-glow:rgba(10,110,138,.06);
  --clr-sunset:#e07a42;--clr-sunset-deep:#b85e30;--clr-sunset-light:#fce0cc;--clr-sunset-glow:rgba(224,122,66,.08);
  --clr-sand:#f5efe6;--clr-aqua:#3db8bd;--clr-aqua-pale:#e4f6f6;
  --clr-border:rgba(10,110,138,.15);--clr-border-lt:rgba(0,0,0,.06);--clr-border-warm:rgba(224,122,66,.2);
  --clr-text:#1e293b;--clr-text-dim:#5a6a7a;--clr-text-mute:#94a3b8;--clr-white:#ffffff;--clr-heading:#0a1f2e;
  --ff-display:'Didot','Bodoni MT','Noto Serif Display','Times New Roman',Georgia,serif;
  --ff-body:'Avenir Next','Segoe UI','Helvetica Neue',Helvetica,Arial,sans-serif;
  --sp-xs:.25rem;--sp-sm:.5rem;--sp-md:1rem;--sp-lg:1.5rem;--sp-xl:2.5rem;--sp-2xl:4rem;--sp-3xl:6rem;
  --max-w:1200px;--max-w-narrow:820px;--nav-h:72px;
  --ease-out:cubic-bezier(.22,1,.36,1);--dur:.4s;
  --shadow-sm:0 1px 3px rgba(0,0,0,.04),0 1px 2px rgba(0,0,0,.06);
  --shadow-md:0 4px 16px rgba(0,0,0,.06),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 12px 40px rgba(0,0,0,.08),0 4px 12px rgba(0,0,0,.04);
  --shadow-card:0 2px 12px rgba(10,110,138,.06);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--ff-body);background:var(--clr-bg);color:var(--clr-text);line-height:1.7;overflow-x:hidden}
::selection{background:var(--clr-ocean);color:var(--clr-white)}
img{max-width:100%;display:block}
a{color:var(--clr-ocean);text-decoration:none;transition:color var(--dur) var(--ease-out)}
a:hover{color:var(--clr-ocean-deep)}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--clr-ocean);outline-offset:2px}

h1,h2,h3,h4,h5{font-family:var(--ff-display);font-weight:400;line-height:1.2;color:var(--clr-heading);letter-spacing:.01em}
h1{font-size:clamp(2rem,5vw,3.5rem)}h2{font-size:clamp(1.6rem,3.5vw,2.5rem)}h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}h4{font-size:1.15rem}

.eyebrow{font-family:var(--ff-body);font-size:.75rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--clr-sunset);display:block;margin-bottom:var(--sp-sm)}
.lead{font-size:1.15rem;color:var(--clr-text-dim);max-width:640px;line-height:1.8}

.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--sp-lg)}
.container--narrow{max-width:var(--max-w-narrow)}
section{padding:var(--sp-3xl) 0}

.grid-2{display:grid;grid-template-columns:1fr;gap:var(--sp-xl)}
.grid-3{display:grid;grid-template-columns:1fr;gap:var(--sp-xl)}
@media(min-width:768px){.grid-2{grid-template-columns:1fr 1fr}.grid-3{grid-template-columns:1fr 1fr 1fr}}

/* NAV */
.site-nav{position:fixed;top:0;left:0;width:100%;height:var(--nav-h);z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--clr-border-lt)}
.site-nav .container{display:flex;align-items:center;justify-content:space-between;height:100%}
.nav-brand{display:inline-flex;align-items:center;justify-content:center;width:230px;height:58px;padding:4px 10px;background:var(--clr-heading);border-radius:6px;white-space:nowrap}
.brand-logo{width:100%;height:100%;object-fit:contain}
.nav-links{display:none;list-style:none;gap:var(--sp-lg);align-items:center}
.nav-links a{font-size:.8rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--clr-text-dim);position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--clr-ocean),var(--clr-sunset));border-radius:1px;transition:width var(--dur) var(--ease-out)}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--clr-ocean)}
.nav-links a:hover::after,.nav-links a[aria-current="page"]::after{width:100%}
@media(min-width:1024px){.nav-links{display:flex}.nav-toggle{display:none !important}}

.nav-toggle{background:none;border:none;width:40px;height:40px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:5px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--clr-text);transition:transform var(--dur) var(--ease-out),opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:rotate(45deg) translate(4px,4px)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:rotate(-45deg) translate(4px,-4px)}

.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;width:100%;height:calc(100vh - var(--nav-h));background:rgba(255,255,255,.98);backdrop-filter:blur(20px);z-index:999;padding:var(--sp-xl) var(--sp-lg);overflow-y:auto}
.mobile-menu.is-open{display:block}
.mobile-menu a{display:block;font-size:1.1rem;padding:var(--sp-md) 0;color:var(--clr-text-dim);border-bottom:1px solid var(--clr-border-lt);letter-spacing:.04em}
.mobile-menu a:hover{color:var(--clr-ocean)}

/* HERO — DARK IMMERSIVE */
.hero{position:relative;min-height:90vh;display:flex;align-items:center;padding-top:calc(var(--nav-h) + var(--sp-3xl));padding-bottom:var(--sp-3xl);overflow:hidden;background:var(--clr-heading);color:var(--clr-white)}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(ellipse 120% 80% at 0% 100%,rgba(10,110,138,.4) 0%,transparent 50%),
  radial-gradient(ellipse 80% 60% at 100% 0%,rgba(224,122,66,.2) 0%,transparent 50%),
  radial-gradient(ellipse 60% 50% at 50% 50%,rgba(61,184,189,.1) 0%,transparent 60%);
  pointer-events:none}
.hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='1' cy='1' r='.6' fill='rgba(255,255,255,0.04)'/%3E%3C/svg%3E") repeat;pointer-events:none}

/* Floating orbs */
.hero-orb{position:absolute;border-radius:50%;filter:blur(60px);pointer-events:none;animation:float-orb 20s ease-in-out infinite}
.hero-orb--1{width:500px;height:500px;background:rgba(10,110,138,.15);top:-10%;right:-5%;animation-delay:0s}
.hero-orb--2{width:350px;height:350px;background:rgba(224,122,66,.1);bottom:-5%;left:-5%;animation-delay:-7s}
.hero-orb--3{width:250px;height:250px;background:rgba(61,184,189,.12);top:40%;right:30%;animation-delay:-14s}
@keyframes float-orb{0%,100%{transform:translate(0,0) scale(1)}25%{transform:translate(30px,-20px) scale(1.05)}50%{transform:translate(-20px,30px) scale(.95)}75%{transform:translate(20px,20px) scale(1.02)}}

.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1fr;gap:var(--sp-2xl);align-items:center}
@media(min-width:900px){.hero-grid{grid-template-columns:1.2fr 1fr}}
.hero-grid--media{align-items:center}

.hero-content{position:relative;z-index:1;max-width:660px}
.hero h1{margin-bottom:var(--sp-lg);color:var(--clr-white);font-size:clamp(2.2rem,5.5vw,3.8rem);line-height:1.1}
.hero h1 em{font-style:normal;background:linear-gradient(135deg,var(--clr-ocean-light) 0%,var(--clr-aqua) 40%,var(--clr-sunset) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero .lead{margin-bottom:var(--sp-xl);color:rgba(255,255,255,.7);max-width:580px}
.hero .ribbon{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12);color:var(--clr-ocean-light)}
.hero .ribbon svg{stroke:var(--clr-ocean-light)}
.hero .btn--primary{box-shadow:0 4px 24px rgba(10,110,138,.4)}
.hero .btn--outline{color:var(--clr-white);border-color:rgba(255,255,255,.3)}
.hero .btn--outline:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.5)}

/* Hero metrics panel */
.hero-metrics{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-md)}
.hero-metric{padding:var(--sp-lg);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:12px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .4s var(--ease-out)}
.hero-metric:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.15);transform:translateY(-2px)}
.hero-metric-number{font-family:var(--ff-display);font-size:clamp(1.6rem,3vw,2.2rem);color:var(--clr-white);line-height:1;margin-bottom:var(--sp-xs)}
.hero-metric-label{font-size:.7rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.4)}
.hero-metric-detail{font-size:.8rem;color:rgba(255,255,255,.5);margin-top:var(--sp-sm);line-height:1.5}
.hero-metric--accent .hero-metric-number{background:linear-gradient(135deg,var(--clr-ocean-light),var(--clr-aqua));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-side{display:grid;gap:var(--sp-md)}
.hero-metrics--compact .hero-metric{padding:var(--sp-md)}
.hero-metrics--compact .hero-metric-number{font-size:clamp(1.2rem,2vw,1.55rem)}

/* Hero bottom wave */
.hero-wave{position:absolute;bottom:-1px;left:0;right:0;z-index:2}
.hero-wave svg{display:block;width:100%;height:auto}

/* Nav dark override on hero pages */
.site-nav--dark{background:rgba(10,31,46,.85);border-bottom-color:rgba(255,255,255,.06)}
.site-nav--dark .nav-brand{background:transparent;padding:0}
.site-nav--dark .nav-links a{color:rgba(255,255,255,.6)}
.site-nav--dark .nav-links a:hover,.site-nav--dark .nav-links a[aria-current="page"]{color:var(--clr-white)}
.site-nav--dark .nav-toggle span{background:var(--clr-white)}

/* SHORT HERO — dark, same palette as main hero */
.hero--short{min-height:45vh}
.hero--short .hero-wave svg{height:60px}
.hero--short .eyebrow{color:var(--clr-ocean-light)}
.hero--short .lead{color:rgba(255,255,255,.65)}

.ribbon{display:inline-flex;align-items:center;gap:var(--sp-sm);padding:var(--sp-xs) var(--sp-md);border:1px solid var(--clr-border);border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--clr-ocean);background:rgba(10,110,138,.04);margin-bottom:var(--sp-lg)}
.ribbon svg{width:14px;height:14px;stroke:var(--clr-ocean)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:var(--sp-sm);padding:.875rem 2rem;font-family:var(--ff-body);font-size:.82rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;border:none;border-radius:6px;cursor:pointer;transition:all var(--dur) var(--ease-out);text-decoration:none;white-space:nowrap}
.btn--primary{background:linear-gradient(135deg,var(--clr-ocean) 0%,var(--clr-ocean-deep) 100%);color:var(--clr-white);box-shadow:0 4px 16px rgba(10,110,138,.25)}
.btn--primary:hover{background:linear-gradient(135deg,var(--clr-ocean-deep) 0%,#04485a 100%);color:var(--clr-white);box-shadow:0 6px 24px rgba(10,110,138,.35);transform:translateY(-1px)}
.btn--outline{background:transparent;color:var(--clr-ocean);border:1.5px solid var(--clr-ocean)}
.btn--outline:hover{background:var(--clr-ocean);color:var(--clr-white)}
.btn--ghost{background:transparent;color:var(--clr-text-dim);padding:.875rem 0}
.btn--ghost:hover{color:var(--clr-ocean)}
.btn--sm{padding:.6rem 1.4rem;font-size:.75rem}
.btn--warm{background:linear-gradient(135deg,var(--clr-sunset) 0%,var(--clr-sunset-deep) 100%);color:var(--clr-white);box-shadow:0 4px 16px rgba(224,122,66,.2)}
.btn--warm:hover{box-shadow:0 6px 24px rgba(224,122,66,.3);transform:translateY(-1px);color:var(--clr-white)}
.btn-group{display:flex;flex-wrap:wrap;gap:var(--sp-md)}

/* CARDS */
.card{background:var(--clr-bg-card);border:1px solid var(--clr-border-lt);border-radius:10px;padding:var(--sp-xl);box-shadow:var(--shadow-card);transition:border-color var(--dur) var(--ease-out),transform var(--dur) var(--ease-out),box-shadow var(--dur)}
.card:hover{border-color:var(--clr-border);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.card h3{margin-bottom:var(--sp-md)}.card p{color:var(--clr-text-dim);font-size:.95rem}
.card--featured{border-color:var(--clr-border);position:relative;background:linear-gradient(180deg,#f8fcfe 0%,#fff 100%)}
.card--featured::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--clr-ocean-deep),var(--clr-ocean),var(--clr-aqua),var(--clr-sunset));border-radius:10px 10px 0 0}

/* TIERS */
.tier-card{text-align:center;padding:var(--sp-2xl) var(--sp-xl)}
.tier-amount{font-family:var(--ff-display);font-size:2.5rem;color:var(--clr-ocean);margin-bottom:var(--sp-sm)}
.tier-label{font-size:.75rem;letter-spacing:.14em;text-transform:uppercase;color:var(--clr-text-mute);margin-bottom:var(--sp-lg)}
.tier-card ul{list-style:none;text-align:left}
.tier-card li{padding:var(--sp-sm) 0;border-top:1px solid var(--clr-border-lt);font-size:.9rem;color:var(--clr-text-dim)}
.tier-card li:last-child{border-bottom:1px solid var(--clr-border-lt)}

/* TIMELINE */
.timeline{position:relative;padding-left:2.5rem}
.timeline::before{content:'';position:absolute;left:11px;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,var(--clr-ocean-light),var(--clr-sunset-light));border-radius:1px}
.timeline-step{position:relative;padding-bottom:var(--sp-xl)}
.timeline-step:last-child{padding-bottom:0}
.timeline-step::before{content:attr(data-step);position:absolute;left:-2.5rem;top:0;width:24px;height:24px;border-radius:50%;background:var(--clr-white);border:2px solid var(--clr-ocean);color:var(--clr-ocean);font-size:.65rem;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;text-align:center;box-shadow:0 0 0 4px rgba(10,110,138,.08)}
.timeline-step h4{color:var(--clr-heading);margin-bottom:var(--sp-xs)}
.timeline-step p{color:var(--clr-text-dim);font-size:.9rem}

.section-divider{width:60px;height:2px;background:linear-gradient(90deg,var(--clr-ocean),var(--clr-aqua));margin:var(--sp-lg) 0;border-radius:1px}
.section-header{margin-bottom:var(--sp-2xl)}
.section-header h2{margin-bottom:var(--sp-md)}

/* ACCORDION */
.accordion{border-top:1px solid var(--clr-border-lt)}
.accordion-item{border-bottom:1px solid var(--clr-border-lt)}
.accordion-trigger{width:100%;background:none;border:none;padding:var(--sp-lg) 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;text-align:left;font-family:var(--ff-body);font-size:1rem;color:var(--clr-text);line-height:1.5;gap:var(--sp-md)}
.accordion-trigger:hover{color:var(--clr-ocean)}
.accordion-icon{width:20px;height:20px;flex-shrink:0;stroke:var(--clr-text-mute);transition:transform var(--dur) var(--ease-out),stroke var(--dur)}
.accordion-item.is-open .accordion-icon{transform:rotate(45deg);stroke:var(--clr-ocean)}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height var(--dur) var(--ease-out)}
.accordion-panel-inner{padding-bottom:var(--sp-lg);color:var(--clr-text-dim);font-size:.92rem;line-height:1.8}

/* FORMS */
.form-section{background:var(--clr-bg);border:1px solid var(--clr-border-lt);border-radius:12px;padding:var(--sp-2xl);box-shadow:var(--shadow-md)}
.form-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-md)}
@media(min-width:600px){.form-grid{grid-template-columns:1fr 1fr}.form-grid .full-width{grid-column:1/-1}}
.form-field{display:flex;flex-direction:column;gap:var(--sp-xs)}
.form-field label{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--clr-text-dim)}
.form-field input,.form-field select,.form-field textarea{background:var(--clr-bg-alt);border:1px solid var(--clr-border-lt);border-radius:6px;padding:.75rem 1rem;font-family:var(--ff-body);font-size:.92rem;color:var(--clr-text);transition:border-color var(--dur) var(--ease-out),box-shadow var(--dur)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--clr-ocean);box-shadow:0 0 0 3px rgba(10,110,138,.1);outline:none}
.form-field textarea{resize:vertical;min-height:100px}
.form-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%235a6a7a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center;padding-right:2.5rem}
.form-toggle{display:flex;align-items:center;gap:var(--sp-sm);cursor:pointer;font-size:.88rem;color:var(--clr-text-dim)}
.form-toggle input[type="checkbox"]{width:18px;height:18px;accent-color:var(--clr-ocean)}

/* LISTINGS */
.listing-card{background:var(--clr-bg-card);border:1px solid var(--clr-border-lt);border-radius:12px;overflow:hidden;box-shadow:var(--shadow-card);transition:border-color var(--dur) var(--ease-out),transform var(--dur),box-shadow var(--dur)}
.listing-card:hover{border-color:var(--clr-border);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.listing-card-img{height:200px;display:flex;align-items:center;justify-content:center;overflow:hidden;position:relative}
.listing-card-img svg{width:100%;height:100%}
.listing-card-body{padding:var(--sp-lg)}
.listing-card-body h3{font-size:1.15rem;margin-bottom:var(--sp-xs)}
.listing-card-meta{font-size:.85rem;color:var(--clr-text-dim);margin-bottom:var(--sp-md)}
.listing-card-meta strong{color:var(--clr-ocean)}
.chips{display:flex;flex-wrap:wrap;gap:var(--sp-xs);margin-bottom:var(--sp-md)}
.chip{display:inline-block;padding:.2rem .65rem;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--clr-border);border-radius:20px;color:var(--clr-ocean);background:var(--clr-ocean-glow)}
.listing-card-highlights{list-style:none;margin-bottom:var(--sp-lg)}
.listing-card-highlights li{font-size:.85rem;color:var(--clr-text-dim);padding:var(--sp-xs) 0;padding-left:1rem;position:relative}
.listing-card-highlights li::before{content:'—';position:absolute;left:0;color:var(--clr-sunset)}
.listing-card-actions{display:flex;gap:var(--sp-sm);flex-wrap:wrap}

.filters-bar{display:flex;flex-wrap:wrap;gap:var(--sp-md);margin-bottom:var(--sp-xl);padding:var(--sp-lg);background:var(--clr-bg-alt);border:1px solid var(--clr-border-lt);border-radius:10px}
.filters-bar .form-field{flex:1;min-width:160px}
.filters-bar label{font-size:.7rem}

.detail-hero{padding-top:calc(var(--nav-h) + var(--sp-2xl));padding-bottom:var(--sp-xl)}
.detail-gallery{display:grid;grid-template-columns:1fr;gap:var(--sp-md);margin-bottom:var(--sp-2xl)}
@media(min-width:768px){.detail-gallery{grid-template-columns:repeat(3,1fr)}}
.detail-gallery-item{height:220px;background:linear-gradient(135deg,var(--clr-ocean-pale),var(--clr-sunset-light));border:1px solid var(--clr-border-lt);border-radius:10px;display:flex;align-items:center;justify-content:center}

.featured-bundles{background:linear-gradient(180deg,var(--clr-bg-alt) 0%,var(--clr-bg) 100%)}

/* NDA NOTE */
.nda-note{display:flex;align-items:flex-start;gap:var(--sp-md);padding:var(--sp-lg);background:var(--clr-ocean-glow);border-left:3px solid var(--clr-ocean);border-radius:0 8px 8px 0;font-size:.88rem;color:var(--clr-text-dim);margin:var(--sp-xl) 0}
.nda-note svg{flex-shrink:0;width:20px;height:20px;stroke:var(--clr-ocean)}

.sample-badge{display:inline-block;padding:.15rem .55rem;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:var(--clr-sunset-glow);color:var(--clr-sunset-deep);border-radius:4px;border:1px solid var(--clr-border-warm)}

/* CONTENT PAGES */
.page-content{padding-top:calc(var(--nav-h) + var(--sp-2xl));padding-bottom:var(--sp-3xl)}
.page-content h2{margin-top:var(--sp-2xl);margin-bottom:var(--sp-md)}
.page-content h3{margin-top:var(--sp-xl);margin-bottom:var(--sp-sm)}
.page-content p{margin-bottom:var(--sp-md);color:var(--clr-text-dim)}
.page-content ul,.page-content ol{margin-bottom:var(--sp-md);padding-left:var(--sp-lg);color:var(--clr-text-dim)}
.page-content li{margin-bottom:var(--sp-sm)}

/* FOOTER */
.site-footer{padding:var(--sp-3xl) 0 var(--sp-xl);background:var(--clr-heading);color:rgba(255,255,255,.7)}
.site-footer a{color:rgba(255,255,255,.6)}.site-footer a:hover{color:var(--clr-ocean-light)}
.footer-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-2xl);margin-bottom:var(--sp-2xl)}
@media(min-width:768px){.footer-grid{grid-template-columns:2fr 1fr 1fr 1fr}}
.footer-brand{margin-bottom:var(--sp-md)}
.footer-logo{width:210px;height:auto}
.footer-brand+p{color:rgba(255,255,255,.5);font-size:.85rem;max-width:320px}
.footer-col h5{font-family:var(--ff-body);font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:var(--sp-md)}
.footer-col ul{list-style:none}.footer-col li{margin-bottom:var(--sp-sm)}.footer-col a{font-size:.88rem}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--sp-md);padding-top:var(--sp-xl);border-top:1px solid rgba(255,255,255,.1);font-size:.78rem;color:rgba(255,255,255,.35)}
.footer-bottom a{color:rgba(255,255,255,.35)}.footer-bottom a:hover{color:var(--clr-ocean-light)}

/* ANIMATIONS */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* PLACEHOLDERS */
.svg-pattern-a{background:linear-gradient(135deg,var(--clr-ocean-pale) 0%,#e8f4f8 50%,var(--clr-sunset-light) 100%)}
.svg-pattern-b{background:linear-gradient(135deg,var(--clr-sunset-light) 0%,var(--clr-aqua-pale) 100%)}

/* UTILITY */
.text-center{text-align:center}.text-ocean{color:var(--clr-ocean)}.text-sunset{color:var(--clr-sunset)}
.text-dim{color:var(--clr-text-dim)}.text-mute{color:var(--clr-text-mute)}.text-gold{color:var(--clr-sunset)}
.mt-sm{margin-top:var(--sp-sm)}.mt-md{margin-top:var(--sp-md)}.mt-lg{margin-top:var(--sp-lg)}.mt-xl{margin-top:var(--sp-xl)}
.mb-md{margin-bottom:var(--sp-md)}.mb-lg{margin-bottom:var(--sp-lg)}.mb-xl{margin-bottom:var(--sp-xl)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.bg-alt{background:var(--clr-bg-alt)}

@media print{.site-nav,.mobile-menu,.site-footer,.btn{display:none !important}body{background:#fff;color:#111}h1,h2,h3{color:#111}}

/* ============================================================
   DESIGN POLISH — Depth, Texture, Flow
   ============================================================ */

/* STAT CALLOUTS */
.stat-row{display:grid;grid-template-columns:1fr;gap:var(--sp-lg);margin:var(--sp-xl) 0}
@media(min-width:600px){.stat-row{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}
.stat-item{text-align:center;padding:var(--sp-xl) var(--sp-lg);background:var(--clr-bg);border:1px solid var(--clr-border-lt);border-radius:12px;position:relative;overflow:hidden}
.stat-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--clr-ocean),var(--clr-aqua),var(--clr-sunset))}
.stat-number{font-family:var(--ff-display);font-size:clamp(2rem,4vw,2.8rem);color:var(--clr-heading);line-height:1;margin-bottom:var(--sp-sm)}
.stat-label{font-size:.75rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--clr-text-mute)}

/* PULL QUOTES / HIGHLIGHT BLOCKS */
.pull-quote{position:relative;padding:var(--sp-xl) var(--sp-xl) var(--sp-xl) calc(var(--sp-xl) + 4px);margin:var(--sp-xl) 0;background:linear-gradient(135deg,var(--clr-ocean-glow),rgba(61,184,189,.04));border-left:4px solid var(--clr-ocean);border-radius:0 12px 12px 0}
.pull-quote p{font-family:var(--ff-display);font-size:1.25rem;color:var(--clr-heading);line-height:1.6;margin:0}
.pull-quote .pull-attr{font-family:var(--ff-body);font-size:.78rem;color:var(--clr-text-mute);margin-top:var(--sp-md);font-style:normal;letter-spacing:.06em;text-transform:uppercase;font-weight:600}

.highlight-box{padding:var(--sp-xl);margin:var(--sp-xl) 0;border-radius:12px;border:1px solid var(--clr-border-lt);position:relative;overflow:hidden}
.highlight-box--ocean{background:linear-gradient(135deg,rgba(10,110,138,.04),rgba(61,184,189,.03));border-color:rgba(10,110,138,.12)}
.highlight-box--sunset{background:linear-gradient(135deg,rgba(224,122,66,.04),rgba(252,224,204,.2));border-color:var(--clr-border-warm)}
.highlight-box--ocean::before,.highlight-box--sunset::before{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.highlight-box--ocean::before{background:linear-gradient(90deg,var(--clr-ocean-deep),var(--clr-ocean),var(--clr-aqua))}
.highlight-box--sunset::before{background:linear-gradient(90deg,var(--clr-sunset-deep),var(--clr-sunset),var(--clr-sunset-light))}
.highlight-box h3,.highlight-box h4{margin-bottom:var(--sp-md)}
.highlight-box p{color:var(--clr-text-dim);margin-bottom:var(--sp-sm)}
.highlight-box p:last-child{margin-bottom:0}

/* PROCESS STEPS WITH NUMBERS */
.process-grid{display:grid;grid-template-columns:1fr;gap:var(--sp-lg);margin:var(--sp-xl) 0}
@media(min-width:768px){.process-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.process-grid{grid-template-columns:1fr 1fr 1fr}}
.process-step{padding:var(--sp-xl);background:var(--clr-bg);border:1px solid var(--clr-border-lt);border-radius:12px;position:relative;overflow:hidden;transition:border-color var(--dur),box-shadow var(--dur)}
.process-step:hover{border-color:var(--clr-border);box-shadow:var(--shadow-md)}
.process-step::before{content:'';position:absolute;top:0;left:0;bottom:0;width:3px;background:linear-gradient(180deg,var(--clr-ocean),var(--clr-aqua))}
.step-num{font-family:var(--ff-display);font-size:2.2rem;color:var(--clr-ocean-pale);line-height:1;margin-bottom:var(--sp-sm);opacity:.7}
.process-step h4{margin-bottom:var(--sp-sm);color:var(--clr-heading)}
.process-step p{font-size:.92rem;color:var(--clr-text-dim);margin:0}

/* ICON FEATURE CARDS */
.feature-card{padding:var(--sp-xl);background:var(--clr-bg);border:1px solid var(--clr-border-lt);border-radius:12px;transition:all var(--dur)}
.feature-card:hover{border-color:var(--clr-border);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.feature-icon{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:var(--sp-lg)}
.feature-icon--ocean{background:linear-gradient(135deg,rgba(10,110,138,.1),rgba(61,184,189,.08))}
.feature-icon--ocean svg{stroke:var(--clr-ocean);width:24px;height:24px}
.feature-icon--sunset{background:linear-gradient(135deg,rgba(224,122,66,.1),rgba(252,224,204,.3))}
.feature-icon--sunset svg{stroke:var(--clr-sunset);width:24px;height:24px}
.feature-card h4{margin-bottom:var(--sp-sm)}
.feature-card p{font-size:.92rem;color:var(--clr-text-dim);margin:0}

/* SPLIT SECTIONS (text + visual side-by-side) */
.split{display:grid;grid-template-columns:1fr;gap:var(--sp-2xl);align-items:center}
@media(min-width:768px){.split{grid-template-columns:1fr 1fr}.split--reverse{direction:rtl}.split--reverse>*{direction:ltr}}
.split--compact{gap:var(--sp-xl)}
.split-visual{position:relative;border-radius:12px;overflow:hidden;min-height:300px}
.split-visual--gradient{background:linear-gradient(135deg,var(--clr-ocean-pale) 0%,var(--clr-aqua-pale) 40%,var(--clr-sunset-light) 100%);display:flex;align-items:center;justify-content:center;padding:var(--sp-2xl)}

/* SITE IMAGES */
.site-image{position:relative;overflow:hidden;border-radius:12px;border:1px solid var(--clr-border-lt);box-shadow:var(--shadow-lg);background:var(--clr-surface)}
.site-image img{width:100%;height:100%;object-fit:cover}
.site-image--hero{aspect-ratio:3/2;box-shadow:0 20px 60px rgba(0,0,0,.22);border-color:rgba(255,255,255,.14)}
.site-image--square{aspect-ratio:1/1;max-width:420px;justify-self:end}
.site-image--portrait{aspect-ratio:4/5;max-width:300px}
.principal-photo-wrap{display:flex;justify-content:center;align-items:flex-start}
.principal-photo{width:min(100%,300px)}
@media(max-width:767px){
  .site-image--square{justify-self:stretch;max-width:none}
  .site-image--portrait{max-width:260px}
}

/* NUMBERED LIST STYLED */
.numbered-list{counter-reset:numlist;margin:var(--sp-xl) 0}
.numbered-item{display:flex;gap:var(--sp-lg);padding:var(--sp-lg) 0;border-bottom:1px solid var(--clr-border-lt)}
.numbered-item:last-child{border-bottom:none}
.numbered-item::before{counter-increment:numlist;content:counter(numlist,decimal-leading-zero);font-family:var(--ff-display);font-size:1.8rem;color:var(--clr-ocean-pale);line-height:1;flex-shrink:0;min-width:40px;padding-top:2px}
.numbered-item div h4{color:var(--clr-heading);margin-bottom:var(--sp-xs)}
.numbered-item div p{color:var(--clr-text-dim);font-size:.92rem;margin:0}

/* GRADIENT DIVIDERS */
.gradient-divider{height:2px;background:linear-gradient(90deg,transparent,var(--clr-ocean),var(--clr-aqua),var(--clr-sunset),transparent);margin:var(--sp-3xl) auto;max-width:400px;border:none;opacity:.4}

/* BADGE VARIANTS */
.badge{display:inline-block;padding:.3rem .8rem;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border-radius:20px}
.badge--ocean{background:rgba(10,110,138,.08);color:var(--clr-ocean);border:1px solid rgba(10,110,138,.15)}
.badge--sunset{background:rgba(224,122,66,.08);color:var(--clr-sunset-deep);border:1px solid rgba(224,122,66,.15)}

/* FULL-WIDTH COLOR BANDS */
.band--ocean{background:linear-gradient(135deg,var(--clr-ocean-deep),var(--clr-ocean));color:var(--clr-white)}
.band--ocean h2,.band--ocean h3{color:var(--clr-white)}
.band--ocean .lead,.band--ocean p{color:rgba(255,255,255,.85)}
.band--ocean .eyebrow{color:var(--clr-ocean-light)}
.band--ocean a{color:var(--clr-ocean-light)}
.band--ocean .btn--outline{color:var(--clr-white);border-color:rgba(255,255,255,.4)}
.band--ocean .btn--outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.7)}

/* TWO-TONE SECTION */
.two-tone{display:grid;grid-template-columns:1fr;min-height:400px}
@media(min-width:768px){.two-tone{grid-template-columns:1fr 1fr}}
.two-tone-left{padding:var(--sp-3xl) var(--sp-xl);display:flex;flex-direction:column;justify-content:center}
.two-tone-right{padding:var(--sp-3xl) var(--sp-xl);display:flex;flex-direction:column;justify-content:center;background:var(--clr-bg-alt)}
@media(min-width:768px){.two-tone-left{padding:var(--sp-3xl) var(--sp-2xl) var(--sp-3xl) 0}.two-tone-right{padding:var(--sp-3xl) 0 var(--sp-3xl) var(--sp-2xl)}}

/* ICON LIST */
.icon-list{margin:var(--sp-lg) 0}
.icon-list-item{display:flex;gap:var(--sp-md);padding:var(--sp-md) 0;align-items:flex-start}
.icon-list-item svg{flex-shrink:0;width:20px;height:20px;stroke:var(--clr-ocean);margin-top:2px}
.icon-list-item p{font-size:.92rem;color:var(--clr-text-dim);margin:0}
.icon-list-item strong{color:var(--clr-heading)}

/* SECTION LABEL ACCENT */
.section-label{display:flex;align-items:center;gap:var(--sp-md);margin-bottom:var(--sp-xl)}
.section-label::after{content:'';flex:1;height:1px;background:linear-gradient(90deg,var(--clr-border),transparent)}

/* ENHANCED CARD VARIANTS */
.card--gradient{background:linear-gradient(135deg,rgba(10,110,138,.03),rgba(61,184,189,.02),rgba(224,122,66,.02))}
.card--bordered-ocean{border-left:3px solid var(--clr-ocean)}
.card--bordered-sunset{border-left:3px solid var(--clr-sunset)}
.card--dark{background:var(--clr-heading);color:rgba(255,255,255,.85)}
.card--dark h3,.card--dark h4{color:var(--clr-white)}

/* RESPONSIVE POLISH */
@media(max-width:767px){
  .pull-quote{padding:var(--sp-lg) var(--sp-lg) var(--sp-lg) calc(var(--sp-lg) + 4px)}
  .pull-quote p{font-size:1.1rem}
  .stat-row{grid-template-columns:1fr 1fr}
  .process-grid{gap:var(--sp-md)}
  .two-tone-left,.two-tone-right{padding:var(--sp-xl) var(--sp-lg)}
}
