/* ===== Tokens ===== */
:root{
  --bg:#faf7f3; --bg-alt:#efe9e1; --dark:#21201d; --text:#4a463f; --muted:#8b8579;
  --accent:#804c73; --accent-soft:#a06a92; --white:#fff;
  --shadow-sm:0 6px 20px rgba(33,32,29,.06);
  --shadow-md:0 18px 50px rgba(33,32,29,.10);
  --shadow-lg:0 30px 80px rgba(33,32,29,.18);
  --radius:18px; --radius-lg:28px; --max:1180px;
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
}

/* ===== Base ===== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--serif);color:var(--dark);font-weight:600;line-height:1.1}
.accent{color:var(--accent);font-style:italic;font-weight:500}

.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 28px}

/* ===== Buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 28px;border-radius:999px;
  font-family:var(--sans);font-size:.95rem;font-weight:600;
  cursor:pointer;border:1px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease, color .25s ease;
}
.btn--primary{background:var(--accent);color:var(--white);box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--accent-soft);transform:translateY(-3px);box-shadow:var(--shadow-md)}
.btn--ghost{background:rgba(255,255,255,.12);color:var(--white);border-color:rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn--ghost:hover{background:rgba(255,255,255,.95);color:var(--dark);transform:translateY(-3px)}
.btn--block{width:100%;margin-top:6px}

/* ===== Eyebrow ===== */
.eyebrow{
  text-transform:uppercase;letter-spacing:.28em;font-size:.72rem;font-weight:600;
  color:var(--accent);margin-bottom:18px;font-family:var(--sans);
}
.eyebrow--light{color:#e6c9dd}

/* ===== Nav ===== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:50;
  padding:22px 0;transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav__brand{font-family:var(--serif);font-size:1.6rem;font-weight:600;color:var(--white);letter-spacing:.01em}
.nav__links{display:flex;gap:34px}
.nav__links a{color:rgba(255,255,255,.9);font-size:.95rem;font-weight:500;transition:color .2s ease}
.nav__links a:hover{color:var(--white)}
.nav.scrolled{background:rgba(250,247,243,.92);backdrop-filter:blur(10px);box-shadow:var(--shadow-sm);padding:14px 0}
.nav.scrolled .nav__brand{color:var(--dark)}
.nav.scrolled .nav__links a{color:var(--text)}
.nav.scrolled .nav__links a:hover{color:var(--accent)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero__bg{
  position:absolute;inset:0;
  background:url('https://images.unsplash.com/photo-1616594039964-ae9021a400a0?auto=format&fit=crop&w=1600&q=80') center/cover no-repeat;
  transform:scale(1.04);
}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(110deg,rgba(20,16,18,.78) 0%,rgba(20,16,18,.45) 55%,rgba(20,16,18,.25) 100%)}
.hero__inner{position:relative;z-index:2;padding-top:120px;padding-bottom:80px;max-width:760px}
.hero__title{font-size:clamp(3rem,8vw,6rem);color:var(--white);font-weight:700;letter-spacing:-.01em}
.hero__lead{color:rgba(255,255,255,.85);font-size:1.2rem;max-width:540px;margin:26px 0 36px}
.hero__actions{display:flex;flex-wrap:wrap;gap:16px}
.hero__stats{display:flex;flex-wrap:wrap;gap:48px;margin-top:64px}
.stat{display:flex;flex-direction:column;gap:2px}
.stat__num{font-family:var(--serif);font-size:2.6rem;font-weight:600;color:var(--white)}
.stat__label{color:rgba(255,255,255,.72);font-size:.85rem;text-transform:uppercase;letter-spacing:.12em}

/* ===== Sections ===== */
.section{padding:110px 0}
.section--alt{background:var(--bg-alt)}
.section__head{max-width:680px;margin:0 auto 64px;text-align:center}
.section__title{font-size:clamp(2.2rem,5vw,3.4rem)}
.section__lead{color:var(--muted);font-size:1.12rem;margin-top:18px}

/* ===== Card base ===== */
.card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform .35s ease, box-shadow .35s ease}

/* ===== Portfolio ===== */
.portfolio__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.project{overflow:hidden}
.project--wide{grid-column:span 2}
.project:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.project__media{overflow:hidden;aspect-ratio:16/11}
.project--wide .project__media{aspect-ratio:21/9}
.project__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.project:hover .project__media img{transform:scale(1.06)}
.project__body{padding:26px 30px 32px}
.tag{
  display:inline-block;font-size:.7rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent);background:rgba(128,76,115,.09);padding:5px 14px;border-radius:999px;margin-bottom:14px;
}
.project__name{font-size:1.9rem}
.project__meta{color:var(--muted);margin-top:4px}

