/* Edge Developer LLC — Luxury Minimalist Design System */
:root{
  --ink:#0d0d0d;
  --ink-soft:#1a1a1a;
  --cream:#f5f0e8;
  --cream-2:#ece5d8;
  --paper:#fbf8f2;
  --gold:#c9a84c;
  --gold-soft:#d9bf78;
  --muted:#6b6358;
  --line:rgba(13,13,13,.12);
  --line-dark:rgba(245,240,232,.18);
  --shadow-lg:0 30px 80px -30px rgba(13,13,13,.35);
  --shadow-sm:0 10px 30px -15px rgba(13,13,13,.25);
  --maxw:1240px;
  --serif:"Cormorant Garamond","Playfair Display",Georgia,serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none;transition:color .25s ease,opacity .25s ease}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.1;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:clamp(2.4rem,5.5vw,4.5rem)}
h2{font-size:clamp(1.9rem,3.6vw,3rem)}
h3{font-size:clamp(1.3rem,2vw,1.6rem)}
p{color:var(--muted)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--sans);font-size:.72rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--gold);font-weight:600;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:28px;height:1px;background:var(--gold)}
.section{padding:clamp(64px,9vw,128px) 0}
.section--dark{background:var(--ink);color:var(--cream)}
.section--dark h1,.section--dark h2,.section--dark h3{color:var(--cream)}
.section--dark p{color:rgba(245,240,232,.7)}
.section--cream{background:var(--cream)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(251,248,242,.85);
  backdrop-filter:saturate(150%) blur(14px);
  -webkit-backdrop-filter:saturate(150%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-size:1.4rem;letter-spacing:.02em}
.brand-mark{
  width:42px;height:42px;border-radius:8px;background:var(--ink);
  display:grid;place-items:center;color:var(--gold);font-weight:700;
  font-family:Georgia,serif;font-size:1.05rem;letter-spacing:-1px;
}
.brand-name{font-weight:500}
.brand-name small{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.32em;color:var(--muted);text-transform:uppercase;margin-top:2px}
.nav-links{display:flex;gap:34px;align-items:center;list-style:none}
.nav-links a{font-size:.88rem;letter-spacing:.06em;text-transform:uppercase;font-weight:500;color:var(--ink)}
.nav-links a.active{color:var(--gold)}
.nav-cta{display:inline-flex;align-items:center;gap:8px}
.nav-toggle{display:none;background:none;border:0;width:42px;height:42px;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);margin:5px auto;transition:.25s}
.nav-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 26px;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;border:1px solid var(--ink);background:var(--ink);color:var(--cream);
  cursor:pointer;transition:.3s;border-radius:0;font-family:var(--sans);
}
.btn:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn--ghost{background:transparent;color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--cream)}
.btn--gold{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.btn--gold:hover{background:var(--ink);border-color:var(--ink);color:var(--cream)}
.btn--light{background:transparent;border-color:var(--cream);color:var(--cream)}
.btn--light:hover{background:var(--cream);color:var(--ink)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;color:var(--cream);overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,13,13,.15) 0%,rgba(13,13,13,.55) 60%,rgba(13,13,13,.85) 100%),
             url("../images/hero.jpg") center/cover no-repeat;
  z-index:0;
}
.hero .container{position:relative;z-index:1;padding-top:120px;padding-bottom:80px;width:100%}
.hero h1{color:var(--cream);max-width:18ch;margin-top:18px}
.hero .lead{color:rgba(245,240,232,.85);max-width:54ch;margin:24px 0 36px;font-size:1.1rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

.hero-meta{
  position:absolute;bottom:0;left:0;right:0;z-index:1;
  border-top:1px solid var(--line-dark);
  background:linear-gradient(180deg,transparent,rgba(13,13,13,.5));
}
.hero-meta-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.hero-meta-item{padding:22px 24px;border-left:1px solid var(--line-dark);color:var(--cream)}
.hero-meta-item:first-child{border-left:0}
.hero-meta-item .num{font-family:var(--serif);font-size:1.8rem;color:var(--gold)}
.hero-meta-item .label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;opacity:.75;margin-top:4px}

/* ---------- Page header (interior pages) ---------- */
.page-header{padding:120px 0 80px;background:var(--ink);color:var(--cream);position:relative}
.page-header h1{color:var(--cream);margin-top:16px;max-width:22ch}
.page-header p{color:rgba(245,240,232,.75);max-width:60ch;margin-top:18px;font-size:1.05rem}

