/* ============================================================
   MGI Design — Studio Noir × Atelier
   Warm dark stone palette, Cormorant display, cinematic.
   ============================================================ */
:root{
  --bg:#211E1A;        /* warm near-black stone */
  --bg-2:#1A1714;      /* deeper */
  --panel:#2A2620;     /* raised surface */
  --panel-2:#322D26;
  --ink:#ECE6DB;       /* warm light text */
  --muted:#C4B9A9;
  --dim:#9A8C78;
  --faint:#6F6457;
  --brass:#B89B7E;     /* warm brass / clay accent */
  --brass-lt:#D4BFA6;
  --line:rgba(236,230,219,.14);
  --line-soft:rgba(236,230,219,.08);
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Helvetica Neue',Helvetica,Arial,sans-serif;
  --mono:'Courier New',monospace;
  --pad:clamp(22px,5vw,72px);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--sans);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
::selection{background:var(--brass);color:#1A1714}

/* ---------- type helpers ---------- */
.serif{font-family:var(--serif)}
.mono{font-family:var(--mono)}
.lbl{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--brass);font-weight:500}
.lbl-dim{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--dim)}
.eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--dim)}

h1,h2,h3{font-weight:400;margin:0}
.display{font-family:var(--serif);font-weight:300;line-height:1.02;letter-spacing:.005em}
.display em,.serif em{font-style:italic}

/* ---------- layout ---------- */
.wrap{max-width:1400px;margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
.app{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
.fade-in{animation:fade .9s cubic-bezier(.2,.7,.2,1) both}
@keyframes fade{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media (prefers-reduced-motion:reduce){.fade-in{animation:none}}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px var(--pad);transition:background .4s ease,padding .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent}
.nav.solid{background:rgba(26,23,20,.86);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line-soft);padding-top:16px;padding-bottom:16px}
.nav .mark{display:flex;align-items:center;line-height:0}
.nav .mark img{height:101px;width:auto;display:block;transition:height .4s ease}
.nav.solid .mark img{height:81px}
.nav .links{display:flex;gap:34px;align-items:center}
.nav .links a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);
  position:relative;padding:6px 0;transition:color .25s}
.nav .links a:hover,.nav .links a.active{color:var(--ink)}
.nav .links a.active::after{content:'';position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--brass)}
.nav .inquire{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink);
  border:1px solid var(--line);border-radius:40px;padding:9px 20px;transition:.25s}
.nav .inquire:hover{border-color:var(--brass);color:var(--brass-lt)}
.nav .burger{display:none;background:none;border:none;color:var(--ink);cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.nav .burger span{width:24px;height:1.5px;background:currentColor;display:block;transition:.3s}

/* mobile menu */
.mmenu{position:fixed;inset:0;z-index:55;background:var(--bg-2);
  display:flex;flex-direction:column;justify-content:center;gap:8px;padding:0 var(--pad);
  opacity:0;pointer-events:none;transition:opacity .4s}
.mmenu.open{opacity:1;pointer-events:auto}
.mmenu a{font-family:var(--serif);font-size:42px;color:var(--ink);padding:10px 0;border-bottom:1px solid var(--line-soft)}
.mmenu a .n{font-family:var(--mono);font-size:13px;color:var(--brass);margin-right:18px}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden}
.hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:brightness(.6) saturate(.92);animation:kenburns 22s ease-out both}
@keyframes kenburns{from{transform:scale(1.08)}to{transform:scale(1)}}
.hero::after{content:'';position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 50% 52%, rgba(20,18,15,.5) 0%, rgba(20,18,15,.12) 45%, rgba(20,18,15,0) 72%),
    linear-gradient(180deg,rgba(20,18,15,.62) 0%,rgba(20,18,15,.28) 30%,rgba(20,18,15,.32) 60%,rgba(20,18,15,.92) 100%)}
.hero .inner{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:0 var(--pad)}
.hero h1{font-family:var(--serif);font-weight:300;font-size:clamp(56px,11vw,148px);
  line-height:.96;letter-spacing:.01em;margin:18px 0 0}
.hero h1 em{font-style:italic}
.hero .sub{margin-top:26px;font-size:clamp(11px,1.4vw,14px);letter-spacing:.32em;
  text-transform:uppercase;color:var(--brass-lt)}
.hero .foot{position:absolute;left:var(--pad);right:var(--pad);bottom:30px;z-index:3;
  display:flex;justify-content:space-between;align-items:center}
.hero .foot .mono{font-size:12px;color:var(--muted)}
.scrollcue{display:flex;align-items:center;gap:10px;font-size:11px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--muted)}
.scrollcue .line{width:40px;height:1px;background:var(--brass);transform-origin:left;animation:cue 2.4s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleX(.4)}50%{transform:scaleX(1)}}

