/* ===== Lot & Line — v51n (projects fixes: numbers + process shell) ===== */
:root{
  --gold:#C8A24A;
  --ink:#171512; --muted:#6b655e; --line:#E0D7C7;
  --olive:#222b13;
  --graph:#1f2224; --graph-ink:#F2EFE7;
  --projectGrey:#353834;
  --max:1160px; --headerH:74px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink);line-height:1.7;background:#fff}
a{color:inherit;text-decoration:none}

html,
body {
  background-color: #171512; /* your dark ink color instead of white */
}

/* --- Header --- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(17,17,17,.55); color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
}
.header-bar{
  position:relative;
  max-width:var(--max); margin:0 auto; padding:10px 18px; min-height:var(--headerH);
  display:grid; grid-template-columns:1fr auto 1fr; grid-template-areas:"nav brand contact";
  align-items:center; gap:16px;
}
#siteNav{grid-area:nav; display:flex; gap:18px; white-space:nowrap}
#siteNav a{color:#fff; font-size:12px; opacity:.95}
.brand{grid-area:brand; position:absolute; left:50%; transform:translateX(-50%)}
.brand-logo{height:34px; opacity:0; transition:opacity .25s ease}
body.past-hero .brand-logo{opacity:1}
.header-right{grid-area:contact; justify-self:end; display:flex; align-items:center; gap:14px}
.header-strap{display:none; text-align:right; line-height:1.05; font-size:12px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:#fff}
.header-strap span{display:block}
body.past-hero .header-strap{display:block}
.contact-cta{
  display:inline-block; padding:8px 12px; font-size:12px;
  background:var(--gold); color:#111; border:1px solid #b08b31; border-radius:999px;
  font-weight:600; transition:transform .15s,box-shadow .2s,background .2s
}
.contact-cta:hover{transform:translateY(-1px);box-shadow:0 6px 18px rgba(200,162,74,.35);background:#d6b65c}
.menu-toggle{display:none;background:transparent;border:0;padding:6px;cursor:pointer}
.menu-toggle span{display:block;width:22px;height:2px;background:#fff;margin:4px 0;border-radius:2px}
.nav-panel{display:none}

/* --- Layout helpers --- */
.wrap{max-width:var(--max); margin:0 auto; padding:0 18px}
section{padding:40px 0; scroll-margin-top:calc(var(--headerH) + 4px); position:relative}
.alt-graphite{background:var(--graph); color:var(--graph-ink)}

