/* ============================================================
   LightScaper — site design system
   Palette: candlelit room. Fonts: Montserrat / Cormorant / Mulish.
   ============================================================ */
:root{
  --ground:#040911;        /* near-black — a tiny breath of blue */
  --ground-2:#06090f;
  --panel:#0f110b;         /* warm green-black — cards / boxes */
  --panel-2:#14160e;
  --line:rgba(246,193,36,.18);   /* vibrant yellow hairline */
  --gold:#e5ac1f;          /* candle amber — small label text */
  --yellow:#f6c124;        /* vibrant yellow — titles + lines */
  --gold-soft:#f1c860;     /* softer amber — display accents */
  --green:#46583a;         /* dark garden green — sparse accents */
  --ink:#e9dfc8;           /* warm cream — body */
  --muted:rgba(233,223,200,.58); /* dim candlelight — secondary */
  --brand:'Montserrat',system-ui,sans-serif;
  --display:'Cormorant Garamond',Georgia,serif;
  --body:'Mulish',system-ui,sans-serif;
  --wrap:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:
    radial-gradient(60% 38% at 50% -4%, rgba(229,172,31,.08), transparent 60%),
    radial-gradient(80% 50% at 50% 28%, rgba(229,172,31,.022), transparent 70%),
    var(--ground);
  background-attachment:fixed;
  color:var(--ink);font-family:var(--body);font-weight:300;line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:var(--wrap);margin:0 auto;padding-left:clamp(1.25rem,5vw,4rem);padding-right:clamp(1.25rem,5vw,4rem)}

/* ---------- nav ---------- */
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
  padding:1.15rem clamp(1.25rem,5vw,4rem);
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:30;background:rgba(4,9,17,.86);backdrop-filter:blur(9px);
}
.lockup{display:flex;align-items:center;gap:.7rem}
.lockup .crest{height:58px;width:auto}
.lockup .wordmark{height:34px;width:auto}
.menu{display:flex;gap:clamp(1rem,2.6vw,2.1rem);font-family:var(--brand);font-weight:400;
  font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}
.menu a{color:var(--muted);transition:color .25s;position:relative}
.menu a:hover,.menu a[aria-current]{color:var(--yellow)}