/* ============================================================
   STATEMENT / SECTIONS
   ============================================================ */
.section{padding:clamp(70px,11vw,140px) 0}
.section.tight{padding:clamp(48px,7vw,90px) 0}
.statement{max-width:1020px}
.statement h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.6vw,60px);
  line-height:1.16;letter-spacing:-.005em;margin:22px 0 0;color:var(--ink);text-wrap:pretty}
.statement h2 em{font-style:italic;color:var(--brass-lt)}
.sec-head{display:flex;justify-content:space-between;align-items:baseline;
  padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:8px;gap:20px;flex-wrap:wrap}
.sec-head h2{font-family:var(--serif);font-weight:300;font-size:clamp(26px,3.4vw,42px)}

/* ============================================================
   WORK INDEX  (Direction A structure)
   ============================================================ */
.index{}
.idx-row{display:grid;grid-template-columns:70px 1fr 230px 130px 84px;align-items:center;
  gap:24px;padding:30px 0;border-bottom:1px solid var(--line);
  position:relative;cursor:pointer;transition:padding .4s cubic-bezier(.2,.7,.2,1)}
.idx-row .num{font-family:var(--mono);font-size:14px;color:var(--brass)}
.idx-row .nm{font-family:var(--serif);font-size:clamp(26px,3.2vw,38px);font-weight:400;
  transition:color .3s,transform .4s cubic-bezier(.2,.7,.2,1);color:var(--ink)}
.idx-row .meta{font-size:12.5px;letter-spacing:.05em;color:var(--dim)}
.idx-row .thumb{width:84px;height:58px;object-fit:cover;border-radius:2px;
  filter:grayscale(.2) brightness(.92);transition:.4s;opacity:.9}
.idx-row .ph-thumb{width:84px;height:58px;border-radius:2px}
.idx-row .arrow{position:absolute;right:0;top:50%;transform:translate(20px,-50%);
  opacity:0;color:var(--brass);transition:.4s;font-size:20px}
.idx-row:hover{padding-left:18px}
.idx-row:hover .nm{color:var(--brass-lt);transform:translateX(0)}
.idx-row:hover .thumb{filter:none;opacity:1;transform:scale(1.04)}

/* floating hover preview */
.hover-preview{position:fixed;width:280px;height:340px;pointer-events:none;z-index:40;
  opacity:0;transform:translate(-50%,-50%) scale(.96);transition:opacity .3s,transform .3s;
  border-radius:3px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.hover-preview.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
.hover-preview img{width:100%;height:100%;object-fit:cover}

/* ============================================================
   PLACEHOLDER
   ============================================================ */
.ph{position:relative;background:
    repeating-linear-gradient(135deg,#2C2820 0 11px,#322D25 11px 22px);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.ph::before{content:attr(data-label);font-family:var(--mono);font-size:11px;
  letter-spacing:.12em;color:var(--faint);text-transform:uppercase;text-align:center;padding:14px}
.ph-thumb{background:repeating-linear-gradient(135deg,#2C2820 0 8px,#322D25 8px 16px)}

/* ============================================================
   PORTFOLIO GRID
   ============================================================ */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 44px}
.filters button{background:none;border:1px solid var(--line);color:var(--muted);
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:10px 20px;
  border-radius:40px;cursor:pointer;transition:.25s}
.filters button:hover{border-color:var(--brass);color:var(--ink)}
.filters button.on{background:var(--brass);border-color:var(--brass);color:#1A1714}
.pgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(20px,2.6vw,40px)}
.pcard{cursor:pointer;grid-column:span 6}
.pcard.tall{grid-column:span 6}
.pcard .frame{position:relative;overflow:hidden;border-radius:3px;background:var(--panel)}
.pcard .frame img,.pcard .frame .ph{width:100%;height:100%;object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.2,1),filter .6s}
.pcard .frame img{filter:brightness(.86) saturate(.96)}
.pcard:hover .frame img{transform:scale(1.05);filter:brightness(.96)}
.pcard .tagrow{position:absolute;top:16px;left:16px;z-index:2;display:flex;gap:7px}
.pcard .tag{font-size:10px;letter-spacing:.16em;text-transform:uppercase;
  background:rgba(20,18,15,.6);backdrop-filter:blur(6px);color:var(--brass-lt);
  padding:6px 11px;border-radius:30px}
.pcard .cc{display:flex;justify-content:space-between;align-items:baseline;margin-top:16px;gap:16px}
.pcard .cc .nm{font-family:var(--serif);font-size:clamp(22px,2.4vw,28px)}
.pcard .cc .loc{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);margin-top:4px}
.pcard .cc .yr{font-family:var(--mono);font-size:13px;color:var(--dim)}

/* ============================================================
   PROJECT DETAIL
   ============================================================ */
.proj-hero{position:relative;height:78vh;min-height:520px;overflow:hidden}
.proj-hero img,.proj-hero .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.proj-hero img{filter:brightness(.78)}
.proj-hero::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(20,18,15,.5),rgba(20,18,15,0) 40%,rgba(20,18,15,.85))}
.proj-hero .cap{position:absolute;left:var(--pad);right:var(--pad);bottom:42px;z-index:3}
.proj-hero .cap h1{font-family:var(--serif);font-weight:300;font-size:clamp(40px,7vw,92px);line-height:1}
.proj-meta{display:grid;grid-template-columns:1.4fr 1fr;gap:50px;
  padding:clamp(48px,7vw,90px) 0;border-bottom:1px solid var(--line)}