/* --- Hero --- */
.hero{position:relative}
.fullvh{min-height:100vh; display:grid; place-items:center; align-content:center}
.hero-bg{position:absolute; inset:0; background-size:cover; background-position:center}
.hero-inner{position:relative; z-index:2; color:#fff; text-shadow:0 1px 12px rgba(0,0,0,.25); text-align:center}
.display{
  font-family:"Cormorant Garamond",serif; letter-spacing:.12em; text-transform:uppercase;
  margin:0 0 10px; font-weight:700; line-height:1.06; color:#fff; font-size:36px
}
@media (min-width:600px){.display{font-size:52px}}
@media (min-width:1000px){.display{font-size:66px}}
.script{
  font-family:"Mrs Saint Delafield","Pinyon Script",cursive; letter-spacing:0;
  font-weight:400; font-size:1.4em; text-transform:none; display:inline-block;
  transition:opacity .18s ease; color:#fff
}
.script.fade{opacity:.82}
.substrap{margin-top:6px; font-family:"Cormorant Garamond",serif; letter-spacing:.12em; text-transform:uppercase; opacity:.95}
.hero-badge{position:absolute; left:50%; transform:translateX(-50%); top:calc(var(--headerH) + 28px); z-index:4}
.hero-logo{height:88px; display:block}

/* Hero arrow */
.scroll-indicator.is-abs{ position:absolute; left:50%; transform:translateX(-50%); bottom:76px; }
.arrow-wrap{display:flex; justify-content:center; margin:12px 0 0; z-index:4; position:relative}
.scroll-indicator{display:inline-block; z-index:4; animation:bounce 1.8s ease-in-out infinite}
.scroll-indicator svg{width:28px; height:28px}
.scroll-indicator svg path{stroke:var(--gold)!important; stroke-width:2; fill:none}
@keyframes bounce{0%,100%{transform:translateY(0)}50%{transform:translateY(8px)}}
/* ===== HERO: slow cinematic zoom ===== */
@keyframes heroZoom {
  0%   { transform: scale(1); }
  100% { transform: scale(1.06); }
}

.hero-bg{
  transform-origin: center center;
  animation: heroZoom 8s ease-in-out infinite alternate;
  will-change: transform;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .hero-bg{
    animation: none;
  }
}
/* ===== Tagline ===== */
section.tagline{ padding:22px 0; }
.tagline{ position:relative; background:#000; color:var(--gold); }
.tagline .wrap{ position:relative; z-index:1; min-height:40vh; display:grid; place-items:center; text-align:center; }
.tagline .line{
  font-family:"Mrs Saint Delafield","Pinyon Script",cursive;
  color:var(--gold); font-weight:400; line-height:1.12;
  font-size:clamp(36px, 11vw, 76px);
  margin:0;
}
.tagline .seg{ display:inline; opacity:0; transform:translateY(26px); transition:opacity 1.05s ease, transform 1.05s ease; }
.tagline .seg.show{ opacity:1; transform:none; }
.tagline .s2,.tagline .s3{ margin-left:.12em; }

/* --- Projects (base) --- */
h1,h2,h3{font-family:"Cormorant Garamond",serif; letter-spacing:.12em; text-transform:uppercase; margin:0 0 8px}
.project-types{background:var(--projectGrey); color:#fff}
.project-types h2,.project-types h3{color:#fff; text-align:center}
.lede{
  max-width:760px; margin:8px auto 22px;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  letter-spacing:0; text-transform:none;
}
.project-types .lede{ color:var(--gold) !important; text-transform:lowercase; text-align:center; }

.process-title{ margin-top:32px; }
.process-lede{
  color:var(--gold) !important;
  text-align:center;
  margin:6px auto 14px;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  max-width:760px; text-transform:lowercase;
}

.type-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:18px}
.type-grid .group h3{margin:0 0 10px}
.type-grid .chips{display:grid; grid-template-columns:1fr 1fr; gap:12px}

.chip{
  background:transparent; border:1.5px solid rgba(200,162,74,.8); color:#f5f2ea;
  padding:14px; border-radius:999px; cursor:pointer; text-align:center;
  transition:transform .15s,box-shadow .2s, background .2s, color .2s, border-color .2s
}
.chip:hover{transform:translateY(-2px); box-shadow:0 6px 16px rgba(0,0,0,.22)}
.chip.selected{background:var(--gold); color:#111; border-color:#b08b31; box-shadow:0 0 0 3px rgba(200,162,74,.25)}

.timeline{display:flex; flex-wrap:wrap; justify-content:center; gap:8px; position:relative; margin-top:16px}
.timeline .progress{position:absolute; left:0; top:-6px; height:3px; background:var(--gold); width:20%; transition:width .25s}
.step{background:rgba(255,255,255,.08); color:#fff; border:1px solid rgba(255,255,255,.22); padding:10px 14px; border-radius:999px; cursor:pointer}
.step.active{border-color:var(--gold); background:rgba(255,255,255,.12)}
/* Project type buttons — default (unselected) visibility */
#projects .chips .chip {
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  border: 1.5px solid rgba(255,255,255,0.35);
}

/* Hover polish */
#projects .chips .chip:hover {
  background: rgba(0, 0, 0, 0.6);
}

/* Selected state (already mostly there, reinforcing) */
#projects .chips .chip.selected {
  background: rgba(0,0,0,0.75);
  color: var(--gold) !important;
  border: 2px solid var(--gold);
  box-shadow: 0 0 10px rgba(200,162,74,0.45);
}
/* ===== Process box — always visible shell (before selection) ===== */
#tlPanels{
  position:relative;
  max-width:920px;
  margin:14px auto 0;
  min-height:150px;                    /* keeps the box visible by default */
}
#tlPanels::before{
  content:"";
  position:absolute; inset:0;
  border:1.5px solid var(--gold);
  border-radius:12px;
  background:rgba(255,255,255,.08);
  pointer-events:none;
  z-index:0;
}
/* Panels sit above the shell; only text is toggled by JS */
#tlPanels .panel{
  position:absolute; inset:0;
  display:none;
  background:transparent;              /* avoid double fill/border */
  border:none;
  color:#fff;
  border-radius:12px;
  padding:16px 18px 32px;
  line-height:1.6;
  z-index:1;
}
#tlPanels .panel.show{ display:block; }

/* ===== Numbers on section headings (scoped to #projects) ===== */
/* Left-align titles and show gold circle numbers on all viewports */
#projects h2.with-step,
#projects .process-title.with-step,
#projects .needs-title.with-step{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-start !important;
  gap:12px !important;
  padding-left:0 !important;
  text-align:left !important;
  margin:0 0 10px 0;
}
#projects h2.with-step::before,
#projects .process-title.with-step::before,
#projects .needs-title.with-step::before{
  content: attr(data-step) !important;
  position:static !important;   /* avoid absolute misalignment */
  transform:none !important;
  display:inline-grid !important;
  place-items:center !important;
  width:32px; height:32px; border-radius:999px;
  background:var(--gold);
  color:#111;                   /* high contrast numeral */
  font:700 15px/1 Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  box-shadow:0 0 0 3px rgba(200,162,74,.20);
}
@media (max-width:600px){
  #projects h2.with-step::before,
  #projects .process-title.with-step::before,
  #projects .needs-title.with-step::before{
    width:28px; height:28px; font-size:14px;
  }
}
/* Project type buttons — selected state text fix */
#projects .chips .chip.selected,
#projects .chips .chip.type.selected {
  color: var(--gold) !important;
  background: rgba(0, 0, 0, 0.72);
  border: 2px solid var(--gold) !important;
}

/* Ensure inner text/spans also stay gold */
#projects .chips .chip.selected *,
#projects .chips .chip.type.selected * {
  color: var(--gold) !important;
}
/* Hide the helper lines you don’t want in this section */
#projects > .wrap > .lede:first-of-type,
#projects .process-lede,
#projects #tlHint{ display:none !important; }

/* --- Contact --- */
#needs{scroll-margin-top:calc(var(--headerH) + 20px); margin-top:34px}
.contact-mini{margin-top:20px; background:#fff; border:1px solid var(--line); border-radius:16px; padding:16px; max-width:920px; margin-inline:auto}
.contact-mini textarea{width:100%; padding:12px; border:1px solid var(--line); border-radius:12px; margin-bottom:12px}
.mini-grid{display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px; margin-bottom:16px}
.mini-grid input{padding:12px; border:1px solid var(--line); border-radius:12px; width:100%}
.btn{display:inline-block; padding:12px 18px; border-radius:999px; background:#111; color:#fff; border:1px solid #000; transition:transform .15s,box-shadow .2s}
.btn:hover{transform:translateY(-1px); box-shadow:0 6px 16px rgba(0,0,0,.08)}
.send-row{display:flex; align-items:center; gap:10px}
.req-note{font-size:12px; opacity:.8}

/* ===== Design & Development Packages ===== */

#design-packages,
#development-packages{
  position:relative;
  padding:56px 0 48px;
  color:#fff;
  overflow:hidden;
}

/* Background image + smoked overlay */

#design-packages::before,
#development-packages::before{
  content:"";
  position:absolute;
  inset:0;
  background-size:cover;
  background-color: rgba(0,0,0,0.05);
  background-position:center;
  background-repeat:no-repeat;
  z-index:0;
}

