:root{
  --ink:#171615;
  --ink-2:#2f2d2a;
  --muted:#77726a;
  --muted-2:#9b948a;
  --paper:#fbfaf7;
  --paper-2:#f4f0e8;
  --white:#fff;
  --line:#e6dfd3;
  --line-dark:rgba(23,22,21,.12);
  --accent:#171615;
  --accent-soft:#ded4c4;
  --cream:#fffdf8;
  --radius-xl:44px;
  --radius-lg:30px;
  --radius-md:20px;
  --shadow:0 28px 90px rgba(39,34,26,.09);
  --shadow-soft:0 16px 50px rgba(39,34,26,.055);
  --max:1160px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    radial-gradient(circle at 8% 0%,rgba(220,207,185,.55),transparent 30%),
    radial-gradient(circle at 94% 16%,rgba(226,218,202,.65),transparent 25%),
    linear-gradient(180deg,#fffdf9 0%,var(--paper) 44%,#f7f2ea 100%);
  color:var(--ink);
  font-family:Manrope,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:-1;
  background-image:
    linear-gradient(rgba(23,22,21,.032) 1px,transparent 1px),
    linear-gradient(90deg,rgba(23,22,21,.028) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.72),transparent 82%);
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:#171615;color:#fff}

.site-nav{
  position:sticky;
  top:16px;
  z-index:30;
  width:min(var(--max),calc(100% - 32px));
  margin:16px auto 0;
  padding:10px 10px 10px 18px;
  border:1px solid rgba(23,22,21,.095);
  border-radius:999px;
  background:rgba(255,253,248,.76);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  box-shadow:0 16px 55px rgba(33,28,20,.07);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand{display:flex;align-items:baseline;gap:2px;font-weight:900;letter-spacing:-.055em}
.brand span{font-family:"Playfair Display",Georgia,serif;font-size:30px;font-style:normal;font-weight:700}
.brand em{font-style:normal;font-size:13px;text-transform:uppercase;letter-spacing:.16em;font-weight:800;margin-left:1px}
.site-nav nav{display:flex;gap:4px;align-items:center}
.site-nav nav a{padding:11px 14px;display:inline-flex;align-items:center;gap:7px;border-radius:999px;color:#504c46;font-size:14px;font-weight:700;transition:background .22s ease,color .22s ease,transform .22s ease}
.site-nav nav a:hover{background:rgba(23,22,21,.06);color:#171615;transform:translateY(-1px)}
.nav-cta{background:#171615!important;color:#fff!important;padding-inline:18px!important;box-shadow:0 10px 24px rgba(23,22,21,.16)}

.hero{
  width:min(var(--max),calc(100% - 32px));
  margin:34px auto 0;
  min-height:690px;
  border-radius:var(--radius-xl);
  border:1px solid rgba(23,22,21,.1);
  background:
    linear-gradient(115deg,rgba(255,255,255,.86) 0%,rgba(255,253,248,.92) 42%,rgba(234,226,213,.94) 100%);
  display:grid;
  grid-template-columns:minmax(0,1.22fr) minmax(340px,.78fr);
  gap:38px;
  padding:52px;
  position:relative;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.hero:before{
  content:"EDGE";
  position:absolute;
  right:-42px;
  bottom:-54px;
  font-family:"Playfair Display",Georgia,serif;
  font-size:210px;
  line-height:1;
  letter-spacing:-.045em;
  color:rgba(23,22,21,.035);
  pointer-events:none;
}
.grain:after{
  content:"";
  position:absolute;
  inset:0;
  background-image:radial-gradient(rgba(23,22,21,.08) .7px,transparent .7px);
  background-size:16px 16px;
  opacity:.23;
  pointer-events:none;
  mix-blend-mode:multiply;
}
.hero-copy,.hero-card{position:relative;z-index:2}
.hero-copy{display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.kicker{
  margin:0 0 16px;
  color:#7c756b;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
}
.hero h1{
  margin:0;
  font-family:"Playfair Display",Georgia,serif;
  font-weight:400;
  font-size:clamp(50px,7.2vw,104px);
  line-height:.94;
  letter-spacing:-.045em;
  max-width:790px;
}
.lead{font-size:19px;line-height:1.78;color:#5d5851;max-width:650px;margin:28px 0 0}
.hero-actions{display:flex;gap:12px;margin-top:34px;flex-wrap:wrap}
.btn,.button{
  border:0;
  border-radius:999px;
  padding:15px 21px;
  font-weight:800;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
}
.btn:hover,.button:hover{transform:translateY(-2px)}
.primary{background:#171615;color:#fff;box-shadow:0 16px 34px rgba(23,22,21,.18)}
.ghost{background:rgba(255,255,255,.64);border:1px solid var(--line);color:#2e2b27}

.hero-card{
  align-self:end;
  background:rgba(255,255,255,.64);
  border:1px solid rgba(255,255,255,.88);
  border-radius:38px;
  padding:16px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
}
.floating-label{display:inline-flex;align-items:center;gap:8px;background:#171615;color:#fff;padding:10px 13px;border-radius:999px;font-size:12px;font-weight:800;margin:4px 0 14px 4px}.floating-label i{color:#bff0a7}

.portrait-wrap{height:345px;border-radius:30px;background:linear-gradient(135deg,#e7dfd3,#f8f3ea);overflow:hidden;display:grid;place-items:center;position:relative}
.portrait-wrap:after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.16),transparent 46%);pointer-events:none}
.portrait-wrap img{width:100%;height:100%;object-fit:cover;filter:saturate(.96) contrast(1.02)}
.avatar-placeholder{font-family:"Playfair Display",Georgia,serif;font-size:98px;color:#181716;letter-spacing:-.08em}
.hero-card h2{font-family:"Playfair Display",Georgia,serif;font-size:38px;font-weight:400;letter-spacing:-.055em;margin:18px 8px 0}
.hero-card p{color:var(--muted);margin:4px 8px 18px;font-weight:600}
.mini-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:0 4px 4px}
.mini-stats span{border:1px solid var(--line);border-radius:20px;padding:14px;background:rgba(255,253,248,.72);color:#6f685f;font-size:13px;line-height:1.35}
.mini-stats b{display:block;color:#171615;font-size:22px;margin-bottom:2px;letter-spacing:-.04em}

.section{width:min(var(--max),calc(100% - 32px));margin:94px auto;position:relative}
.section-head{display:grid;grid-template-columns:190px minmax(0,1fr) 330px;align-items:end;gap:34px;margin-bottom:32px}
.section-head.compact{grid-template-columns:190px minmax(0,1fr)}
.section-head h2,.about-block h2,.contact-panel h2{
  font-family:"Playfair Display",Georgia,serif;
  font-size:clamp(38px,5.2vw,68px);
  font-weight:700;
  letter-spacing:-.035em;
  line-height:1;
  margin:0;
}
.section-head p:last-child{color:var(--muted);line-height:1.7;margin:0;font-weight:520}

.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px;align-items:stretch}
.work-card{
  grid-column:span 4;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(23,22,21,.095);
  border-radius:34px;
  overflow:hidden;
  box-shadow:var(--shadow-soft);
  transition:transform .28s ease,box-shadow .28s ease,border-color .28s ease;
}
.work-card:hover{transform:translateY(-6px);box-shadow:0 26px 70px rgba(39,34,26,.12);border-color:rgba(23,22,21,.18)}
.work-card.wide{grid-column:span 8}
.work-card a{display:flex;flex-direction:column;height:100%}
.work-image{height:285px;background:linear-gradient(135deg,#eee8de,#d9cfbf);overflow:hidden;position:relative}
.work-card.wide .work-image{height:390px}
.work-image:before{content:"";position:absolute;inset:14px;border:1px solid rgba(255,255,255,.36);border-radius:24px;z-index:1;pointer-events:none}
.work-image img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease,filter .55s ease}
.work-card:hover .work-image img{transform:scale(1.045);filter:saturate(1.04) contrast(1.02)}
.work-card h3{font-size:24px;letter-spacing:-.04em;margin:14px 20px 8px;line-height:1.08}
.work-card p{margin:0 20px 24px;color:var(--muted);line-height:1.62;font-size:15px}
.work-meta{display:flex;justify-content:space-between;gap:12px;margin:20px 20px 0;color:#7d766d;font-size:11px;text-transform:uppercase;letter-spacing:.14em;font-weight:800}
.work-meta em{font-style:normal;color:#171615}

.service-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.service-card{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(23,22,21,.095);
  border-radius:30px;
  padding:26px;
  min-height:230px;
  box-shadow:0 12px 38px rgba(39,34,26,.045);
  transition:transform .25s ease,background .25s ease;
}
.service-card:hover{transform:translateY(-4px);background:#fff}
.service-icon{font-size:22px;width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:#f2ebe0;border:1px solid var(--line);margin-bottom:30px;color:#201e1b}.service-icon i{line-height:1}
.service-card h3{font-size:21px;letter-spacing:-.04em;margin:0 0 10px}
.service-card p,.about-block p,.contact-panel p{color:var(--muted);line-height:1.75}

.about-block{
  display:grid;
  grid-template-columns:.82fr 1fr;
  gap:48px;
  background:#171615;
  color:#fff;
  border-radius:42px;
  padding:50px;
  overflow:hidden;
  box-shadow:var(--shadow);
}
.about-block:after{content:"";position:absolute;right:32px;bottom:28px;width:180px;height:180px;border:1px solid rgba(255,255,255,.11);border-radius:50%}
.about-block .kicker,.about-block p{color:#cfc7bc}.about-block p{font-size:18px;margin:0}.about-block h2{color:#fff}

.quote-wall{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.quote-wall blockquote{
  margin:0;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(23,22,21,.095);
  border-radius:32px;
  padding:30px;
  font-family:"Playfair Display",Georgia,serif;
  font-size:26px;
  line-height:1.32;
  letter-spacing:-.015em;
  box-shadow:0 12px 36px rgba(39,34,26,.045);
}
.quote-wall cite{display:block;margin-top:22px;font-family:Manrope,sans-serif;font-size:13px;color:#7c756b;font-style:normal;letter-spacing:.03em}

.contact-panel{
  display:grid;
  grid-template-columns:.82fr 1fr;
  gap:30px;
  background:rgba(255,255,255,.82);
  border:1px solid rgba(23,22,21,.095);
  border-radius:42px;
  padding:38px;
  box-shadow:var(--shadow);
}
.contact-panel h2{margin-bottom:18px}
.contact-form{display:grid;gap:12px}
.contact-form input,.contact-form textarea{
  width:100%;
  border:1px solid var(--line);
  background:#fffdf9;
  border-radius:20px;
  padding:16px;
  font:inherit;
  outline:none;
  transition:border-color .2s ease,box-shadow .2s ease,background .2s ease;
}
.contact-form input:focus,.contact-form textarea:focus{border-color:rgba(23,22,21,.35);box-shadow:0 0 0 4px rgba(23,22,21,.055);background:#fff}
.contact-form textarea{resize:vertical;min-height:160px}
.contact-form button{justify-self:start}

.footer{
  width:min(var(--max),calc(100% - 32px));
  margin:50px auto 22px;
  padding:28px 0 0;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  gap:28px;
  color:#6f685f;
}
.footer strong{color:#171615;letter-spacing:-.04em;font-size:20px}.footer p{margin:8px 0 0}.footer-links{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-start}.footer-links a{border:1px solid var(--line);border-radius:999px;padding:10px 13px;background:rgba(255,255,255,.56);font-weight:700;color:#3d3934;display:inline-flex;align-items:center;gap:7px}

.project-page{width:min(1000px,calc(100% - 32px));margin:54px auto}.back-link{color:#69635b;font-weight:800}.project-hero{margin-top:24px;background:rgba(255,255,255,.82);border:1px solid rgba(23,22,21,.095);border-radius:42px;padding:36px;box-shadow:var(--shadow)}
.project-hero h1{font-family:"Playfair Display",Georgia,serif;font-size:clamp(46px,7vw,78px);font-weight:700;letter-spacing:-.035em;line-height:1;margin:0 0 22px}.project-hero p{color:var(--muted);line-height:1.8;font-size:17px}.project-hero img{border-radius:30px;margin-top:30px;width:100%;max-height:720px;object-fit:cover;box-shadow:0 18px 48px rgba(39,34,26,.1)}

.process-line{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
.process-item{
  min-height:190px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(23,22,21,.095);
  border-radius:32px;
  padding:26px;
  box-shadow:0 12px 38px rgba(39,34,26,.04);
}
.process-item span{
  display:inline-flex;
  width:42px;
  height:42px;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid var(--line);
  background:#fffdf8;
  color:#7b746b;
  font-size:12px;
  font-weight:900;
  letter-spacing:.1em;
  margin-bottom:32px;
}
.process-item strong{display:block;font-size:24px;letter-spacing:-.045em}
.process-item p{color:var(--muted);line-height:1.65;margin:10px 0 0}

@media(max-width:980px){
  .hero{grid-template-columns:1fr;min-height:auto;padding:34px}.hero-card{align-self:auto}.section-head,.section-head.compact{grid-template-columns:1fr;gap:14px}.work-card,.work-card.wide{grid-column:span 6}.service-grid{grid-template-columns:repeat(2,1fr)}.about-block,.contact-panel{grid-template-columns:1fr}.quote-wall{grid-template-columns:1fr}.process-line{grid-template-columns:1fr}
}
@media(max-width:720px){
  .site-nav{top:10px;width:calc(100% - 20px);border-radius:24px;align-items:flex-start}.site-nav nav{display:none}.brand span{font-size:31px}.hero{width:calc(100% - 20px);margin-top:18px;border-radius:30px;padding:24px}.hero h1{font-size:50px}.lead{font-size:17px}.portrait-wrap{height:285px}.section{width:calc(100% - 20px);margin:68px auto}.work-card,.work-card.wide{grid-column:1/-1}.work-card.wide .work-image,.work-image{height:285px}.service-grid{grid-template-columns:1fr}.about-block,.contact-panel{border-radius:30px;padding:26px}.quote-wall blockquote{font-size:23px}.footer{width:calc(100% - 20px);display:block}.footer-links{margin-top:18px}.hero-actions{width:100%}.hero-actions .btn{flex:1}.mini-stats{grid-template-columns:1fr}
}