.proj-meta .lead{font-family:var(--serif);font-weight:300;font-size:clamp(22px,2.7vw,32px);
  line-height:1.4;color:var(--ink)}
.proj-meta .specs{display:flex;flex-direction:column;gap:18px}
.proj-meta .spec{display:flex;justify-content:space-between;gap:20px;
  padding-bottom:16px;border-bottom:1px solid var(--line-soft)}
.proj-meta .spec .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.proj-meta .spec .v{font-family:var(--serif);font-size:19px;text-align:right}
.proj-body{max-width:760px;margin:0 auto;padding:clamp(48px,7vw,90px) 0;
  font-size:17px;line-height:1.85;color:var(--muted)}
.proj-body p{margin:0 0 22px}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(16px,2vw,28px);padding-bottom:clamp(48px,7vw,90px)}
.gallery .g{overflow:hidden;border-radius:3px;cursor:zoom-in;background:var(--panel)}
.gallery .g img,.gallery .g .ph{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.gallery .g:hover img{transform:scale(1.04)}
.g-6{grid-column:span 6}.g-12{grid-column:span 12}.g-4{grid-column:span 4}.g-8{grid-column:span 8}

.proj-nav{display:flex;justify-content:space-between;align-items:center;
  padding:clamp(40px,6vw,72px) 0;border-top:1px solid var(--line)}
.proj-nav a{display:flex;flex-direction:column;gap:8px}
.proj-nav .lbl-dim{margin-bottom:2px}
.proj-nav .t{font-family:var(--serif);font-size:clamp(24px,3vw,34px);color:var(--ink);transition:color .3s}
.proj-nav a:hover .t{color:var(--brass-lt)}
.proj-nav .r{text-align:right}

/* ============================================================
   IN PROGRESS
   ============================================================ */
.prog-row{display:grid;grid-template-columns:120px 1fr 200px 160px;gap:28px;align-items:center;
  padding:34px 0;border-bottom:1px solid var(--line)}
.prog-row .stage{display:inline-flex;align-items:center;gap:9px;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.prog-row .dot{width:7px;height:7px;border-radius:50%;background:var(--brass)}
.prog-row .nm{font-family:var(--serif);font-size:clamp(24px,2.8vw,32px)}
.prog-row .loc{font-size:12px;letter-spacing:.06em;color:var(--dim);margin-top:3px}
.prog-row .bar{height:2px;background:var(--line);position:relative;border-radius:2px}
.prog-row .bar span{position:absolute;left:0;top:0;bottom:0;background:var(--brass);border-radius:2px}
.prog-row .pct{font-family:var(--mono);font-size:12px;color:var(--dim);margin-top:8px;display:block}
.prog-row .type{font-family:var(--mono);font-size:12px;color:var(--brass);text-align:right}

/* ============================================================
   ABOUT
   ============================================================ */
.about-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,70px);align-items:center}
.about-hero .pic{aspect-ratio:4/5;border-radius:3px;overflow:hidden}
.about-hero .pic img,.about-hero .pic .ph{width:100%;height:100%;object-fit:cover}
.about-hero h2{font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.4vw,56px);line-height:1.12;margin:20px 0 24px}
.about-hero p{color:var(--muted);font-size:16.5px;line-height:1.85;margin:0 0 20px;max-width:520px}
.approach{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px)}
.approach .col .n{font-family:var(--mono);font-size:13px;color:var(--brass)}
.approach .col h3{font-family:var(--serif);font-size:26px;margin:14px 0 12px}
.approach .col p{color:var(--dim);font-size:15px;line-height:1.75}
.stats{display:flex;gap:clamp(30px,6vw,90px);flex-wrap:wrap}
.stats .s .v{font-family:var(--serif);font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1}
.stats .s .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-top:10px}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px)}
.contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(36px,6vw,72px);line-height:1.02;margin:18px 0 0}
.contact h2 em{font-style:italic;color:var(--brass-lt)}
.contact .details{margin-top:42px;display:flex;flex-direction:column;gap:26px}
.contact .details .blk .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:7px}
.contact .details .blk a,.contact .details .blk .v{font-family:var(--serif);font-size:22px;color:var(--ink)}
.contact .details .blk a:hover{color:var(--brass-lt)}
.form{display:flex;flex-direction:column;gap:22px}
.field label{display:block;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:10px}
.field input,.field textarea,.field select{width:100%;background:transparent;border:none;
  border-bottom:1px solid var(--line);color:var(--ink);font-family:var(--sans);font-size:16px;
  padding:10px 0;outline:none;transition:border-color .3s}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brass)}