/* Set your actual image filenames here */
#design-packages::before{
  background-image: url("../img/packages/design_package.PNG");
}

#development-packages::before{
  background-image: url("../img/packages/development_package.PNG");
}

#design-packages::after,
#development-packages::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(to bottom, rgba(0,0,0,0.18), rgba(0,0,0,0.05));
  z-index:0;
}

#design-packages .wrap,
#development-packages .wrap{
  position:relative;
  z-index:1;
}

/* Headings + lead text */

#design-packages h2,
#development-packages h2{
  text-align:center;
  color:#fff;
  margin-bottom:10px;
}

#design-packages .lede,
#development-packages .lede{
  color:#f5f5f5;
  text-align:left;
  max-width:840px;
}

.lede.lede-small{
  font-size:.9rem;
  opacity:.9;
}

.packages-note{
  margin-top:20px;
}

/* Cards / grid */

.packages-grid{
  display:grid;
  gap:18px;
  margin-top:24px;
}

@media (min-width:780px){
  .packages-grid{
    grid-template-columns:repeat(3,minmax(0,1fr));
  }
}

.package-card{
  background:rgba(0,0,0,.72);
  border-radius:18px;
  border:1px solid rgba(255,255,255,.18);
  padding:18px 18px 16px;
  box-shadow:0 16px 40px rgba(0,0,0,.35);
}

.package-card h3{
  margin:0 0 6px;
  font-family:"Cormorant Garamond",serif;
  letter-spacing:.11em;
  text-transform:uppercase;
  font-size:18px;
}

.package-who{
  font-size:.9rem;
  margin:0 0 8px;
  opacity:.92;
}

.package-list{
  margin:0;
  padding-left:18px;
  font-size:.9rem;
  line-height:1.5;
}

.package-list li + li{
  margin-top:4px;
}

/* ==== Packages: Details button styling ==== */

.package-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.package-toggle {
  display: inline-block;
  padding: 0.35rem 1.2rem;
  border-radius: 999px;
  border: 1px solid var(--gold);
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  font-size: 0.75rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
}

.package-toggle:hover {
  background: rgba(0, 0, 0, 0.65);
  border-color: var(--gold);
}

.package-toggle:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* ensure hidden bodies don't occupy space */
.package-body[hidden] {
  display: none;
}

/* ===== Packages: gold-outlined smoked cards ===== */

#design-packages .package-card,
#development-packages .package-card{
  border: 1px solid var(--gold);
  box-shadow: 0 14px 34px rgba(0,0,0,.45), 0 0 0 1px rgba(200,162,74,.25);
}

#design-packages .package-card:hover,
#development-packages .package-card:hover{
  box-shadow: 0 18px 40px rgba(0,0,0,.6), 0 0 0 1px rgba(200,162,74,.45);
  transform: translateY(-2px);
}

/* Arrow spacing for these bands */

#design-packages .arrow-wrap,
#development-packages .arrow-wrap{
  margin-top:32px;
}

