:root{
  --cream:#f3ecdc;
  --paper:#f8f3e7;
  --deep:#27301f;
  --moss:#4b5738;
  --sage:#9aac88;
  --soft:#d8d8c6;
  --taupe:#a49672;
  --ink:#1e211b;
  --muted:#68705d;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Nunito Sans",system-ui,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 20% 10%,rgba(154,172,136,.28),transparent 35%),
    linear-gradient(180deg,#f5efdf 0%,#eee6d4 100%);
  overflow-x:hidden;
}
body:before{
  content:"";
  position:fixed;
  inset:0;
  background-image:url("assets/paper/torn-paper-10.png");
  background-size:900px auto;
  opacity:.06;
  pointer-events:none;
  mix-blend-mode:multiply;
  z-index:-1;
}
a{color:inherit}
img{max-width:100%;display:block}

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:18px clamp(18px,4vw,64px);
  background:rgba(243,236,220,.76);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(75,87,56,.12);
}
.brand{
  display:flex;
  align-items:center;
  gap:13px;
  text-decoration:none;
  min-width:max-content;
}
.brand-dog{width:58px;height:auto}
.brand-text strong{
  display:block;
  font-family:"Cormorant Garamond",serif;
  font-size:31px;
  line-height:.9;
  color:var(--moss);
  letter-spacing:.01em;
}
.brand-text small{
  display:block;
  margin-top:5px;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:10px;
  font-weight:700;
  color:var(--muted);
}
.main-nav{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:24px;
  flex:1;
  font-size:14px;
}
.main-nav a{
  text-decoration:none;
  color:#2f3329;
  transition:.25s ease;
}
.main-nav a:hover{color:var(--moss)}
.nav-item{position:relative;padding:12px 0}
.dropdown>a:after{content:"⌄";font-size:14px;margin-left:5px}
.dropdown-panel{
  position:absolute;
  top:100%;
  left:-18px;
  width:265px;
  display:grid;
  gap:2px;
  padding:16px;
  background:rgba(248,243,231,.97);
  border:1px solid rgba(75,87,56,.15);
  border-radius:22px;
  box-shadow:0 20px 50px rgba(39,48,31,.13);
  opacity:0;
  transform:translateY(12px);
  pointer-events:none;
  transition:.25s ease;
}
.dropdown:hover .dropdown-panel{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.dropdown-panel a{
  padding:10px 12px;
  border-radius:14px;
}
.dropdown-panel a:hover{background:#ece6d8}
.nav-cta,.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  text-decoration:none;
  border-radius:999px;
  font-weight:800;
  transition:.28s ease;
}
.nav-cta{
  padding:12px 18px;
  background:var(--moss);
  color:var(--cream);
  min-width:max-content;
}
.nav-cta img,.btn img{width:30px}
.nav-cta:hover,.btn.primary:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 26px rgba(39,48,31,.18);
}
.menu-toggle{display:none}

.hero{
  position:relative;
  display:grid;
  grid-template-columns:minmax(320px,.9fr) minmax(420px,1.25fr);
  gap:40px;
  align-items:center;
  min-height:calc(100vh - 88px);
  padding:62px clamp(18px,5vw,78px) 78px;
}
.hero-copy{
  position:relative;
  z-index:2;
  padding:28px 0;
}
.overline{
  text-transform:uppercase;
  letter-spacing:.2em;
  font-weight:800;
  font-size:12px;
  color:var(--muted);
  margin-bottom:16px;
}
h1,h2,h3{
  font-family:"Cormorant Garamond",serif;
  font-weight:600;
  color:var(--deep);
}
h1{
  font-size:clamp(54px,7.2vw,112px);
  line-height:.86;
  letter-spacing:-.045em;
  margin-bottom:28px;
}
h1 em{
  font-style:italic;
  color:var(--moss);
  font-weight:500;
}
.lead{
  max-width:560px;
  font-size:20px;
  line-height:1.75;
  color:#3f4437;
}
.button-row{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:30px;
}
.btn{
  padding:15px 24px;
}
.btn.primary{
  background:var(--moss);
  color:var(--cream);
}
.btn.ghost{
  border:1px solid rgba(39,48,31,.45);
  color:var(--deep);
  background:rgba(248,243,231,.4);
}
.hero-media{
  position:relative;
  min-height:520px;
}
.hero-img{
  width:100%;
  height:540px;
  object-fit:cover;
  object-position:center;
  border-radius:48px 48px 120px 48px;
  box-shadow:0 24px 70px rgba(39,48,31,.20);
  filter:saturate(.82) contrast(.96) brightness(.94);
}
.hero-note{
  position:absolute;
  width:370px;
  left:-80px;
  bottom:-28px;
  transform:rotate(-3deg);
  opacity:.94;
  filter:drop-shadow(0 18px 30px rgba(39,48,31,.12));
}
.location-badge{
  position:absolute;
  right:-22px;
  bottom:34px;
  width:154px;
  height:154px;
  border-radius:999px;
  display:grid;
  place-content:center;
  text-align:center;
  background:var(--moss);
  color:var(--cream);
  box-shadow:0 18px 36px rgba(39,48,31,.2);
  transform:rotate(7deg);
}
.location-badge span{
  text-transform:uppercase;
  font-size:11px;
  letter-spacing:.2em;
}
.location-badge strong{
  font-family:"Cormorant Garamond",serif;
  font-size:26px;
  line-height:1;
}
.paper-float{
  position:absolute;
  z-index:0;
  opacity:.35;
  pointer-events:none;
}
.float-one{
  width:280px;
  left:2%;
  bottom:20px;
  transform:rotate(8deg);
}

