/* HP Construction — Coastal stylesheet · shared across all pages */

:root{
  --white:#FFFFFF;
  --bone:#FAF7F1;
  --sand:#EDE7DA;
  --ink:#1A1817;
  --ink-soft:#3A3633;
  --taupe:#8B7F70;
  --rule:rgba(26,24,23,.10);
  --rule-strong:rgba(26,24,23,.22);
  --accent:#1565A0;
  --accent-soft:#2A7AB5;
  --olive:#C9A876;          /* renamed concept — now camel/tan for warm editorial accents */
  --olive-soft:#D8BC8E;
  --olive-deep:#0B2E4F;     /* deep navy — cinematic dark moments */
  --navy:#0B2E4F;
  --navy-soft:#163048;
  --camel:#C9A876;
  --sky:#80C2DF;
  --powder:#C6D1DC;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ——— RESET + BASE ——— */
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--white);color:var(--ink);font-family:"Inter",system-ui,sans-serif;font-weight:300;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;line-height:1.6;font-size:15px}
::selection{background:var(--accent);color:#fff}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.serif{font-family:"Cormorant Garamond",Georgia,serif;font-weight:300}

/* ——— TOP UTILITY BAR ——— */
.util{display:flex;justify-content:space-between;align-items:center;padding:10px 36px;border-bottom:1px solid var(--rule);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--taupe)}
.util .left span{color:var(--accent);font-weight:500}

/* ——— NAVIGATION ——— */
nav.main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:26px 36px;border-bottom:1px solid var(--rule);background:var(--white);position:sticky;top:0;z-index:50;transition:padding .3s var(--ease),box-shadow .3s var(--ease)}
nav.main.scrolled{padding:18px 36px;box-shadow:0 1px 0 var(--rule),0 8px 30px rgba(26,24,23,.04)}
nav.main ul.left,nav.main ul.right{display:flex;list-style:none;gap:36px;align-items:center}
nav.main ul.right{justify-content:flex-end}
nav.main ul li a{font-size:12px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:var(--ink);padding-bottom:4px;border-bottom:1px solid transparent;transition:border-color .3s var(--ease),color .3s var(--ease)}
nav.main ul li a:hover{border-color:var(--ink)}
nav.main ul li.active a{border-color:var(--ink)}
nav.main ul li.cta a{border:1px solid var(--ink);padding:10px 20px;letter-spacing:.22em}
nav.main ul li.cta a:hover{background:var(--ink);color:#fff}
nav.main .mark{display:flex;flex-direction:column;align-items:center;gap:4px;justify-self:center}
nav.main .mark svg{height:30px;width:auto;color:var(--accent);display:block;transition:transform .35s var(--ease)}
nav.main .mark:hover svg{transform:translateY(-1px)}
nav.main .mark .wm{font-family:"Inter",sans-serif;font-size:9px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;color:var(--ink);margin-top:2px}

/* ——— PAGE HEADER (non-home page) ——— */
.page-header{padding:120px 36px 80px;text-align:center;background:var(--white);border-bottom:1px solid var(--rule)}
.page-header .eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin-bottom:24px;font-weight:500;display:inline-flex;align-items:center;gap:14px}
.page-header .eyebrow::before,.page-header .eyebrow::after{content:"";display:inline-block;width:30px;height:1px;background:var(--accent)}
.page-header h1{font-family:"Cormorant Garamond",serif;font-weight:300;font-size:clamp(46px,5.5vw,72px);line-height:1.05;letter-spacing:-.005em;max-width:1100px;margin:0 auto 28px;color:var(--ink)}
.page-header h1 em{font-style:italic}
.page-header p{font-size:16px;line-height:1.7;color:var(--ink-soft);max-width:640px;margin:0 auto}

/* ——— SECTION COMMON ——— */
section.bone-bg{background:var(--bone)}
section.sand-bg{background:var(--sand)}

/* ——— TESTIMONIAL ELEMENT (used across pages) ——— */
.testimonial-card{background:var(--white);padding:50px 44px;border:1px solid var(--rule);position:relative}
.testimonial-card::before{content:"\201C";position:absolute;top:22px;left:30px;font-family:"Cormorant Garamond",serif;font-size:64px;color:var(--olive);line-height:.5;opacity:.65}
.testimonial-card blockquote{font-family:"Cormorant Garamond",serif;font-weight:300;font-style:italic;font-size:21px;line-height:1.45;color:var(--ink);padding-top:14px;margin-bottom:30px}
.testimonial-card cite{font-style:normal;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--taupe);font-weight:500;display:block;padding-top:24px;border-top:1px solid var(--rule)}
.testimonial-card cite span{color:var(--ink);display:block;font-size:14px;font-family:"Cormorant Garamond",serif;font-style:italic;letter-spacing:.005em;text-transform:none;margin-bottom:6px;font-weight:300}