/* --- About (gold background) --- */
.about-gold{background:var(--gold); color:#111}
.about-gold h2,.about-gold p{color:#111}
.about-title{
  font-family:"Mrs Saint Delafield","Pinyon Script",cursive;
  text-transform:lowercase; letter-spacing:0; text-align:left; font-size:3.2rem;
}

/* About layout */
.about-grid.v3{
  display:grid;
  grid-template-columns:1.6fr 1fr;
  grid-template-areas:
    "m-title m-pic"
    "m-copy  m-pic"
    "m-copy  m-pic"
    "sep     sep"
    "f-title f-pic"
    "f-copy  f-pic"
    "f-copy  f-pic";
  column-gap:28px; row-gap:18px; align-items:start;
}
.about-sub{margin:0 0 6px; font-family:"Cormorant Garamond",serif; letter-spacing:.18em; text-transform:uppercase; font-size:14px; color:#111}
.about-sub.matthew{ grid-area:m-title; }
.portrait.matthew{  grid-area:m-pic; }
.about-copy{        grid-area:m-copy; }
.about-sep{         grid-area:sep; border:0; height:1px; background:rgba(0,0,0,.22); margin:6px 0; }
.about-sub.felix{   grid-area:f-title; }
.portrait.felix{    grid-area:f-pic; }
.felix-text{        grid-area:f-copy; }

.about-grid.v3 .portrait img{
  width:100%; height:auto; display:block;
  aspect-ratio:4/5; object-fit:cover; border-radius:18px;
}

/* paragraph / element reveal */
.rev{
  opacity: 0;
  transform: translateY(16px);
  transition: opacity .6s ease, transform .6s ease;
}

.rev.show{
  opacity: 1;
  transform: translateY(0);
}

/* --- Puget Sound --- */
.service-area{background:var(--gold); color:#111}
.service-area h2,.service-area p{color:#111}

/* --- Footer --- */
.site-footer{background:#111; color:#ddd; border-top:1px solid rgba(255,255,255,.08); padding:20px 0 36px}
.site-footer a{color:#ddd}

/* ===== Responsive ===== */
@media (max-width:900px){
  .type-grid{grid-template-columns:1fr}
  .type-grid .chips{grid-template-columns:1fr 1fr}
  .mini-grid{grid-template-columns:1fr}
  .about-title{font-size:2.6rem}
  .about-grid.v3{
    grid-template-columns:1fr;
    grid-template-areas:
      "m-title" "m-pic" "m-copy"
      "sep"
      "f-title" "f-pic" "f-copy";
  }
  .about-grid.v3 .portrait img{ max-width:520px; margin:0 auto; }
}

/* Nav collapse block (unchanged) */
@media (max-width:820px){
  .header-bar{grid-template-columns:auto 1fr auto; grid-template-areas:"menu brand contact"}
  .menu-toggle{display:block}
  #siteNav{display:none}
  .nav-panel{display:none; position:fixed; top:var(--headerH); left:0; right:0; background:#111; border-bottom:1px solid rgba(255,255,255,.1); z-index:999}
  .nav-panel a{display:block; color:#fff; padding:14px 20px; border-top:1px solid rgba(255,255,255,.08)}
  .nav-open .nav-panel{display:block}
  .brand{position:absolute; left:50%; transform:translateX(-50%); z-index:2}
  .header-right{max-width:calc(50vw - 70px); overflow:hidden; gap:8px}
  body.past-hero .header-strap{display:block; font-size:10px; line-height:1.05; letter-spacing:.16em}
  .contact-cta{padding:6px 10px; font-size:11px; white-space:nowrap}
}
@media (max-width:360px){
  .header-strap{display:none}
  .contact-cta{padding:6px 8px; font-size:10px}
}

/* ===== Mobile logo centering fix ===== */
@media (max-width:820px){
  .header-bar{
    grid-template-columns: 1fr auto 1fr;
    grid-template-areas: "menu brand contact";
    padding-left: max(18px, env(safe-area-inset-left, 0px));
    padding-right: max(18px, env(safe-area-inset-right, 0px));
  }
  .menu-toggle{ grid-area: menu; justify-self: start; }
  .brand{
    grid-area: brand;
    position: static; left: auto; transform: none; justify-self: center;
  }
  .brand-logo{ display:block; height:34px; }
  .header-right{
    grid-area: contact; justify-self: end; max-width: none; overflow: visible;
  }
}

/* ===== Studies ===== */
.study-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:16px;
}
@media (max-width:900px){ .study-grid{ grid-template-columns:1fr; } }

.study-card{
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px; overflow:hidden;
  display:grid; grid-template-columns: 240px 1fr;
}
@media (max-width:700px){ .study-card{ grid-template-columns:1fr; } }
.study-thumb img{ display:block; width:100%; height:100%; object-fit:cover; }

.study-body{ padding:14px 16px; color:#fff; }
.study-title{ margin:0 0 4px; color:#fff; }
.study-kicker{ margin:0 0 10px; color:#ddd; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif; }
.study-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:10px; }

.study-detail{ display:none; border-top:1px solid rgba(255,255,255,.12); margin-top:10px; padding-top:12px; }
.study-card.open .study-detail{ display:block; }
.study-detail h4{ margin:12px 0 6px; color:#fff; }
.study-detail ul{ margin:0 0 8px 18px; }
.study-detail .faq summary{ cursor:pointer; }
.study-detail .es{ font-style:italic; opacity:.9; }

.study-meta{ display:flex; gap:14px; font-size:.9em; opacity:.9; margin:6px 0 10px; }
.study-ctas{ display:flex; flex-wrap:wrap; gap:10px; }
.btn.ghost{ background:transparent; color:#fff; border-color:#fff; }
.study-body[hidden]{ display:none; }

/* Dark pill version */
.studies .studies-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
@media (max-width:900px){ .studies .studies-grid{ grid-template-columns:1fr; } }
.study-card{ background:var(--graph); color:var(--graph-ink); border:1.5px solid var(--gold); border-radius:14px; padding:16px 18px; }
.study-head{ display:grid; grid-template-columns:1fr auto; gap:10px; align-items:start; }
.study-head h3{ margin:0 0 6px; color:var(--graph-ink); font-family:"Cormorant Garamond",serif; letter-spacing:.06em; text-transform:none; }
.study-tags{
  grid-column:1 / -1; display:flex; flex-wrap:wrap; gap:6px 8px; list-style:none;
  padding:0; margin:0 0 6px;
}
.study-tags li{
  padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18); color:var(--graph-ink);
  font-size:12px; letter-spacing:.12em; text-transform:uppercase;
}
.study-toggle{
  justify-self:end; padding:10px 14px; border-radius:999px;
  background:transparent; border:1.5px solid rgba(200,162,74,.8);
  color:#f5f2ea; font-weight:600; cursor:pointer;
  transition:transform .15s,box-shadow .2s,background .2s,color .2s,border-color .2s;
}
.study-toggle:hover{ transform:translateY(-2px); box-shadow:0 6px 16px rgba(0,0,0,.22); }
.study-toggle[aria-expanded="true"]{
  background:var(--gold); color:#111; border-color:#b08b31; box-shadow:0 0 0 3px rgba(200,162,74,.25);
}

/* Reveal on scroll + accordion transitions */
.study-card.rev{ opacity:1; transform:none; transition:opacity .6s ease, transform .6s ease; }
.study-card.rev.show{ opacity:1; transform:none; }
.study-body{ overflow:hidden; max-height:0; opacity:0; transition:max-height .35s ease, opacity .3s ease; will-change:max-height, opacity; margin-top:8px; }
.study-card.open .study-body{ opacity:1; }

/* Masonry on wide */
@media (min-width: 960px){
  .studies .studies-grid{ columns:2; column-gap:18px; display:block !important; }
  .studies .study-card{
    display:block; break-inside:avoid; -webkit-column-break-inside:avoid; -moz-column-break-inside:avoid; column-break-inside:avoid; margin:0 0 18px;
  }
}
@media (max-width: 959.98px){
  .studies .studies-grid{ display:block !important; }
  .studies .study-card{ margin-bottom:18px; }
}
.study-thumb{ margin:0 0 10px; overflow:hidden; border-radius:10px; }
.study-thumb img{ display:block; width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; }

/* Resources reuse */
#resources .study-head h3{ text-transform:none; letter-spacing:.02em; }
#resources .study-tags li{ letter-spacing:.1em; }
.resource-card .study-body{ max-height:none !important; opacity:1 !important; overflow:visible !important; margin-top:10px; }
.resource-card .study-toggle{ display:inline-block; text-align:center; }
#resources .study-tags li{ letter-spacing:.1em; }
#resources{ display:none !important; }

/* ===== Projects: timeline & packages visuals ===== */

/* keep content above photo veil */
#projects .chips,
#projects .timeline { position: relative; z-index: 2; }

/* Project selector pills (when selected) */
#projects .chips .chip.type.selected {
  background: rgba(0,0,0,.72);
  border: 2px solid var(--gold) !important;
  box-shadow: 0 0 8px rgba(200,162,74,.55);
}

/* Process step pills */
#projects .timeline .step {
  background: rgba(0,0,0,.38);
  color: #fff;
  border: 1px solid rgba(255,255,255,.40);
}
#projects .timeline .step.active {
  background: rgba(0,0,0,.68);
  border: 2px solid var(--gold) !important;
  box-shadow: 0 0 8px rgba(200,162,74,.55);
}

/* Process description box: smoked background + gold frame */
#tlPanels::before{
  background: rgba(0,0,0,.58) !important;
  border: 1.5px solid var(--gold) !important;
}
#tlPanels .panel{
  color:#fff !important;
  z-index:1;
}

/* Center Design & Development Package headers on desktop */
@media (min-width: 900px){
  #design-packages h2,
  #development-packages h2,
  #design-packages .lede,
  #development-packages .lede{
    text-align: center !important;
    margin-left: auto;
    margin-right: auto;
  }
}

/* Projects background photo after type is selected */
#projects.project-types{
  background-color: var(--projectGrey);
}
#projects.project-types.has-photo{
  position: relative;
  background-color: var(--projectGrey);
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
#projects.project-types.has-photo::before{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(
    to bottom,
    rgba(0,0,0,.35) 0%,
    rgba(0,0,0,.45) 50%,
    rgba(0,0,0,.55) 100%
  );
  pointer-events:none;
  z-index:0;
}
#projects.project-types .wrap{ position:relative; z-index:1; }

/* Simple halo text style (base) */
.halo-text {
  text-shadow:
    0 1px 2px rgba(0,0,0,0.35),
    0 0 6px rgba(0,0,0,0.25);
}

/* Package cards: section-wide details transitions */
.package-details {
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.35s ease, opacity 0.3s ease;
}
.package-details.is-open {
  max-height: 800px;
  opacity: 1;
}

/* Details button */
.package-details-toggle {
  display: inline-block;
  margin-top: 0.5rem;
  margin-bottom: 0.5rem;
  padding: 0.45rem 1.3rem;
  border-radius: 999px;
  border: 1px solid var(--gold);
  background: rgba(0,0,0,0.35);
  color: #fff;
  font-size: 0.8rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}
.package-details-toggle:hover {
  background: rgba(0,0,0,0.55);
}

/* Full Design / Full Development blurb styling (gold frame) */
.full-service-note {
  margin: 26px auto 0;
  padding: 18px 22px;
  max-width: 900px;

  background: rgba(0, 0, 0, 0.46);
  border-radius: 16px;
  border: 1px solid var(--gold);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(4px) saturate(120%);

  font-size: 1rem;
  line-height: 1.6;
  color: #f5f2ea;
}
.full-service-note strong {
  font-weight: 600;
  color: #fff;
}

/* Halo-pill blocks (design + dev explanatory lines, same size as lead) */
#design-packages .lede.lede-small,
#development-packages .packages-note.halo-text {
  margin: 26px auto 0;
  padding: 16px 22px;
  max-width: 900px;

  background: rgba(0, 0, 0, 0.38);
  border-radius: 16px;
  border: 1px solid var(--gold);
  box-shadow: 0 12px 30px rgba(0,0,0,0.40);
  backdrop-filter: blur(3px) saturate(115%);

  font-size: 1rem;
  line-height: 1.6;
  color: #f5f2ea;
  text-align: left;
  text-shadow:
    0 1px 2px rgba(0,0,0,0.45),
    0 0 8px rgba(0,0,0,0.28);
}

/* --- About / Puget / Studies specific tweaks and arrows --- */

/* Service area */
.service-area { background: var(--gold); color:#111; }
.service-area h2, .service-area p { color:#111; }

.service-title{
  text-align:center; margin:0 0 6px;
  font-family:"Cormorant Garamond",serif; letter-spacing:.12em; text-transform:uppercase;
}
.service-lede{
  max-width:820px; margin:0 auto 10px; text-align:center;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
.service-body, .tacoma-note{ max-width:900px; margin:10px auto; }

.geo-chips{
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center;
  list-style:none; padding:0; margin:14px auto 8px; max-width:980px;
}
.geo-chips li{
  padding:8px 12px; border-radius:999px;
  border:1px solid rgba(0,0,0,.14);
  background:#fff; color:#111; font-weight:600;
}

/* counties details */
.counties{
  max-width:900px; margin:10px auto 0; border-top:1px solid rgba(0,0,0,.18); padding-top:10px;
}
.counties summary{
  cursor:pointer; font-weight:700;
  list-style:none;
}
.counties[open] summary{ opacity:.85; }
.counties p{ margin:8px 0 0; }

/* map placeholder */
.map-placeholder{
  margin:16px auto 0; max-width:980px; min-height:220px;
  border:2px dashed rgba(0,0,0,.35); border-radius:12px;
  display:grid; place-items:center; font-weight:700; text-transform:uppercase;
  letter-spacing:.08em; background:rgba(255,255,255,.5);
}

/* STUDIES title center desktop / left mobile */
@media (min-width: 900px){
  #studies h2 {
    text-align: center !important;
    margin-left: auto;
    margin-right: auto;
  }
}
@media (max-width: 899.98px){
  #studies h2 {
    text-align: left !important;
  }
}

/* PUGET alignment */
@media (max-width: 820px){
  #puget h2,
  #puget p {
    text-align: left !important;
    margin-left: 0;
    margin-right: 0;
  }
}
#puget .puget-sub { margin: 6px 0 6px; }
#puget .puget-br { display: inline; }

/* Puget: graphite-style accordions */
#puget .puget-acc{
  background: var(--graph) !important;
  color: var(--graph-ink) !important;
  border: 1.5px solid var(--gold) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
}
#puget .puget-acc > summary{
  list-style: none;
  background: transparent !important;
  color: var(--graph-ink) !important;
  border: 1.5px solid rgba(255,255,255,.18) !important;
  border-radius: 999px !important;
  padding: 12px 16px !important;
  cursor: pointer;
}
#puget .puget-acc[open] > summary{
  background: rgba(255,255,255,.08) !important;
  border-color: var(--gold) !important;
}
#puget .puget-acc .pill-list li{
  background: rgba(255,255,255,.08) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  color: var(--graph-ink) !important;
  border-radius: 999px !important;
  font-size: 12px;
}
#puget details summary::-webkit-details-marker{ display:none; }
#puget .ps-row{ display:grid; grid-template-columns: 1fr 1fr; gap:14px; }
@media (max-width: 760px){
  #puget .ps-row{ grid-template-columns: 1fr; }
}