.field textarea{resize:vertical;min-height:90px}
.field select{appearance:none;cursor:pointer}
.field select option{background:var(--panel)}
.btn-send{align-self:flex-start;margin-top:8px;background:var(--brass);color:#1A1714;border:none;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;padding:16px 36px;border-radius:40px;
  cursor:pointer;transition:.3s}
.btn-send:hover{background:var(--brass-lt);transform:translateY(-1px)}
.btn-send:disabled{opacity:.5;cursor:default;transform:none}
.sent-msg{font-family:var(--serif);font-size:24px;color:var(--brass-lt);font-style:italic}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{border-top:1px solid var(--line);padding:clamp(54px,8vw,96px) 0 40px;margin-top:40px}
.footer .top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:60px}
.footer .big{font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.2vw,52px);line-height:1.08}
.footer .big em{font-style:italic;color:var(--brass-lt)}
.footer .cta{display:inline-block;margin-top:22px;font-family:var(--serif);font-size:24px;font-style:italic;
  border-bottom:1px solid var(--brass);padding-bottom:3px;transition:.3s}
.footer .cta:hover{color:var(--brass-lt)}
.footer .col .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:16px}
.footer .col a,.footer .col .v{display:block;color:var(--muted);font-size:14px;line-height:2;transition:color .25s}
.footer .col a:hover{color:var(--ink)}
.footer .base{display:flex;justify-content:space-between;align-items:center;
  padding-top:30px;border-top:1px solid var(--line-soft);flex-wrap:wrap;gap:14px}
.footer .base .mono{font-size:12px;color:var(--faint);letter-spacing:.04em}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:90;background:rgba(16,14,12,.95);
  display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s}
.lightbox.open{opacity:1;pointer-events:auto}
.lightbox img{max-width:90vw;max-height:84vh;object-fit:contain;border-radius:2px;
  box-shadow:0 40px 120px rgba(0,0,0,.6)}
.lightbox .lb-close{position:absolute;top:26px;right:30px;background:none;border:none;
  color:var(--muted);font-size:30px;cursor:pointer;line-height:1;transition:color .25s}
.lightbox .lb-close:hover{color:var(--ink)}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;
  color:var(--muted);font-size:28px;cursor:pointer;padding:20px;transition:color .25s}
.lightbox .lb-nav:hover{color:var(--ink)}
.lightbox .lb-prev{left:14px}.lightbox .lb-next{right:14px}
.lightbox .lb-count{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  font-family:var(--mono);font-size:12px;color:var(--dim);letter-spacing:.1em}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .nav .links,.nav .inquire{display:none}
  .nav .mark img{height:78px}
  .nav.solid .mark img{height:72px}
  .nav .burger{display:flex}
  .idx-row{grid-template-columns:48px 1fr 64px;gap:16px}
  .idx-row .meta,.idx-row .arrow{display:none}
  .idx-row .meta.keep{display:block;grid-column:2;font-size:11px;margin-top:-6px}
  .proj-meta,.about-hero,.contact,.footer .top{grid-template-columns:1fr;gap:30px}
  .approach{grid-template-columns:1fr}
  .pcard,.pcard.tall{grid-column:span 12}
  .g-6,.g-4,.g-8{grid-column:span 12}
  .prog-row{grid-template-columns:1fr;gap:10px;padding:26px 0}
  .prog-row .type{text-align:left}
  .footer .top{grid-template-columns:1fr 1fr}
  .footer .big-col{grid-column:1/-1}
  .hover-preview{display:none}
}
@media (max-width:560px){
  .footer .top{grid-template-columns:1fr}
}