/* ===== Services ===== */
.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px}
.service{padding:38px 30px;text-align:left}
.service:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.service__icon{
  width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  background:rgba(128,76,115,.1);color:var(--accent);font-size:1.5rem;margin-bottom:22px;
}
.service__title{font-size:1.55rem;margin-bottom:10px}
.service__text{color:var(--muted);font-size:.98rem}

/* ===== About ===== */
.about{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about__media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}
.about__media img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .7s ease}
.about__media:hover img{transform:scale(1.04)}
.about__text{margin:18px 0;font-size:1.08rem}
.about__body .btn{margin-top:14px}

/* ===== Process ===== */
.process__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.process__step{padding:8px 6px}
.process__num{font-family:var(--serif);font-size:3rem;font-weight:600;color:var(--accent-soft);display:block;margin-bottom:8px}
.process__title{font-size:1.55rem;margin-bottom:8px}
.process__text{color:var(--muted);font-size:.98rem}

/* ===== Testimonials ===== */
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.testimonial{padding:36px 32px;display:flex;flex-direction:column;gap:18px}
.testimonial:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.stars{color:#d8a23a;letter-spacing:.14em;font-size:1rem}
.testimonial__quote{font-family:var(--serif);font-size:1.3rem;line-height:1.5;color:var(--dark);font-style:italic}
.testimonial__person{display:flex;align-items:center;gap:14px;margin-top:auto}
.testimonial__person img{width:52px;height:52px;border-radius:50%;object-fit:cover}
.testimonial__name{display:block;font-weight:600;color:var(--dark)}
.testimonial__role{display:block;font-size:.85rem;color:var(--muted)}

/* ===== Contact ===== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.contact__list{list-style:none;margin-top:34px;display:flex;flex-direction:column;gap:18px}
.contact__list li{display:flex;flex-direction:column}
.contact__list strong{font-size:.78rem;text-transform:uppercase;letter-spacing:.16em;color:var(--accent)}
.contact__list span{color:var(--text);font-size:1.05rem}
.contact__form{padding:40px}
.field{margin-bottom:18px;display:flex;flex-direction:column}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{font-size:.8rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--dark);
  padding:13px 16px;border:1px solid #e3dccf;border-radius:var(--radius);background:var(--bg);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(128,76,115,.12);background:var(--white);
}
.field textarea{resize:vertical}
.form-note{margin-top:14px;font-size:.95rem;color:var(--muted);min-height:1.2em}
.form-note.success{color:var(--accent);font-weight:600}

/* ===== Footer ===== */
.footer{background:var(--dark);color:#cfc9bf;padding:72px 0 28px}
.footer__inner{display:grid;grid-template-columns:1.4fr 2fr;gap:48px}
.footer .nav__brand{color:var(--white)}
.footer__tagline{margin:16px 0 22px;max-width:340px;color:#a8a298}
.footer__socials{display:flex;gap:22px}
.footer__socials a{font-size:.9rem;color:#cfc9bf;transition:color .2s ease}
.footer__socials a:hover{color:var(--white)}
.footer__cols{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.footer__col h4{color:var(--white);font-family:var(--sans);font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;font-weight:600;margin-bottom:16px}
.footer__col a{display:block;color:#a8a298;font-size:.95rem;margin-bottom:10px;transition:color .2s ease}
.footer__col a:hover{color:var(--white)}
.footer__bottom{display:flex;justify-content:space-between;border-top:1px solid rgba(255,255,255,.1);margin-top:52px;padding-top:24px;font-size:.85rem;color:#8a847a}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.reveal.visible{opacity:1;transform:none}

/* ===== Responsive ===== */
@media (max-width:980px){
  .nav__links{display:none}
  .section{padding:80px 0}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .process__grid{grid-template-columns:repeat(2,1fr)}
  .testimonials__grid{grid-template-columns:1fr}
  .about,.contact{grid-template-columns:1fr;gap:40px}
  .footer__inner{grid-template-columns:1fr;gap:36px}
  .hero__stats{gap:32px}
}
@media (max-width:600px){
  .container{padding:0 20px}
  .portfolio__grid{grid-template-columns:1fr}
  .project--wide{grid-column:span 1}
  .services__grid,.process__grid{grid-template-columns:1fr}
  .field-row{grid-template-columns:1fr}
  .hero__inner{padding-top:110px}
  .hero__title{font-size:clamp(2.4rem,11vw,3.4rem)}
  .hero__lead{font-size:1.05rem}
  .hero__actions{flex-direction:column;align-items:stretch}
  .hero__stats{gap:24px}
  .stat__num{font-size:2.1rem}
  .footer__cols{grid-template-columns:1fr 1fr}
  .footer__bottom{flex-direction:column;gap:8px;text-align:center}
  .nav__cta{display:none}
}
