/* ===================================================================
   INDIE ROAD HONOLULU — "Warm Local" (Direction B)
   Full multi-page stylesheet · Fraunces + Inter · indigo/bronze/cream
   =================================================================== */

:root{
  --indigo:#132E52; --indigo-d:#0E2341; --light-indigo:#405D7F;
  --beige:#E69E6C; --bronze-d:#A96847; --bronze-l:#F8C297; --bronze-text:#8A4F33;
  --sand:#F3ECE2; --paper:#FAF6F0; --cream:#FFFDF8;
  --ink:#1B2940; --body:#41484F; --muted:#78807A;
  --line:#E4DDD1;
  --h:'Fraunces','Cormorant Garamond',Georgia,serif;
  --b:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
  --wrap:1240px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--b);background:var(--cream);color:var(--body);line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--indigo);outline-offset:2px;border-radius:4px}
.nav :focus-visible,.menu a:focus-visible,.menu .cta:focus-visible,.nav-toggle:focus-visible,.btn-ghost:focus-visible,.hero :focus-visible,.phero :focus-visible{outline-color:#fff}
.skip{position:absolute;left:-9999px}
.skip:focus{position:fixed;left:16px;top:16px;z-index:100;background:#fff;color:var(--indigo);padding:10px 16px;border-radius:6px}
img{max-width:100%;display:block}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 36px}

.eyebrow{font-size:.72rem;letter-spacing:3.5px;text-transform:uppercase;font-weight:600}

/* ---------- BUTTONS ---------- */
.btn{display:inline-block;padding:14px 30px;font-size:.85rem;letter-spacing:.5px;font-weight:500;border-radius:999px;transition:all .2s;cursor:pointer;border:1px solid transparent}
.btn-primary{background:#fff;color:var(--indigo)}
.btn-primary:hover{background:var(--bronze-l);color:var(--indigo)}
.btn-solid{background:var(--beige);color:var(--indigo);font-weight:600}
.btn-solid:hover{background:var(--bronze-l)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ---------- NAV ---------- */
.nav{position:absolute;top:0;left:0;right:0;z-index:30;padding:24px 0}
.nav-row{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:13px;color:#fff}
.brand img{width:50px;height:50px}
.brand-name{font-family:var(--h);font-weight:400;font-size:1.1rem;letter-spacing:.3px}
.brand-sub{font-size:.6rem;letter-spacing:2.5px;text-transform:uppercase;opacity:.75;margin-top:3px}
.menu{display:flex;gap:34px;align-items:center}
.menu a{color:rgba(255,255,255,.9);font-size:.86rem;letter-spacing:.4px;padding:10px 8px;border-bottom:1px solid transparent;transition:.2s}
.menu a:hover,.menu a.active{border-bottom-color:var(--beige)}
.menu .cta{background:var(--beige);color:var(--indigo);padding:10px 22px;border-radius:999px;border:none;font-weight:600;font-size:.8rem}
.menu .cta:hover{background:var(--bronze-l)}
.menu .cta.active{border-bottom:none}
.nav-toggle{display:none;background:none;border:none;color:#fff;font-size:1.55rem;cursor:pointer;line-height:1}

/* ---------- HOME HERO (photo) ---------- */
.hero{position:relative;min-height:90vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0;transform:scale(1.02)}
.hero::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(19,46,82,.5)0%,rgba(19,46,82,.2)38%,rgba(14,35,65,.88)100%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:94px;padding-top:140px}
.hero-eyebrow{color:var(--bronze-l);margin-bottom:18px}
.hero h1{font-family:var(--h);font-weight:300;font-size:4.2rem;line-height:1.03;letter-spacing:-1px;max-width:880px;margin-bottom:22px}
.hero h1 em{font-style:italic;font-weight:400;color:#FFE3C7}
.hero p{font-size:1.06rem;max-width:520px;line-height:1.7;color:rgba(255,255,255,.9);margin-bottom:32px}
.hero-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.hero-meta{position:absolute;right:36px;bottom:34px;text-align:right;color:rgba(255,255,255,.75);font-size:.72rem;letter-spacing:1.5px;text-transform:uppercase;z-index:2}
.hero-meta strong{display:block;font-family:var(--h);font-size:1.1rem;font-style:italic;letter-spacing:0;text-transform:none;color:#fff;margin-bottom:3px;font-weight:400}

/* ---------- PAGE HERO (inner) ---------- */
.phero{position:relative;min-height:50vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:linear-gradient(160deg,#16335c,#0E2341)}
.phero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.phero.has-photo::after{content:'';position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(19,46,82,.5),rgba(14,35,65,.85))}
.phero-inner{position:relative;z-index:2;width:100%;padding:150px 0 64px}
.phero .eyebrow{color:var(--bronze-l);margin-bottom:16px}
.phero h1{font-family:var(--h);font-weight:300;font-size:3.4rem;line-height:1.05;letter-spacing:-.5px;margin-bottom:14px}
.phero h1 em{font-style:italic;color:#FFE3C7}
.phero p{color:rgba(255,255,255,.84);max-width:580px;font-size:1.05rem;line-height:1.7}

/* ---------- INTRO (editorial quote) ---------- */
.intro{padding:108px 0;background:var(--cream)}
.intro-grid{display:grid;grid-template-columns:1.1fr 2fr;gap:64px;align-items:start}
.intro-label{font-size:.72rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--bronze-text);font-weight:600;position:relative;padding-left:54px;padding-top:14px}
.intro-label::before{content:'';position:absolute;left:0;top:22px;width:40px;height:1px;background:var(--bronze-text)}
.intro-text p{font-family:var(--h);font-weight:300;font-size:1.8rem;line-height:1.42;color:var(--indigo);letter-spacing:-.3px;margin-bottom:20px}
.intro-text .sig{font-family:var(--b);font-size:.82rem;color:var(--muted);letter-spacing:.3px}
.intro-text .sig strong{color:var(--indigo);font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:.72rem;display:block;margin-top:4px}

/* ---------- SECTION HEADERS ---------- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;border-bottom:1px solid var(--line);padding-bottom:24px}
.sec-head h2{font-family:var(--h);font-weight:300;font-size:2.8rem;color:var(--indigo);letter-spacing:-.5px;line-height:1}
.sec-head h2 em{font-style:italic;color:var(--bronze-d)}
.sec-head .link{font-size:.76rem;letter-spacing:2px;text-transform:uppercase;color:var(--indigo);font-weight:600;border-bottom:1px solid var(--bronze-d);padding-bottom:4px;white-space:nowrap}
.head-center{text-align:center;margin-bottom:64px}
.head-center .kicker{display:block;font-size:.72rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--bronze-text);font-weight:600;margin-bottom:16px}
.head-center h2{font-family:var(--h);font-weight:300;font-size:3.1rem;color:var(--indigo);letter-spacing:-.5px;line-height:1.05}
.head-center h2 em{font-style:italic;color:var(--bronze-d);font-weight:400}
.head-center p{color:var(--body);font-size:1.05rem;margin-top:16px;max-width:560px;margin-left:auto;margin-right:auto}

/* ---------- SERVICES strip (home) ---------- */
.services-sec{padding:96px 0;background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.services-row{display:grid;grid-template-columns:repeat(4,1fr);background:var(--paper);border:1px solid var(--line)}
.svc{padding:36px 28px;border-right:1px solid var(--line);transition:background .2s}
.svc:last-child{border-right:none}
.svc:hover{background:var(--cream)}
.svc-num{font-family:var(--h);font-style:italic;font-weight:300;font-size:1.8rem;color:var(--bronze-d);margin-bottom:16px}
.svc h3{font-family:var(--h);font-weight:400;font-size:1.3rem;color:var(--indigo);margin-bottom:10px;line-height:1.15}
.svc p{font-size:.86rem;color:var(--body);line-height:1.6;margin-bottom:16px}
.svc-link{font-size:.66rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--bronze-text);font-weight:600}

/* ---------- SERVICES grid (services page) ---------- */
.svc-grid-sec{padding:120px 0;background:var(--cream)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border:1px solid var(--line);background:var(--paper)}
.svc-card{padding:44px 40px;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .2s}
.svc-card:nth-child(2n){border-right:none}
.svc-card:hover{background:var(--cream)}
.svc-card .svc-num{font-size:1.6rem}
.svc-card h3{font-family:var(--h);font-weight:400;font-size:1.5rem;color:var(--indigo);margin-bottom:12px}
.svc-card p{font-size:.94rem;color:var(--body);line-height:1.7}

/* ---------- WORK feature + supports (home) ---------- */
.work{padding:124px 0;background:var(--cream)}
.feature{display:grid;grid-template-columns:1.3fr 1fr;gap:56px;align-items:center;margin-bottom:84px}
.feature-img{height:480px;border-radius:4px;background-size:cover;background-position:center;position:relative;box-shadow:0 30px 60px -30px rgba(19,46,82,.45)}
.feature-img::before{content:'';position:absolute;inset:24px;border:1px solid rgba(255,255,255,.25);border-radius:2px;pointer-events:none}
.feature-body .num{font-family:var(--h);font-style:italic;font-weight:300;font-size:1.1rem;color:var(--bronze-d);margin-bottom:12px}
.feature-body .tag{font-size:.66rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:10px}
.feature-body h3{font-family:var(--h);font-weight:400;font-size:2.3rem;color:var(--indigo);letter-spacing:-.3px;line-height:1.1;margin-bottom:20px}
.feature-body p{color:var(--body);font-size:1rem;line-height:1.8;margin-bottom:24px}
.readmore{font-size:.74rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--indigo);font-weight:600;border-bottom:1px solid var(--bronze-d);padding-bottom:4px}
.supports{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.support{cursor:pointer}
.support-img{height:260px;background-size:cover;background-position:center;border-radius:4px;margin-bottom:18px;transition:transform .3s,box-shadow .3s;box-shadow:0 18px 36px -24px rgba(19,46,82,.5)}
.support:hover .support-img{transform:translateY(-5px);box-shadow:0 26px 46px -24px rgba(19,46,82,.55)}
.support .tag{font-size:.64rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--bronze-text);font-weight:600;margin-bottom:8px}
.support h4{font-family:var(--h);font-weight:400;font-size:1.3rem;color:var(--indigo);margin-bottom:8px;letter-spacing:-.2px}
.support p{font-size:.86rem;color:var(--body);line-height:1.55}

/* ---------- PROJECTS page (alternating rows) ---------- */
.projects{padding:120px 0 30px;background:var(--cream)}
.proj{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;margin-bottom:96px}
.proj-img{height:440px;border-radius:4px;background-size:cover;background-position:center;box-shadow:0 30px 60px -32px rgba(19,46,82,.45)}
.proj:nth-child(even) .proj-text{order:-1}
.proj-text .num{font-family:var(--h);font-style:italic;font-weight:300;font-size:1.1rem;color:var(--bronze-d);margin-bottom:12px}
.proj-text .tag{font-size:.66rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:10px}
.proj-text h3{font-family:var(--h);font-weight:400;font-size:2.1rem;color:var(--indigo);letter-spacing:-.3px;line-height:1.12;margin-bottom:18px}
.proj-text p{color:var(--body);font-size:.98rem;line-height:1.8}
.proj-soon{border:1px dashed var(--bronze-d);border-radius:6px;background:var(--paper);padding:54px 40px;text-align:center;margin-bottom:40px}
.proj-soon .tag{font-size:.66rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:12px}
.proj-soon h3{font-family:var(--h);font-weight:400;font-size:1.7rem;color:var(--indigo);margin-bottom:10px}
.proj-soon p{color:var(--muted);max-width:560px;margin:0 auto;font-size:.95rem}

/* ---------- ABOUT prose + values ---------- */
.prose{padding:112px 0;background:var(--cream)}
.prose-inner{max-width:760px;margin:0 auto}
.prose-lead{font-family:var(--h);font-weight:300;font-size:1.9rem;line-height:1.42;color:var(--indigo);letter-spacing:-.3px;margin-bottom:28px}
.prose-inner p{font-size:1.06rem;line-height:1.85;color:var(--body);margin-bottom:22px}
.values{padding:100px 0;background:var(--sand);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.value{background:var(--paper);border:1px solid var(--line);border-radius:4px;padding:40px 32px}
.value .vnum{font-family:var(--h);font-style:italic;font-weight:300;font-size:1.7rem;color:var(--bronze-d);margin-bottom:16px}
.value h3{font-family:var(--h);font-weight:400;font-size:1.4rem;color:var(--indigo);margin-bottom:12px}
.value p{font-size:.92rem;color:var(--body);line-height:1.7}
.capability{padding:96px 0;background:var(--cream)}
.capability-inner{max-width:820px;margin:0 auto;text-align:center}
.capability h2{font-family:var(--h);font-weight:300;font-size:2.4rem;color:var(--indigo);margin-bottom:18px;letter-spacing:-.4px}
.capability h2 em{font-style:italic;color:var(--bronze-d)}
.capability p{color:var(--body);font-size:1.05rem;line-height:1.8}

/* ---------- CONTACT ---------- */
.contact-sec{padding:112px 0;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.contact-info h2{font-family:var(--h);font-weight:300;font-size:2.2rem;color:var(--indigo);margin-bottom:18px;letter-spacing:-.3px}
.contact-info>p{color:var(--body);font-size:1rem;line-height:1.8;margin-bottom:34px;max-width:420px}
.cinfo-row{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.cinfo-row .lbl{font-size:.66rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--bronze-text);font-weight:600;margin-bottom:4px}
.cinfo-row .val{font-size:1rem;color:var(--ink)}
.contact-card{background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:42px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.7rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:7px}
.field input,.field textarea{width:100%;padding:13px 16px;border:1px solid var(--line);border-radius:6px;background:var(--cream);font-family:var(--b);font-size:.95rem;color:var(--ink);transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--indigo);box-shadow:0 0 0 3px rgba(19,46,82,.35)}
.field textarea{resize:vertical;min-height:130px}

/* ---------- BANNER ---------- */
.banner{background:var(--indigo);color:#fff;padding:112px 0;text-align:center;position:relative;overflow:hidden}
.banner::before{content:'';position:absolute;inset:0;
  background:radial-gradient(800px 400px at 50% 0%,rgba(230,158,108,.25),transparent 60%),radial-gradient(500px 300px at 15% 100%,rgba(230,158,108,.15),transparent 60%)}
.banner-inner{position:relative;z-index:2}
.banner .kicker{display:block;font-size:.72rem;letter-spacing:3.5px;text-transform:uppercase;color:var(--bronze-l);font-weight:500;margin-bottom:20px}
.banner h2{font-family:var(--h);font-weight:300;font-size:3.2rem;letter-spacing:-.5px;line-height:1.05;max-width:780px;margin:0 auto 22px}
.banner h2 em{font-style:italic;color:var(--bronze-l)}
.banner p{color:rgba(255,255,255,.75);max-width:520px;margin:0 auto 34px;font-size:1.05rem}

/* ---------- FOOTER ---------- */
.foot{background:var(--indigo-d);color:rgba(255,255,255,.6);padding:68px 0 26px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:44px;margin-bottom:46px}
.foot-brand img{width:60px;height:60px;margin-bottom:16px}
.foot-brand .fb-name{font-family:var(--h);font-weight:400;color:#fff;font-size:1.2rem;margin-bottom:10px}
.foot-brand p{font-size:.86rem;line-height:1.75;max-width:320px}
.foot h4{color:#fff;font-family:var(--h);font-size:1rem;font-weight:500;margin-bottom:16px}
.foot a{display:block;font-size:.86rem;color:rgba(255,255,255,.55);padding:6px 0;margin-bottom:6px}
.foot a:hover{color:var(--beige)}
.foot-bot{border-top:1px solid rgba(255,255,255,.08);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.74rem;color:rgba(255,255,255,.4)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:980px){
  .intro-grid,.feature,.proj,.contact-grid{grid-template-columns:1fr;gap:40px}
  .proj:nth-child(even) .proj-text{order:0}
  .services-row,.svc-grid,.values-grid{grid-template-columns:repeat(2,1fr)}
  .svc-card:nth-child(2n){border-right:none}
  .hero h1{font-size:3.3rem}
  .feature-img,.proj-img{height:380px}
}
@media(max-width:640px){
  .wrap{padding:0 22px}
  .nav-toggle{display:block}
  .menu{display:none;position:absolute;top:70px;right:18px;left:18px;background:var(--indigo);flex-direction:column;align-items:flex-start;padding:22px 24px;border-radius:12px;gap:18px;box-shadow:0 24px 60px rgba(0,0,0,.35)}
  .menu.open{display:flex}
  .services-row,.svc-grid,.values-grid,.supports{grid-template-columns:1fr}
  .svc,.svc-card{border-right:none;border-bottom:1px solid var(--line)}
  .hero{min-height:84vh}
  .hero h1{font-size:2.5rem}
  .hero-inner{padding-top:120px;padding-bottom:64px}
  .phero h1{font-size:2.2rem}
  .phero-inner{padding-top:120px}
  .sec-head{flex-direction:column;align-items:flex-start;gap:14px}
  .head-center h2,.banner h2{font-size:2.3rem}
  .hero-meta{display:none}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
}