/* Puget trees band */
#puget { position: relative; overflow: hidden; }
#puget > .wrap { position: relative; z-index: 1; }
#puget::before{
  content:"";
  position:absolute; inset:0;
  z-index:0; pointer-events:none;
  background-image: url("data:image/svg+xml;utf8,\
<svg xmlns='http://www.w3.org/2000/svg' width='1200' height='240' viewBox='0 0 1200 240'>\
  <g fill='%23111111' fill-opacity='0.14'>\
    <polygon points='60,190 110,120 160,190'/>\
    <polygon points='70,200 110,145 150,200'/>\
    <polygon points='80,210 110,170 140,210'/>\
    <rect x='108' y='210' width='4' height='30'/>\
    <polygon points='210,200 255,135 300,200'/>\
    <polygon points='220,210 255,155 290,210'/>\
    <polygon points='230,220 255,175 280,220'/>\
    <rect x='253' y='220' width='4' height='20'/>\
    <polygon points='350,185 395,115 440,185'/>\
    <polygon points='360,195 395,140 430,195'/>\
    <polygon points='370,205 395,165 420,205'/>\
    <rect x='393' y='205' width='4' height='35'/>\
    <polygon points='480,198 510,145 540,198'/>\
    <polygon points='488,206 510,165 532,206'/>\
    <polygon points='496,214 510,184 524,214'/>\
    <rect x='508' y='214' width='4' height='22'/>\
    <polygon points='600,192 655,115 710,192'/>\
    <polygon points='612,204 655,140 698,204'/>\
    <polygon points='624,216 655,167 686,216'/>\
    <rect x='653' y='216' width='4' height='28'/>\
    <polygon points='740,198 780,135 820,198'/>\
    <polygon points='748,208 780,155 812,208'/>\
    <polygon points='756,218 780,175 804,218'/>\
    <rect x='778' y='218' width='4' height='22'/>\
    <polygon points='860,182 905,108 950,182'/>\
    <polygon points='870,194 905,136 940,194'/>\
    <polygon points='880,206 905,165 930,206'/>\
    <rect x='903' y='206' width='4' height='38'/>\
    <polygon points='980,196 1015,140 1050,196'/>\
    <polygon points='988,206 1015,160 1042,206'/>\
    <polygon points='996,216 1015,178 1034,216'/>\
    <rect x='1013' y='216' width='4' height='24'/>\
    <polygon points='1120,206 1142,170 1164,206'/>\
    <polygon points='1126,214 1142,186 1158,214'/>\
    <rect x='1140' y='214' width='4' height='18'/>\
  </g>\
</svg>");
  background-repeat: repeat-x;
  background-position: bottom center;
  background-size: auto 210px;
  opacity: 1;
}
@media (max-width: 820px){
  #puget::before{
    background-size: auto 160px;
  }
}
@media (max-width: 420px){
  #puget::before{
    background-size: auto 140px;
  }
}