/* ——— LOC CHIP (image caption used across pages) ——— */
.loc-chip{position:absolute;bottom:20px;left:24px;z-index:3;color:#fff;font-size:10px;letter-spacing:.28em;text-transform:uppercase;font-family:"Inter",sans-serif;font-weight:500;line-height:1.6;text-shadow:0 1px 10px rgba(0,0,0,.7),0 1px 2px rgba(0,0,0,.5);transition:transform .4s var(--ease)}
.loc-chip small{display:block;font-family:"Cormorant Garamond",serif;font-size:15px;letter-spacing:.005em;text-transform:none;color:#fff;opacity:.95;margin-top:6px;font-weight:300;font-style:normal}

/* ——— CONTACT GRID (shared) ——— */
.contact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;color:var(--ink-soft);font-size:14px;text-align:left}
.contact-grid div span{display:block;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-bottom:10px;font-weight:500}
.contact-grid a{display:block;color:var(--ink);border-bottom:1px solid transparent;transition:border-color .3s var(--ease);padding-bottom:1px;width:fit-content;max-width:100%;overflow-wrap:anywhere;word-break:break-word}
.contact-grid a:hover{border-color:var(--accent)}

/* ——— INSTAGRAM PREVIEW (CMS plugin slot) ——— */
section.instagram{padding:120px 36px;background:var(--white);border-top:1px solid var(--rule)}
section.instagram .head{max-width:1280px;margin:0 auto 50px;display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
section.instagram .head .left .label{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;font-weight:500}
section.instagram .head h2{font-family:"Cormorant Garamond",serif;font-weight:300;font-size:clamp(30px,3.4vw,42px);line-height:1.1;color:var(--ink);letter-spacing:-.005em}
section.instagram .head h2 em{font-style:italic;color:var(--olive)}
section.instagram .head .follow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:5px;font-weight:500;transition:color .3s var(--ease)}
section.instagram .head .follow:hover{color:var(--accent)}
section.instagram .head .follow strong{font-family:"Cormorant Garamond",serif;font-weight:300;font-style:italic;font-size:18px;letter-spacing:.005em;text-transform:none;margin-right:8px;color:var(--ink)}
section.instagram .grid{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
section.instagram .tile{aspect-ratio:1;position:relative;overflow:hidden;background:var(--sand);display:block;transition:transform .4s var(--ease)}
section.instagram .tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s var(--ease),filter .4s var(--ease);filter:brightness(.96)}
section.instagram .tile:hover img{transform:scale(1.04);filter:brightness(1)}
section.instagram .tile::after{content:"";position:absolute;inset:0;background:rgba(15,15,14,0);transition:background .3s var(--ease);z-index:2}
section.instagram .tile:hover::after{background:rgba(15,15,14,.15)}
section.instagram .tile .ig-icon{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.7);opacity:0;z-index:3;color:#fff;font-size:20px;transition:opacity .3s var(--ease),transform .35s var(--ease)}
section.instagram .tile:hover .ig-icon{opacity:1;transform:translate(-50%,-50%) scale(1)}
section.instagram .plugin-note{max-width:1280px;margin:36px auto 0;padding:14px 18px;background:rgba(21,101,160,.06);border-left:3px solid var(--accent);font-size:12px;color:var(--ink-soft);font-style:italic;font-weight:300}
section.instagram .plugin-note strong{font-family:"Inter",sans-serif;font-style:normal;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--accent);margin-right:12px;font-weight:600}

@media (max-width:900px){
  section.instagram{padding:60px 22px}
  section.instagram .head h2{font-size:26px}
  section.instagram .grid{grid-template-columns:repeat(3,1fr);gap:4px}
}

