/* ===== Brand tokens ===== */
:root{
  --mauve-deep:#8a6a68;
  --mauve:#a87f7b;
  --rose:#b89490;
  --cream:#ece0d1;
  --cream-soft:#f4ece4;
  --ink:#4a3b38;
  --ink-soft:#6f5b57;
  --white:#ffffff;
  --shadow:0 18px 50px rgba(110,80,78,.16);
  --radius:22px;
  font-size:16px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Assistant','Heebo',sans-serif;
  color:var(--ink);
  background:var(--cream-soft);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3{font-family:'Heebo',sans-serif;font-weight:800;line-height:1.2}
a{text-decoration:none;color:inherit}
section{padding:96px 24px}

/* ===== Navbar ===== */
.nav{position:fixed;top:0;left:0;right:0;z-index:60;background:rgba(244,236,228,0);backdrop-filter:blur(0);border-bottom:1px solid rgba(138,106,104,0);transition:background .4s,backdrop-filter .4s,border-color .4s}
.nav.scrolled{background:rgba(244,236,228,.82);backdrop-filter:blur(12px);border-bottom:1px solid rgba(138,106,104,.12)}
.nav-inner{max-width:1140px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:16px 24px}
.nav-logo{font-family:'Heebo';font-weight:800;font-size:1.35rem;color:var(--cream);letter-spacing:.5px;transition:color .4s}
.nav.scrolled .nav-logo{color:var(--mauve-deep)}
.nav-links{list-style:none;display:flex;gap:28px;align-items:center}
.nav-links a{font-weight:600;color:rgba(255,255,255,.9);transition:color .2s}
.nav.scrolled .nav-links a{color:var(--ink-soft)}
.nav-links a:hover{color:var(--cream)}
.nav.scrolled .nav-links a:hover{color:var(--mauve-deep)}
.nav-cta{background:rgba(255,255,255,.18);border:1.5px solid rgba(255,255,255,.5);color:var(--cream)!important;padding:8px 20px;border-radius:999px}
.nav.scrolled .nav-cta{background:var(--mauve-deep);border-color:transparent;color:var(--cream)!important}

/* ===== Hero scroll stage ===== */
.hero-stage{height:230vh;position:relative}
.hero{
  position:sticky;top:0;height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
}
.hero-gradient{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,#7f5f5d 0%,#a87f7b 42%,#cda9a2 70%,#f4ece4 100%);
  background-size:100% 200%;animation:gradShift 14s ease-in-out infinite alternate;
}
@keyframes gradShift{from{background-position:0 0}to{background-position:0 30%}}

.hero-shimmer{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(60% 40% at 50% 22%,rgba(255,255,255,.35),transparent 70%);
  animation:breathe 8s ease-in-out infinite;
}
@keyframes breathe{0%,100%{opacity:.5;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}

/* particles */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none}
.particle{position:absolute;bottom:-20px;border-radius:50%;background:rgba(255,255,255,.55);filter:blur(.5px);animation:floatUp linear infinite}
@keyframes floatUp{
  0%{transform:translateY(0) translateX(0);opacity:0}
  10%{opacity:.8}
  90%{opacity:.6}
  100%{transform:translateY(-105vh) translateX(var(--drift,20px));opacity:0}
}

/* Logo (descends behind clouds on scroll) */
.hero-logo-wrap{
  position:absolute;left:50%;top:24%;z-index:5;
  transform:translate3d(-50%,0,0);will-change:transform,opacity;
  animation:logoIn 1.2s cubic-bezier(.2,.8,.2,1) both, bob 6s ease-in-out 1.2s infinite;
}
@keyframes logoIn{from{opacity:0;transform:translate3d(-50%,40px,0) scale(.85)}to{opacity:1;transform:translate3d(-50%,0,0) scale(1)}}
@keyframes bob{0%,100%{margin-top:0}50%{margin-top:-12px}}
.hero-logo{width:240px;height:auto;display:block;filter:drop-shadow(0 12px 30px rgba(70,42,40,.3))}
.hero-logo-fallback{
  font-family:'Heebo';font-weight:800;font-size:3.6rem;line-height:.95;color:var(--cream);
  white-space:pre;letter-spacing:1px;text-transform:lowercase;
  filter:drop-shadow(0 12px 30px rgba(70,42,40,.3))}

/* Text content */
.hero-content{position:absolute;left:50%;top:58%;transform:translateX(-50%);z-index:4;width:min(720px,90%);will-change:transform,opacity;animation:fadeUp 1s ease .5s both}
@keyframes fadeUp{from{opacity:0;transform:translate(-50%,30px)}to{opacity:1;transform:translate(-50%,0)}}
.hero-tagline{font-family:'Heebo';font-weight:700;font-size:2.1rem;color:var(--cream);margin-bottom:10px;text-shadow:0 4px 20px rgba(70,42,40,.25)}
.hero-sub{color:rgba(255,255,255,.94);font-size:1.12rem;margin-bottom:28px}
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Cloud layers */
.cloud-layer{position:absolute;left:0;right:0;bottom:-1px;line-height:0;will-change:transform}
.cloud-layer svg{width:140%;height:auto;display:block}
.cloud-back{z-index:2;animation:drift 32s ease-in-out infinite alternate}
.cloud-mid{z-index:4;animation:drift 24s ease-in-out -6s infinite alternate-reverse}
.cloud-front{z-index:6;animation:drift 18s ease-in-out -3s infinite alternate}
@keyframes drift{from{transform:translateX(0)}to{transform:translateX(-14%)}}

/* scroll hint */
.scroll-hint{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:7;color:rgba(255,255,255,.9);font-weight:600;font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:2px;transition:opacity .4s}
.scroll-chevron{font-size:1.6rem;line-height:1;animation:nudge 1.6s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateY(0);opacity:.7}50%{transform:translateY(6px);opacity:1}}