/* About: arrow spacing */
#about { position: relative; }
#about .scroll-indicator.is-abs{
  bottom: 64px;
  z-index: 6;
}
#about .scroll-indicator svg path{
  stroke: #000 !important;
  stroke-width: 2.25;
}
#about .scroll-indicator{
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.15));
}
#about .felix-text p:last-child{
  margin-bottom: 96px;
}
@media (max-width: 900px){
  #about .felix-text p:last-child{
    margin-bottom: 72px;
  }
}

/* Studies arrow */
#studies{ position: relative; }
#studies .wrap{ padding-bottom: 92px; }
#studies .studies-arrow{
  position:absolute; left:50%; transform:translateX(-50%);
  bottom:48px; z-index:100; display:block;
}
#studies .studies-arrow svg{ width:28px; height:28px; display:block; }
#studies .studies-arrow svg path{
  stroke: var(--gold) !important; stroke-width: 2.25; fill:none;
}

/* Extra spacing between timeline box and Step 3 heading (desktop) */
@media (min-width: 821px){
  #tlPanels{ margin-bottom: 28px !important; }
  #projects .needs-title.with-step{
    margin-top: 18px !important;
  }
}

/* Hide Resources section everywhere */
#resources{ display: none !important; }
/* Puget accordions (Counties / Cities) — match site buttons */
.puget-acc summary{
  list-style:none;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;

  padding:12px 16px;
  border-radius:999px;

  background: rgba(0,0,0,.62);
  border: 2px solid var(--gold);
  color:#fff;

  font-family: inherit;
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;

  transition: transform .15s ease, box-shadow .2s ease, background .2s ease;
}