/* ——— RICH FOOTER ——— */
footer{padding:60px 36px 30px;background:var(--olive-deep);color:rgba(255,255,255,.78);border-top:0}
footer .footer-inner{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:50px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.12)}
footer .footer-col h6{font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:#fff;margin-bottom:18px;font-weight:500}
footer .footer-col p{font-size:13px;line-height:1.7;color:rgba(255,255,255,.7);margin-bottom:0}
footer .footer-col a{display:block;font-size:13px;color:rgba(255,255,255,.85);line-height:1.85;border-bottom:1px solid transparent;width:fit-content;max-width:100%;overflow-wrap:anywhere;transition:color .3s var(--ease),border-color .3s var(--ease)}
footer .footer-col a:hover{color:#fff;border-color:rgba(255,255,255,.6)}
footer .footer-col .colophon{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:22px;letter-spacing:-.005em;color:#fff;margin-bottom:14px;text-transform:none}
footer .footer-col .tag{font-family:"Cormorant Garamond",serif;font-style:italic;font-size:15px;color:rgba(255,255,255,.85);max-width:32ch;line-height:1.5;letter-spacing:.005em;text-transform:none}
footer .footer-bottom{max-width:1280px;margin:0 auto;padding-top:30px;display:flex;justify-content:space-between;align-items:center;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.55);font-weight:500;gap:24px;flex-wrap:wrap}
footer .footer-bottom .links a{color:rgba(255,255,255,.7);border-bottom:1px solid transparent;padding-bottom:2px;margin-left:24px;transition:color .3s var(--ease),border-color .3s var(--ease)}
footer .footer-bottom .links a:first-child{margin-left:0}
footer .footer-bottom .links a:hover{color:#fff;border-color:rgba(255,255,255,.6)}

@media (max-width:900px){
  footer{padding:50px 22px 24px;text-align:left}
  footer .footer-inner{grid-template-columns:1fr;gap:34px;padding-bottom:30px;text-align:left}
  footer .footer-col{text-align:left}
  footer .footer-col h6{margin-bottom:12px}
  footer .footer-col p,footer .footer-col a{text-align:left}
  footer .footer-col a{display:block;width:auto;max-width:100%}
  footer .footer-col .colophon{text-align:left;font-size:24px;margin-bottom:10px}
  footer .footer-col .tag{text-align:left;max-width:42ch}
  footer .footer-bottom{flex-direction:column;align-items:flex-start;text-align:left;padding-top:24px;gap:14px}
  footer .footer-bottom .links{display:flex;gap:24px}
  footer .footer-bottom .links a{margin-left:0;margin-right:0}
}

/* ——— PRIMARY CTA ——— */
.cta-primary{display:inline-flex;align-items:center;gap:14px;background:var(--ink);color:#fff;padding:18px 40px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;transition:background .3s var(--ease),transform .25s var(--ease)}
.cta-primary:hover{background:var(--accent);transform:translateY(-2px)}
.cta-secondary{display:inline-flex;align-items:center;gap:12px;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:5px;font-weight:500;transition:color .3s var(--ease),border-color .3s var(--ease)}
.cta-secondary:hover{color:var(--accent);border-color:var(--accent)}

/* ——— GRAIN TEXTURE OVERLAY (ultra-fine, tactile) ——— */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.04;mix-blend-mode:multiply;background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");background-size:200px}

/* ——— PAGE ENTER REVEAL ——— */
.page-enter{position:fixed;inset:0;background:var(--white);z-index:9999;display:flex;align-items:center;justify-content:center;pointer-events:none;animation:enterFade 1.4s var(--ease) .6s forwards}
.page-enter .mark{display:flex;flex-direction:column;align-items:center;gap:10px;opacity:0;animation:enterMark 1.4s var(--ease) .1s forwards}
.page-enter .mark svg{height:42px;width:auto;color:var(--accent)}
.page-enter .mark .wm{font-family:"Inter",sans-serif;font-weight:600;font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--ink)}
.page-enter .mark .hairline{width:0;height:1px;background:var(--camel);margin-top:14px;animation:enterLine 1.2s var(--ease) .5s forwards}
@keyframes enterFade { 0%{opacity:1} 70%{opacity:1} 100%{opacity:0;visibility:hidden} }
@keyframes enterMark { 0%{opacity:0;transform:translateY(8px)} 30%{opacity:1;transform:none} 80%{opacity:1;transform:none} 100%{opacity:0} }
@keyframes enterLine { 0%{width:0} 50%{width:80px} 100%{width:0;opacity:0} }

/* ——— MARQUEE SUBURB STRIP ——— */
section.marquee-band{padding:36px 0;background:var(--bone);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);overflow:hidden;position:relative}
section.marquee-band::before,section.marquee-band::after{content:"";position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
section.marquee-band::before{left:0;background:linear-gradient(90deg,var(--bone) 0%,rgba(250,247,241,0) 100%)}
section.marquee-band::after{right:0;background:linear-gradient(270deg,var(--bone) 0%,rgba(250,247,241,0) 100%)}
section.marquee-band .marquee-track{display:flex;gap:50px;white-space:nowrap;animation:marquee 50s linear infinite;will-change:transform}
section.marquee-band .marquee-track span{font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:300;font-size:38px;color:var(--ink);letter-spacing:-.005em;display:inline-flex;align-items:center;gap:50px}
section.marquee-band .marquee-track span::after{content:"";display:inline-block;width:8px;height:8px;background:var(--camel);border-radius:50%;flex-shrink:0}
section.marquee-band:hover .marquee-track{animation-play-state:paused}
@keyframes marquee { from { transform:translateX(0) } to { transform:translateX(-50%) } }

/* ——— CURSOR-FOLLOW BADGE ——— */
.cursor-badge{position:fixed;top:0;left:0;z-index:9000;pointer-events:none;transform:translate(-50%,-50%) scale(.6);opacity:0;transition:opacity .35s var(--ease),transform .35s var(--ease);background:var(--ink);color:#fff;font-family:"Inter",sans-serif;font-size:10px;letter-spacing:.32em;text-transform:uppercase;font-weight:500;padding:18px 24px;border-radius:50%;width:96px;height:96px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.2;mix-blend-mode:normal}
.cursor-badge.active{opacity:1;transform:translate(-50%,-50%) scale(1)}
.cursor-badge.featured{background:var(--camel)}
@media (hover:none) or (pointer:coarse){ .cursor-badge{display:none} }

/* ——— PARALLAX (image moves slower than scroll) ——— */
[data-parallax]{will-change:transform;transition:transform .15s linear}

/* ——— FOCUS STATES ——— */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
a:focus-visible,button:focus-visible{outline-offset:4px}

/* ——— ANIMATIONS ——— */
@keyframes fadeIn { from { opacity:0; transform:translateY(20px) } to { opacity:1; transform:none } }
@keyframes heroSettle { from { opacity:0; transform:scale(1.04) } to { opacity:1; transform:scale(1) } }
nav.main { animation: fadeIn .6s var(--ease) 1.5s both }
.util { animation: fadeIn .5s var(--ease) 1.35s both }
.page-header { animation: fadeIn .9s var(--ease) 1.6s both }

[data-reveal]{opacity:0;transform:translateY(22px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
[data-reveal].in-view{opacity:1;transform:none}
[data-reveal-delay="1"].in-view{transition-delay:.1s}
[data-reveal-delay="2"].in-view{transition-delay:.2s}
[data-reveal-delay="3"].in-view{transition-delay:.3s}

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
  [data-reveal]{opacity:1;transform:none}
}

/* ——— HAMBURGER MENU (mobile) ——— */
nav.main{position:relative}
.nav-toggle{display:none;background:transparent;border:0;cursor:pointer;padding:10px;width:44px;height:44px;flex-direction:column;justify-content:center;align-items:center;gap:5px;z-index:60;position:absolute;right:18px;top:50%;transform:translateY(-50%)}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);transition:transform .35s var(--ease),opacity .25s var(--ease)}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

.nav-overlay{position:fixed;inset:0;background:var(--white);z-index:40;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s var(--ease)}
.nav-overlay.open{opacity:1;pointer-events:auto}
.nav-overlay ul{list-style:none;text-align:center;padding:0}
.nav-overlay ul li{margin-bottom:20px;opacity:0;transform:translateY(16px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.nav-overlay.open ul li{opacity:1;transform:none}
.nav-overlay.open ul li:nth-child(1){transition-delay:.12s}
.nav-overlay.open ul li:nth-child(2){transition-delay:.18s}
.nav-overlay.open ul li:nth-child(3){transition-delay:.24s}
.nav-overlay.open ul li:nth-child(4){transition-delay:.3s}
.nav-overlay.open ul li:nth-child(5){transition-delay:.36s}
.nav-overlay ul li a{font-family:"Cormorant Garamond",serif;font-weight:300;font-size:34px;color:var(--ink);letter-spacing:-.005em;display:inline-block;padding:6px 0;border-bottom:1px solid transparent;transition:border-color .3s var(--ease),color .3s var(--ease)}
.nav-overlay ul li a:hover{border-color:var(--ink)}
.nav-overlay ul li.cta a{font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:500;border:1px solid var(--ink);padding:14px 30px;margin-top:18px}
.nav-overlay ul li.cta a:hover{background:var(--ink);color:#fff}
.nav-overlay .nav-foot{position:absolute;bottom:30px;left:0;right:0;text-align:center;font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--taupe);font-weight:500;opacity:0;transition:opacity .5s var(--ease) .5s}
.nav-overlay.open .nav-foot{opacity:1}
.nav-overlay .nav-foot a{color:var(--ink);border-bottom:1px solid var(--accent);padding-bottom:2px}
body.nav-open{overflow:hidden}

/* ——— TABLET + MOBILE ——— */
@media (max-width:1100px){
  nav.main ul.left,nav.main ul.right{display:none}
  nav.main{grid-template-columns:auto 1fr auto;padding:18px 22px}
  nav.main .mark{justify-self:start;flex-direction:row;align-items:center;gap:12px}
  nav.main .mark .wm{margin-top:0;border-left:1px solid var(--rule);padding-left:12px}
  .nav-toggle{display:flex}
}
@media (max-width:900px){
  .util{display:none}
  .page-header{padding:80px 22px 60px}
  .page-header h1{font-size:34px}
  .contact-grid{grid-template-columns:1fr 1fr;gap:26px;font-size:13px}
  .contact-grid a{font-size:13px}
  footer{flex-direction:column;gap:12px;text-align:center;padding:30px 22px}
}