/* ===== Buttons ===== */
.btn{display:inline-block;padding:13px 30px;border-radius:999px;font-weight:700;font-family:'Heebo';transition:transform .25s,box-shadow .25s,background .25s;cursor:pointer;border:none;position:relative;overflow:hidden}
.btn-primary{background:var(--mauve-deep);color:var(--cream)}
.btn-primary:hover{background:var(--mauve);transform:translateY(-3px);box-shadow:var(--shadow)}
.btn-ghost{background:rgba(255,255,255,.18);color:var(--cream);border:1.5px solid rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.32);transform:translateY(-3px)}
.btn-block{width:100%;margin-top:8px}

/* ===== Section heads ===== */
.section-head{max-width:680px;margin:0 auto 56px;text-align:center}
.eyebrow{display:inline-block;color:var(--mauve);font-weight:700;letter-spacing:2px;font-size:.85rem;text-transform:uppercase;margin-bottom:12px}
.section-head h2{font-size:2.4rem;color:var(--ink);margin-bottom:14px}
.section-lead{color:var(--ink-soft);font-size:1.08rem}

/* ===== Reveal on scroll ===== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.8,.2,1);transition-delay:var(--d,0ms)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none}
  .hero-logo-wrap,.hero-content,.cloud-layer,.hero-gradient,.hero-shimmer,.particle{animation:none!important}
}

/* ===== Services ===== */
.services{background:var(--cream-soft);position:relative}
.cards{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px}
.card{background:var(--white);border-radius:var(--radius);padding:36px 28px;box-shadow:0 10px 30px rgba(110,80,78,.07);border:1px solid rgba(138,106,104,.08);transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-8px) scale(1.015);box-shadow:var(--shadow)}
.card-icon{width:56px;height:56px;display:grid;place-items:center;border-radius:16px;background:linear-gradient(135deg,#cda9a2,#a87f7b);color:var(--cream);font-size:1.5rem;margin-bottom:18px;transition:transform .4s}
.card:hover .card-icon{transform:rotate(-8deg) scale(1.08)}
.card h3{font-size:1.3rem;margin-bottom:10px;color:var(--mauve-deep)}
.card p{color:var(--ink-soft)}

/* ===== Portfolio ===== */
.portfolio{background:linear-gradient(180deg,#f4ece4,#efe3d8)}
.gallery{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.g-item{border-radius:var(--radius);overflow:hidden;box-shadow:0 10px 28px rgba(110,80,78,.1);background:var(--white);transition:transform .35s,box-shadow .35s}
.g-item:hover{transform:translateY(-6px)}
.g-ph{aspect-ratio:4/3;display:grid;place-items:center;background:linear-gradient(135deg,#c9a59e,#8a6a68);color:var(--cream);font-family:'Heebo';font-weight:700;font-size:1.2rem;letter-spacing:1px;transition:transform .5s}
.g-item:hover .g-ph{transform:scale(1.06)}
.g-item figcaption{padding:14px 18px;font-weight:600;color:var(--ink)}

/* ===== About ===== */
.about{background:var(--cream-soft)}
.about-inner{max-width:1040px;margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:center}
.about-text h2{font-size:2.4rem;margin-bottom:16px;color:var(--ink)}
.about-text p{color:var(--ink-soft);margin-bottom:14px}
.about-stats{list-style:none;display:flex;gap:28px;margin-top:24px;flex-wrap:wrap}
.about-stats li{display:flex;flex-direction:column}
.about-stats strong{font-family:'Heebo';font-size:1.8rem;color:var(--mauve-deep)}
.about-stats span{color:var(--ink-soft);font-size:.92rem}
.about-card{aspect-ratio:1;border-radius:30px;background:linear-gradient(160deg,#a87f7b,#8a6a68);display:grid;place-items:center;box-shadow:var(--shadow);animation:floatCard 7s ease-in-out infinite}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.about-logo-fallback{font-family:'Heebo';font-weight:800;font-size:2.6rem;color:var(--cream);text-align:center;line-height:1;text-transform:lowercase}

/* ===== Contact ===== */
.contact{background:linear-gradient(180deg,#efe3d8,#e6d6c8)}
.contact-inner{max-width:720px;margin:0 auto}
.contact-form{background:var(--white);border-radius:var(--radius);padding:36px;box-shadow:var(--shadow);display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column}
.field-full{grid-column:1/-1}
.field label{font-weight:600;margin-bottom:6px;color:var(--ink)}
.field input,.field select,.field textarea{font-family:inherit;font-size:1rem;padding:12px 14px;border:1.5px solid rgba(138,106,104,.25);border-radius:12px;background:var(--cream-soft);color:var(--ink);transition:border .2s,box-shadow .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--mauve);box-shadow:0 0 0 4px rgba(168,127,123,.15)}
.thanks{display:none;grid-column:1/-1;text-align:center;color:var(--mauve-deep);font-weight:600}
.contact-quick{display:flex;gap:14px;justify-content:center;margin-top:28px;flex-wrap:wrap}
.quick-link{background:var(--white);padding:12px 22px;border-radius:999px;font-weight:600;color:var(--mauve-deep);box-shadow:0 6px 18px rgba(110,80,78,.1);transition:transform .25s,box-shadow .25s}
.quick-link:hover{transform:translateY(-3px);box-shadow:var(--shadow)}

/* ===== Footer ===== */
.footer{background:var(--mauve-deep);color:var(--cream);text-align:center;padding:42px 24px}
.footer-logo{font-family:'Heebo';font-weight:800;font-size:1.6rem;margin-bottom:8px;text-transform:lowercase}
.footer p{opacity:.85;font-size:.92rem}

/* ===== Responsive ===== */
@media(max-width:760px){
  .nav-links{gap:16px}
  .nav-links li:not(:last-child){display:none}
  .hero-tagline{font-size:1.6rem}
  .hero-logo{width:180px}
  .hero-logo-fallback{font-size:2.7rem}
  .section-head h2{font-size:1.9rem}
  .about-inner{grid-template-columns:1fr}
  .about-card{max-width:280px;margin:0 auto}
  .contact-form{grid-template-columns:1fr;padding:26px}
}