.intro-section{
  display:grid;
  grid-template-columns:minmax(300px,.9fr) 1fr;
  gap:48px;
  align-items:center;
  padding:70px clamp(18px,6vw,90px);
}
.journal-note,.about-paper{
  position:relative;
  min-height:360px;
}
.paper-bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:fill;
  filter:drop-shadow(0 20px 34px rgba(39,48,31,.12));
}
.note-content{
  position:relative;
  z-index:1;
  padding:62px 60px;
}
.note-content h2,.section-heading h2,.movement-copy h2,.book-inner h2{
  font-size:clamp(38px,5vw,70px);
  line-height:.95;
  letter-spacing:-.025em;
}
.note-content p,.movement-copy p,.support-card p,.review,.book-inner p{
  font-size:17px;
  line-height:1.8;
  color:#3e4337;
}
.issue-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:13px;
  align-content:center;
}
.issue-cloud span{
  padding:13px 18px;
  border-radius:999px;
  background:rgba(154,172,136,.28);
  border:1px solid rgba(75,87,56,.16);
  color:#3f4935;
  font-weight:700;
  transform:rotate(var(--r,0deg));
}
.issue-cloud span:nth-child(2n){--r:-2deg}
.issue-cloud span:nth-child(3n){--r:2deg}

.services-section{
  padding:70px clamp(18px,5vw,78px);
}
.section-heading{
  max-width:900px;
  margin-bottom:36px;
}
.services-track{
  display:grid;
  grid-template-columns:repeat(5,minmax(190px,1fr));
  gap:18px;
}
.service-card{
  min-height:255px;
  padding:26px;
  border-radius:34px;
  background:rgba(248,243,231,.72);
  border:1px solid rgba(75,87,56,.14);
  box-shadow:0 18px 45px rgba(39,48,31,.07);
  transition:.35s ease;
}
.service-card:nth-child(even){transform:translateY(26px)}
.service-card:hover{
  transform:translateY(-8px) rotate(-1deg);
  background:#fbf7ed;
}
.service-card span{
  color:var(--taupe);
  font-weight:900;
}
.service-card h3{
  font-size:32px;
  line-height:1;
  margin:28px 0 12px;
}
.service-card p{line-height:1.65;color:#4e5448}

.movement-section{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:44px;
  align-items:center;
  padding:90px clamp(18px,5vw,78px);
}
.landscape-panel img{
  width:100%;
  height:680px;
  object-fit:cover;
  object-position:center;
  border-radius:48px;
  filter:saturate(.78) contrast(.98);
  box-shadow:0 22px 65px rgba(39,48,31,.18);
}
.movement-copy{
  padding:40px;
  background:rgba(154,172,136,.16);
  border-radius:42px;
}
.movement-copy p{margin-top:20px}

.support-section{
  padding:40px clamp(18px,5vw,78px) 80px;
}
.support-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.support-card{
  background:var(--moss);
  color:var(--cream);
  border-radius:34px;
  padding:34px;
  min-height:240px;
}
.support-card:nth-child(2){
  background:#69765a;
  transform:translateY(24px);
}
.support-card:nth-child(3){
  background:#373f2b;
}
.support-card h3{
  color:var(--cream);
  font-size:34px;
  line-height:1;
  margin-bottom:18px;
}
.support-card p{color:#f6efde}

.about-section{
  display:grid;
  grid-template-columns:.95fr 1.05fr;
  gap:42px;
  align-items:center;
  padding:90px clamp(18px,5vw,78px);
}
.about-image img{
  height:690px;
  width:100%;
  object-fit:cover;
  object-position:center;
  border-radius:120px 48px 48px 48px;
  filter:saturate(.8) contrast(.95);
  box-shadow:0 22px 60px rgba(39,48,31,.16);
}
.about-paper{min-height:510px}
.text-link{
  display:inline-block;
  margin-top:18px;
  font-weight:900;
  color:var(--moss);
  text-decoration:none;
}

.reviews-section{
  padding:80px clamp(18px,5vw,78px);
}
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.review{
  background:#fbf7ed;
  padding:32px;
  border-radius:34px;
  box-shadow:0 14px 36px rgba(39,48,31,.07);
  font-family:"Cormorant Garamond",serif;
  font-size:29px;
  line-height:1.15;
}
.review cite{
  display:block;
  margin-top:22px;
  font-family:"Nunito Sans",sans-serif;
  font-size:14px;
  color:var(--muted);
  font-style:normal;
}

.book-section{
  padding:70px clamp(18px,5vw,78px) 90px;
}
.book-inner{
  border-radius:50px;
  padding:60px;
  background:
    linear-gradient(rgba(75,87,56,.88),rgba(75,87,56,.88)),
    url("assets/hero-estelle-dogs.jpg") center/cover;
  color:var(--cream);
  text-align:center;
  overflow:hidden;
}
.book-inner h2,.book-inner p,.book-inner .overline{color:var(--cream)}
.book-inner p{max-width:650px;margin:0 auto 28px}

.footer{
  display:grid;
  grid-template-columns:1.4fr .6fr .6fr;
  gap:40px;
  padding:56px clamp(18px,5vw,78px);
  background:var(--deep);
  color:var(--cream);
}
.footer a{
  display:block;
  color:var(--cream);
  text-decoration:none;
  margin:8px 0;
}
.footer-brand{
  display:flex!important;
  align-items:center;
  gap:12px;
  font-family:"Cormorant Garamond",serif;
  font-size:34px;
}
.footer-brand img{width:70px}
.footer p{max-width:430px;line-height:1.7;color:#e9dec9;margin-top:14px}
.footer h3{
  color:var(--cream);
  font-size:26px;
  margin-bottom:10px;
}

.reveal{
  opacity:0;
  transform:translateY(34px);
  transition:opacity .8s ease, transform .8s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

@media(max-width:1120px){
  .main-nav{display:none}
  .menu-toggle{
    display:grid;
    gap:6px;
    width:42px;
    height:42px;
    place-content:center;
    border:0;
    border-radius:999px;
    background:rgba(75,87,56,.12);
  }
  .menu-toggle span{
    display:block;
    width:22px;
    height:2px;
    background:var(--moss);
  }
  .site-header.menu-open .main-nav{
    position:absolute;
    top:76px;
    left:18px;
    right:18px;
    display:grid;
    gap:10px;
    padding:20px;
    border-radius:28px;
    background:#f8f3e7;
    box-shadow:0 20px 60px rgba(39,48,31,.16);
  }
  .site-header.menu-open .dropdown-panel{
    position:static;
    width:auto;
    opacity:1;
    transform:none;
    pointer-events:auto;
    box-shadow:none;
    margin-top:8px;
  }
}

@media(max-width:900px){
  .nav-cta{display:none}
  .brand-text strong{font-size:26px}
  .brand-dog{width:48px}
  .hero,.intro-section,.movement-section,.about-section{
    grid-template-columns:1fr;
  }
  .hero{
    padding-top:38px;
    min-height:auto;
  }
  .hero-media{min-height:auto}
  .hero-img{height:360px;border-radius:34px 34px 70px 34px}
  .hero-note,.location-badge{display:none}
  .note-content{padding:45px 34px}
  .journal-note,.about-paper{min-height:auto}
  .paper-bg{object-fit:cover;border-radius:34px}
  .services-track,.support-grid,.review-grid,.footer{
    grid-template-columns:1fr;
  }
  .service-card:nth-child(even),.support-card:nth-child(2){transform:none}
  .landscape-panel img,.about-image img{height:420px;border-radius:36px}
  .book-inner{padding:44px 24px;border-radius:36px}
}

@media(max-width:520px){
  .site-header{padding:14px 16px}
  .brand-text small{display:none}
  h1{font-size:56px}
  .lead{font-size:17px}
  .button-row{align-items:stretch}
  .btn{width:100%}
  .intro-section,.services-section,.movement-section,.about-section,.reviews-section,.book-section{
    padding-left:16px;
    padding-right:16px;
  }
}


@media(max-width:900px){
  .hero{
    grid-template-columns:1fr;
    gap:30px;
    padding-top:30px;
  }

  .hero-copy{
    padding:26px;
  }

  .hero-copy::before{
    inset:-20px;
  }

  .hero-media{
    min-height:auto;
  }

  .hero-media::before{
    inset:-14px;
  }

  .hero-img{
    height:390px;
    clip-path:polygon(6% 0%, 100% 2%, 96% 94%, 12% 100%, 0% 88%, 2% 10%);
  }
}