.puget-acc summary::-webkit-details-marker{ display:none; }

.puget-acc[open] summary{
  box-shadow: 0 0 14px rgba(200,162,74,.35);
  transform: translateY(-1px);
}

.puget-acc .puget-panel{
  margin-top:12px;
  padding:14px 16px;
  border-radius:16px;

  background: rgba(0,0,0,.55);
  border: 1px solid rgba(200,162,74,.55);
  color:#fff;
}
/* Package toggle active state (like Studies cards) */
.package-toggle.active {
  background: var(--gold);
  color: #111;
  border-color: #b08b31;
  box-shadow: 0 0 0 3px rgba(200,162,74,.25);
}
/* Mobile portrait: add breathing room before Step 3 */
@media (max-width: 600px) {
  #tlPanels {
    margin-bottom: 32px;
  }

  #projects .needs-title.with-step {
    margin-top: 24px;
  }
}
/* Puget cards: use the same look as package cards, just spacing tweaks */
.puget-card { margin-top: 14px; }

/* Dot-separated (wraps nicely) */
.inline-bullets{
  list-style:none;
  padding:0;
  margin:0;

  display:flex;
  flex-wrap:wrap;
  gap:10px 16px;
}

.inline-bullets li{
  position:relative;
  padding-left:14px;
}

.inline-bullets li::before{
  content:"•";
  position:absolute;
  left:0;
  color: var(--gold);
}
/* Puget cards: force white text everywhere */
#puget .puget-card,
#puget .puget-card *{
  color:#fff !important;
}

/* Keep the dot gold */
#puget .puget-card .inline-bullets li::before{
  color: var(--gold) !important;
}

/* If your button is getting dark text when active, force it readable */
#puget .puget-card .package-toggle.active{
  color:#111 !important; /* gold button usually looks best with dark text */
}
/* Mobile portrait: spacing between 3rd package card and full-service card */
@media (max-width: 600px){
  #design-packages .package-card:nth-of-type(3),
  #development-packages .package-card:nth-of-type(3){
    margin-bottom: 18px;
  }

  /* If your full service card has a class, use it too (safe even if not) */
  .full-service-card{
    margin-top: 18px;
  }
}
@media (max-width: 600px){
  .packages-grid{ gap: 18px !important; }
}
/* Packages intro text: make it a boxed callout matching the cards */
#design-packages .packages-lead,
#development-packages .packages-lead,
#design-packages .packages-intro,
#development-packages .packages-intro{
  padding: 16px 16px;
  border-radius: 16px;
  border: 1.5px solid rgba(200,162,74,.7);
  background: rgba(0,0,0,.45);
  color:#fff;
}

/* If you don’t have those classes, this fallback hits the first paragraph in each section */
#design-packages .wrap > p:first-of-type,
#development-packages .wrap > p:first-of-type{
  padding: 16px 16px;
  border-radius: 16px;
  border: 1.5px solid rgba(200,162,74,.7);
  background: rgba(0,0,0,.45);
  color:#fff;
}
/* Timeline steps: selected (active) should be gold */
#projects .timeline .step.active,
#projects .timeline .step.active *{
  color: var(--gold) !important;
  border-color: var(--gold) !important;
}

/* If you use a filled active state, keep contrast */
#projects .timeline .step.active{
  background: rgba(0,0,0,.70) !important;
  box-shadow: 0 0 12px rgba(200,162,74,.28);
}
/* Contact section: smoked-glass look + gold outline */
#contact .wrap,
#contact .contact-card,
#contactForm{
  border: 1.5px solid rgba(200,162,74,.7);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 18px;
}
/* Send button: gold outline */
#cf_send{
  border: 2px solid var(--gold) !important;
  box-shadow: 0 0 0 3px rgba(200,162,74,.18);
}

/* Keep hover consistent */
#cf_send:hover{
  box-shadow: 0 0 0 3px rgba(200,162,74,.28);
}
/* Package/Puget card bodies: smooth open/close */
.package-body,
.package-details{
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height .35s ease, opacity .25s ease;
}