/* ---------- buttons ---------- */
.btns{display:flex;flex-wrap:wrap;gap:.9rem}
.btn{
  font-family:var(--brand);font-weight:500;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.85rem 1.5rem;border:1px solid var(--line);color:var(--ink);
  transition:.3s;background:transparent;display:inline-block;
}
.btn:hover{border-color:var(--yellow);color:var(--yellow);box-shadow:0 0 24px rgba(229,172,31,.12)}
.btn.solid{background:var(--yellow);border-color:var(--yellow);color:#1a1303}
.btn.solid:hover{background:var(--gold-soft);border-color:var(--gold-soft);color:#1a1303}

/* ---------- type helpers ---------- */
.eyebrow{font-family:var(--brand);font-weight:500;font-size:.72rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
h1.display,h2.display{font-family:var(--display);font-weight:500;color:#f8f5ef;line-height:1.1;letter-spacing:0}
h1.display{font-size:clamp(2.2rem,5vw,4rem)}
h2.display{font-size:clamp(1.8rem,3.4vw,2.7rem)}
.display em{font-style:italic;color:var(--gold-soft)}
.lead{color:var(--muted);font-size:clamp(1rem,1.3vw,1.12rem);max-width:60ch}

/* ---------- hero (landing) ---------- */
.hero{position:relative;min-height:clamp(84vh,90vh,960px);display:flex;align-items:center;overflow:hidden;
  border-bottom:1px solid var(--line)}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;filter:brightness(.62) saturate(1.03)}
.hero-shade{position:absolute;inset:0;z-index:1;background:
  linear-gradient(90deg, rgba(4,9,17,.94) 0%, rgba(4,9,17,.74) 42%, rgba(4,9,17,.42) 100%),
  linear-gradient(0deg, rgba(4,9,17,.92) 0%, rgba(4,9,17,0) 52%)}
.hero .wrap{position:relative;z-index:2;width:100%;padding-top:clamp(3rem,8vw,6rem);padding-bottom:clamp(3rem,8vw,6rem)}
.hero .eyebrow.soft{color:#d9c089;opacity:.92}
.hero h1{font-family:var(--display);font-weight:500;color:#fff;
  font-size:clamp(2rem,4.4vw,3.5rem);line-height:1.08;max-width:18ch;margin-top:1.1rem}
.hero h1 em{font-style:italic;color:#fff}
.hero .sub{margin-top:1.4rem;max-width:52ch;color:var(--ink);font-size:clamp(1rem,1.3vw,1.12rem)}
.hero .sub-emph{margin-top:1.1rem;max-width:50ch;font-family:var(--display);font-style:italic;
  font-size:clamp(1.15rem,1.8vw,1.5rem);color:#f1e7d1;padding-left:1rem;border-left:2px solid var(--gold)}
.hero .btns{margin-top:2.2rem}

/* ---------- generic section ---------- */
.section{padding:clamp(3rem,7vw,5.5rem) 0;border-bottom:1px solid var(--line)}
.section.tight{padding:clamp(2.2rem,5vw,3.5rem) 0}
.section-head{max-width:60ch;margin-bottom:2.2rem}
.section-head .eyebrow{margin-bottom:1rem}
.section-head .lead{margin-top:1rem}

/* ---------- two column feature ---------- */
.two{display:grid;gap:clamp(1.6rem,4vw,3.5rem);grid-template-columns:1fr 1fr;align-items:center}
.two.narrow{grid-template-columns:1fr 1.2fr}
.two p{color:var(--muted);margin-top:1rem}
.two p:first-of-type{margin-top:1.2rem}
.two .ink{color:var(--ink)}
.panel-img{position:relative;aspect-ratio:4/3;border:1px solid var(--line);overflow:hidden;
  background:
    radial-gradient(120% 80% at 50% 122%, rgba(229,172,31,.26), transparent 52%),
    radial-gradient(90% 64% at 50% 124%, rgba(70,88,58,.18), transparent 58%),
    linear-gradient(180deg,#0b0d07,#080a05)}
.panel-img .ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.7rem}

/* ---------- services list ---------- */
.svc{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.svc .item{border:1px solid var(--line);background:linear-gradient(180deg,#0d0f09,#0a0c06);padding:1.5rem 1.4rem}
.svc .item .tag{font-family:var(--brand);font-weight:600;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.svc .item h3{font-family:var(--display);font-weight:500;font-size:1.4rem;color:#efe6cf;margin:.5rem 0 .5rem}
.svc .item p{color:var(--muted);font-size:.92rem}

/* ---------- stats band ---------- */
.stats{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));text-align:center}
.stat .num{font-family:var(--display);font-weight:500;font-size:clamp(2rem,4vw,3rem);color:#f4ecd8;line-height:1.05}
.stat .num.sm{font-size:clamp(1.05rem,2.1vw,1.6rem);letter-spacing:.01em}
.stat .lbl{font-family:var(--brand);font-weight:500;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:.6rem}

/* ---------- portfolio grid + cards ---------- */
.grid{display:grid;gap:clamp(1rem,2vw,1.6rem);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}
.card{position:relative;border:1px solid var(--line);background:linear-gradient(180deg,#0d0f09,#0a0c06);overflow:hidden;display:flex;flex-direction:column}
.frame{position:relative;aspect-ratio:4/3;overflow:hidden;
  background:
    radial-gradient(115% 80% at 50% 122%, rgba(229,172,31,.28), transparent 52%),
    radial-gradient(90% 64% at 50% 124%, rgba(70,88,58,.20), transparent 58%),
    linear-gradient(180deg,#0b0d07,#080a05)}
.frame img.photo{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.7,.2,1),filter .6s ease;filter:brightness(.96) saturate(1.04)}
.card:hover .frame img.photo{transform:scale(1.04);filter:brightness(1) saturate(1.05)}
.ph{position:absolute;inset:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:.7rem;text-align:center;padding:1.5rem}
.ph .lamp{width:34px;height:34px;opacity:.6;color:var(--gold)}
.ph .pname{font-family:var(--brand);font-weight:500;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold)}
.ph .note{font-family:var(--display);font-style:italic;font-size:1.05rem;color:var(--ink)}
.meta{padding:1.1rem 1.2rem 1.3rem}
.meta .loc{font-family:var(--brand);font-weight:500;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.45rem}
.meta h3{font-family:var(--display);font-weight:500;font-size:1.5rem;line-height:1.12;color:#f4ecd8}
.meta .scope{margin-top:.5rem;font-size:.92rem;color:var(--muted);line-height:1.55}
.meta .rule{width:36px;height:2px;background:var(--yellow);margin-top:.85rem;transition:width .5s ease}
.card:hover .meta .rule{width:60px}

/* ---------- pull quote ---------- */
.quote{max-width:46ch;margin:0 auto;text-align:center}
.quote p{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(1.5rem,3vw,2.2rem);color:var(--ink);line-height:1.3}
.quote .by{font-family:var(--brand);font-weight:500;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:1.4rem}

/* ---------- timeline (history) ---------- */
.timeline{position:relative;margin-top:1rem}
.timeline::before{content:"";position:absolute;left:7px;top:.4rem;bottom:.4rem;width:1px;background:var(--line)}
.tl{position:relative;padding:0 0 2.2rem 2.4rem}
.tl::before{content:"";position:absolute;left:0;top:.55rem;width:15px;height:15px;border-radius:50%;
  border:1px solid var(--yellow);background:radial-gradient(circle,var(--gold) 0 40%,transparent 55%);
  box-shadow:0 0 14px rgba(229,172,31,.4)}
.tl .yr{font-family:var(--brand);font-weight:600;font-size:.66rem;letter-spacing:.2em;color:var(--gold)}
.tl h3{font-family:var(--display);font-weight:500;font-size:1.5rem;color:#f4ecd8;margin:.25rem 0 .5rem}
.tl p{color:var(--muted);max-width:62ch}

/* ---------- footer ---------- */
footer.site{border-top:1px solid var(--line);margin-top:0}
footer.site .wrap{padding-top:clamp(2.25rem,5vw,3.5rem);padding-bottom:clamp(2.25rem,5vw,3.5rem);
  display:flex;flex-wrap:wrap;gap:1.75rem;justify-content:space-between;align-items:center}
.f-lockup{display:flex;align-items:center;gap:.8rem}
.f-lockup .crest{height:52px;width:auto}
.f-lockup .wordmark{height:24px;width:auto}
.f-lic{font-family:var(--brand);font-weight:400;font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:.45rem}
.contact{font-family:var(--brand);font-weight:400;font-size:.72rem;letter-spacing:.06em;color:var(--muted);line-height:1.9;text-align:right}
.contact a{font-family:var(--body);letter-spacing:0;font-size:.9rem}
.contact a:hover{color:var(--yellow)}

@media (max-width:760px){
  .two,.two.narrow{grid-template-columns:1fr}
  .two .order-img{order:-1}
}
@media (max-width:640px){
  .menu{width:100%;justify-content:space-between;gap:.3rem;font-size:.66rem}
  .grid{grid-template-columns:1fr}
  footer.site .wrap{flex-direction:column;align-items:flex-start}
  .contact{text-align:left}
}

/* ---------- real photo figures (history / about) ---------- */
.figure{position:relative;border:1px solid var(--line);overflow:hidden;background:#0a0c06}
.figure.std{aspect-ratio:4/3}
.figure.wide{aspect-ratio:16/9}
.figure.tall{aspect-ratio:3/4}
.figure img{width:100%;height:100%;object-fit:cover;display:block;
  filter:saturate(.9) brightness(.9) contrast(1.03);
  transition:filter .7s ease, transform 1.1s cubic-bezier(.2,.7,.2,1)}
.figure:hover img{filter:saturate(1) brightness(1.04) contrast(1.04);transform:scale(1.03)}
.figure::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(4,9,17,.10) 0%,transparent 35%,rgba(4,9,17,.55) 100%)}
.figure .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:.85rem 1.05rem;
  font-family:var(--brand);font-weight:500;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}

/* origin quote block */
.origin{max-width:62ch;margin:0 auto;text-align:center}
.origin .motto{font-family:var(--display);font-style:italic;font-size:clamp(1.6rem,3vw,2.4rem);color:#f1e7d1;line-height:1.25}
.origin p{color:var(--muted);margin-top:1.3rem}
.origin a{color:var(--gold)}
.origin a:hover{color:var(--yellow)}

/* ---------- at-work gallery ---------- */
.gallery{display:grid;gap:clamp(.7rem,1.4vw,1.1rem);grid-template-columns:repeat(auto-fill,minmax(248px,1fr))}
.gallery .figure{aspect-ratio:4/3}
.gallery .figure.span2{grid-column:span 2}
@media (max-width:560px){.gallery{grid-template-columns:1fr}.gallery .figure.span2{grid-column:span 1}}

/* ---------- the craft: technique cards + diagram ---------- */
.tech{display:grid;gap:clamp(.7rem,1.4vw,1.1rem);grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}
.tech .t{border:1px solid var(--line);background:linear-gradient(180deg,#0d0f09,#0a0c06);padding:1.4rem 1.3rem}
.tech .t svg{width:40px;height:40px;color:var(--gold);margin-bottom:.85rem;display:block}
.tech .t h3{font-family:var(--display);font-weight:500;font-size:1.3rem;color:#efe6cf;margin-bottom:.4rem;line-height:1.15}
.tech .t p{color:var(--muted);font-size:.9rem;line-height:1.5}
.diagram{border:1px solid var(--line);background:linear-gradient(180deg,#0b0d07,#080a05);padding:clamp(1.4rem,3vw,2.2rem)}
.diagram svg{width:100%;height:auto;display:block}

/* ---------- craft: small effect tiles + photo band ---------- */
.effects{display:grid;gap:.8rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.effects .ef{position:relative;border:1px solid var(--line);overflow:hidden;aspect-ratio:1/1;background:#0a0c06}
.effects .ef img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) brightness(.92);transition:filter .6s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.effects .ef:hover img{filter:saturate(1.02) brightness(1.04);transform:scale(1.05)}
.effects .ef .lbl{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:.6rem .75rem;
  font-family:var(--brand);font-weight:500;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;
  color:#f1e7d1;background:linear-gradient(0deg,rgba(4,9,17,.9),transparent)}
.band{position:relative;min-height:clamp(340px,46vh,520px);display:flex;align-items:center;overflow:hidden;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.band-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.5) saturate(1.02)}
.band-shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(4,9,17,.92),rgba(4,9,17,.55) 58%,rgba(4,9,17,.32))}
.band .wrap{position:relative;z-index:2}

/* ---------- craft: effects carousel (dissolve through black) ---------- */
.carousel{position:relative;width:100%;aspect-ratio:16/9;background:#040911;border:1px solid var(--line);overflow:hidden}
.carousel .slide{position:absolute;inset:0;opacity:0;transform:scale(1.05);filter:brightness(.45) blur(9px);
  transition:opacity 1.1s ease, transform 1.5s ease, filter 1.2s ease;will-change:opacity,transform,filter}
.carousel .slide.active{opacity:1;transform:scale(1);filter:brightness(.97) blur(0)}
.carousel .slide img{width:100%;height:100%;object-fit:cover;display:block}
.carousel .slide .lbl{position:absolute;left:0;bottom:0;z-index:2;padding:1.1rem 1.4rem;
  font-family:var(--brand);font-weight:500;font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;color:#f4ecd8;
  background:linear-gradient(0deg,rgba(4,9,17,.82),transparent)}
.car-btn{position:absolute;z-index:3;top:50%;transform:translateY(-50%);width:46px;height:46px;border:1px solid var(--line);
  background:rgba(4,9,17,.4);color:var(--ink);font-size:1.4rem;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:.3s}
.car-btn:hover{border-color:var(--gold);color:var(--gold);background:rgba(4,9,17,.62)}
.car-prev{left:14px}.car-next{right:14px}
.car-dots{position:absolute;z-index:3;bottom:16px;right:18px;display:flex;gap:8px}
.car-dots button{width:8px;height:8px;border-radius:50%;border:none;background:rgba(233,223,200,.4);cursor:pointer;padding:0;transition:.3s}
.car-dots button.on{background:var(--gold);width:22px;border-radius:4px}
@media (max-width:560px){.carousel{aspect-ratio:4/3}}

/* about: paired work photos (electrical + lighting) */
.duo{display:grid;gap:.8rem}
.duo .figure{margin:0}

/* ---------- about: the team ---------- */
.team{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));margin-top:1.5rem}
.member .pf{position:relative;aspect-ratio:3/4;overflow:hidden;border:1px solid var(--line);background:#0a0c06;display:flex;align-items:center;justify-content:center}
.member .pf img{width:100%;height:100%;object-fit:cover;filter:saturate(.98) brightness(.97)}
.member .mono{font-family:var(--display);font-weight:500;font-size:2.6rem;color:var(--gold-soft);letter-spacing:.04em}
.member .pcoming{position:absolute;bottom:.6rem;left:0;right:0;text-align:center;font-family:var(--brand);font-weight:500;font-size:.54rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.member h3{font-family:var(--display);font-weight:500;font-size:1.22rem;color:#f4ecd8;margin:.7rem 0 .15rem}
.member .role{font-family:var(--brand);font-weight:500;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.member p{margin-top:.5rem;font-size:.9rem;line-height:1.55;color:var(--ink)}