/* ---------- Grid sections ---------- */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,5vw,72px);align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.split{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(28px,5vw,72px);align-items:start}
@media (max-width:900px){
  .grid-2,.grid-3,.grid-4,.split{grid-template-columns:1fr}
  .hero-meta-inner{grid-template-columns:repeat(2,1fr)}
  .hero-meta-item:nth-child(3){border-left:0}
}

/* ---------- Service cards ---------- */
.service{
  padding:36px 32px;background:var(--paper);border:1px solid var(--line);
  transition:.35s;position:relative;overflow:hidden;
}
.service::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--gold);transition:.4s}
.service:hover{transform:translateY(-4px);box-shadow:var(--shadow-sm)}
.service:hover::after{width:100%}
.service .icon{width:44px;height:44px;border:1px solid var(--gold);color:var(--gold);display:grid;place-items:center;font-family:var(--serif);font-size:1.1rem;margin-bottom:20px}
.service h3{margin-bottom:10px}
.service p{font-size:.95rem}

/* ---------- Project cards ---------- */
.project{position:relative;overflow:hidden;background:var(--ink)}
.project img{transition:transform .8s cubic-bezier(.2,.7,.2,1);width:100%;aspect-ratio:4/3;object-fit:cover}
.project:hover img{transform:scale(1.06);opacity:.9}
.project .meta{
  position:absolute;left:0;right:0;bottom:0;padding:22px 24px;color:var(--cream);
  background:linear-gradient(180deg,transparent,rgba(13,13,13,.85));
}
.project .meta .tag{font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.project .meta h3{color:var(--cream);font-size:1.4rem;margin-top:4px}

/* ---------- Process steps ---------- */
.steps{counter-reset:step;display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line-dark)}
.step{padding:36px 28px;border-right:1px solid var(--line-dark);counter-increment:step;position:relative}
.step:last-child{border-right:0}
.step::before{
  content:"0" counter(step);font-family:var(--serif);font-size:2.4rem;color:var(--gold);display:block;margin-bottom:14px;
}
.step h3{color:var(--cream);font-size:1.25rem;margin-bottom:8px}
.step p{font-size:.92rem;color:rgba(245,240,232,.7)}
@media (max-width:900px){.steps{grid-template-columns:1fr}.step{border-right:0;border-bottom:1px solid var(--line-dark)}.step:last-child{border-bottom:0}}

/* ---------- Testimonials ---------- */
.quote{
  padding:48px;background:var(--paper);border:1px solid var(--line);
}
.quote p{font-family:var(--serif);font-size:clamp(1.3rem,2vw,1.7rem);color:var(--ink);line-height:1.4;font-style:italic}
.quote .who{margin-top:24px;font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ---------- CTA strip ---------- */
.cta-strip{padding:80px 0;background:var(--ink);color:var(--cream);text-align:center}
.cta-strip h2{color:var(--cream)}
.cta-strip p{color:rgba(245,240,232,.75);max-width:58ch;margin:18px auto 32px;font-size:1.05rem}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:rgba(245,240,232,.7);padding:72px 0 32px;border-top:1px solid var(--line-dark)}
.footer h4{color:var(--cream);font-family:var(--sans);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:18px;font-weight:600}
.footer a{color:rgba(245,240,232,.7)}
.footer a:hover{color:var(--gold)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px;font-size:.92rem}
.footer-bottom{margin-top:56px;padding-top:24px;border-top:1px solid var(--line-dark);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.82rem;color:rgba(245,240,232,.55)}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}

/* ---------- Forms ---------- */
.form{display:grid;gap:18px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:680px){.form .row{grid-template-columns:1fr}}
.form label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:6px;display:block;font-weight:600}
.form input,.form select,.form textarea{
  width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);
  font-family:var(--sans);font-size:1rem;color:var(--ink);border-radius:0;outline:none;transition:.25s;
}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--ink)}
.form textarea{min-height:140px;resize:vertical}
.note{font-size:.8rem;color:var(--muted);margin-top:8px}

/* ---------- Mobile nav ---------- */
@media (max-width:900px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:78px 0 0 0;background:var(--paper);
    flex-direction:column;justify-content:flex-start;align-items:flex-start;
    padding:32px 24px;gap:18px;transform:translateX(100%);transition:.35s;
    border-top:1px solid var(--line);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1.1rem}
  .nav-cta{margin-top:14px}
}

/* ---------- Misc ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}
.divider{height:1px;background:var(--line);margin:48px 0}
.contact-info{display:grid;gap:22px}
.contact-info .item{display:flex;gap:14px;align-items:flex-start}
.contact-info .item .lbl{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);font-weight:600}
.contact-info .item p{color:var(--ink);margin-top:4px}