/* When open, JS sets max-height inline; this class helps styling */
.package-body.is-open,
.package-details.is-open{
  opacity: 1;
}
/* Full-service cards: consistent spacing across breakpoints */
.full-service-card{
  margin-top: 16px;   /* desktop gap */
}

/* If a preceding element already has margin-bottom, avoid double spacing */
.full-service-card:first-of-type{
  margin-top: 16px;
}

/* Mobile portrait: reduce spacing (prevents “double space”) */
@media (max-width: 600px){
  .full-service-card{
    margin-top: 8px !important;
  }
}
@media (max-width: 600px){
  #design-packages .packages-grid,
  #development-packages .packages-grid{
    gap: 14px !important;
  }

  /* When gap is controlling spacing, remove extra margin */
  #design-packages .full-service-card,
  #development-packages .full-service-card{
    margin-top: 0 !important;
  }
}
/* iOS: prevent form auto-zoom on focus */
@media (max-width: 600px){
  #contact input,
  #contact textarea,
  #contact select{
    font-size: 16px !important;
  }
}
/* Shared glass recipe — match package cards */
:root{
  --glass-bg: rgba(0,0,0,.45);
  --glass-border: rgba(200,162,74,.70);
}

/* Package cards (ensure consistent) */
.package-card{
  background: var(--glass-bg);
  border: 1.5px solid var(--glass-border);
}

/* Packages intro + outro boxes (design + development) */
#design-packages .packages-lead,
#design-packages .packages-foot,
#development-packages .packages-lead,
#development-packages .packages-foot{
  background: var(--glass-bg);
  border: 1.5px solid var(--glass-border);
  border-radius: 16px;
  padding: 16px;
}
/* Mobile landscape: hide hero logo only (prevents overlap) */
@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px){
  .hero-logo,
  #hero .hero-logo,
  #heroLogo{
    display: none !important;
  }
}
/* Sections feel like stacked cards */
section{
  position: relative;
  border-top-left-radius: 22px;
  border-top-right-radius: 22px;
  overflow: hidden; /* keeps background images inside rounded corners */
}

/* Add a subtle “push-up” separation between sections */
section + section{
  margin-top: -18px; /* overlap */
  padding-top: 32px; /* compensate so content doesn’t clip */
}

/* Optional: soft shadow so the card stacking is visible */
section + section{
  box-shadow: 0 -18px 30px rgba(0,0,0,.22);
}
#hero{
  border-radius: 0;
  overflow: visible;
}
/* FIX: remove the OUTER box on the final callout (so only the inner halo box shows) */
#design-packages .packages-foot,
#development-packages .packages-foot{
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* Keep spacing clean so it doesn't collapse */
#design-packages .packages-foot > * ,
#development-packages .packages-foot > *{
  margin: 0;
}
/* iOS Safari: stop input focus zoom */
@media screen and (max-width: 900px){
  input, textarea, select, button{
    font-size: 16px !important;
    line-height: 1.2 !important;
  }
}

/* Also prevent Safari from trying to resize text on orientation changes */
html{
  -webkit-text-size-adjust: 100%;
}
/* FORCE: Studies arrow gold */
#studies .studies-arrow svg path{
  stroke: var(--gold) !important;
}
/* FORCE: Development packages arrow black */
#development-packages .scroll-indicator svg path,
#development-packages .arrow-wrap .scroll-indicator svg path{
  stroke: #000 !important;
}
/* ===== STUDIES ARROW — force visible + gold (works for stroke OR fill) ===== */
#studies .studies-arrow{
  display:block !important;
  opacity:1 !important;
  visibility:visible !important;
  z-index:9999 !important;
}

#studies .studies-arrow svg{
  display:block !important;
}

#studies .studies-arrow svg path,
#studies .studies-arrow svg polyline,
#studies .studies-arrow svg line{
  stroke: var(--gold) !important;
}

#studies .studies-arrow svg *{
  fill: none !important;
}

/* If the SVG uses fill instead of stroke (some arrow icons do) */
#studies .studies-arrow svg .fill,
#studies .studies-arrow svg path[fill],
#studies .studies-arrow svg polygon{
  fill: var(--gold) !important;
}
/* Prevent Studies arrow from being clipped */
#studies{
  overflow: visible !important;
}
/* STUDIES arrow: ensure visible + gold */
#studies{ overflow: visible !important; }

#studies .studies-arrow svg path{
  stroke: var(--gold) !important;
  stroke-width: 2.25 !important;
  fill: none !important;
}
/* STUDIES arrow: true center */
#studies .studies-arrow{
  position: static !important;
  transform: none !important;
  left: auto !important;
  bottom: auto !important;
}

#studies .arrow-wrap{
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 12px;   /* adjust if you want */
}
/* ===== STUDIES ARROW — centered, lifted, bouncing ===== */

#studies{
  overflow: visible !important; /* prevent clipping */
}

#studies .arrow-wrap{
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: -12px;      /* lift it up slightly */
  padding-bottom: 12px;  /* breathing room */
}

/* Restore bounce + sizing */
#studies .studies-arrow{
  display: inline-block;
}

#studies .studies-arrow.scroll-indicator{
  animation: bounce 1.8s ease-in-out infinite;
}

/* Ensure SVG inherits animation properly */
#studies .studies-arrow svg{
  width: 28px;
  height: 28px;
  display: block;
}
/* STUDIES arrow — FORCE bounce (avoids transform conflicts) */
#studies .studies-arrow,
#studies .studies-arrow *{
  transform: none !important;
}

#studies .studies-arrow{
  animation: bounce 1.8s ease-in-out infinite !important;
  will-change: transform;
}