/* The Little Shop of Howls — boutique dog grooming, Bartlett TN
   Aesthetic: warm editorial boutique. Cream paper, plum (from their bandana),
   honey accent. Fraunces display + Hanken Grotesk body. */

:root{
  --paper:#FBF5EA;
  --paper-2:#F4EADA;
  --ink:#2A2018;
  --ink-soft:#5A4D40;
  --plum:#5C3D63;
  --plum-deep:#412A47;
  --honey:#D98C4A;
  --honey-soft:#E9B377;
  --rose:#E7C7C0;
  --line:#E2D4BE;
  --cream-card:#FFFDF8;
  --shadow:0 18px 50px -22px rgba(65,42,71,.45);
  --shadow-sm:0 8px 24px -14px rgba(65,42,71,.40);
  --radius:22px;
  --maxw:1180px;
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Hanken Grotesk",-apple-system,BlinkMacSystemFont,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  background:var(--paper);
  color:var(--ink);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
/* subtle paper grain + warm radial glow */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1100px 700px at 85% -8%, rgba(217,140,74,.14), transparent 60%),
    radial-gradient(900px 700px at -10% 30%, rgba(92,61,99,.10), transparent 55%);
  pointer-events:none;
}
body::after{
  content:"";position:fixed;inset:0;z-index:-1;opacity:.04;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55em;
  font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:999px;border:2px solid transparent;
  cursor:pointer;transition:transform .25s cubic-bezier(.2,.8,.3,1),box-shadow .25s,background .25s;
  line-height:1;
}
.btn-primary{background:var(--plum);color:#fdf4ea;box-shadow:var(--shadow-sm)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 34px -16px rgba(92,61,99,.7);background:var(--plum-deep)}
.btn-ghost{background:transparent;border-color:var(--plum);color:var(--plum)}
.btn-ghost:hover{background:var(--plum);color:#fdf4ea;transform:translateY(-3px)}
.btn-honey{background:var(--honey);color:#3a2410;box-shadow:var(--shadow-sm)}
.btn-honey:hover{transform:translateY(-3px);background:var(--honey-soft)}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:rgba(251,245,234,.82);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--font-display);
  font-weight:600;font-size:1.28rem;color:var(--plum);letter-spacing:-.01em}
.brand .moon{width:30px;height:30px;flex:none}
.nav-links{display:flex;align-items:center;gap:2rem}
.nav-links a{font-weight:600;font-size:.96rem;color:var(--ink-soft);transition:color .2s}
.nav-links a:hover{color:var(--plum)}
.nav-cta{display:inline-flex}
.nav-toggle{display:none;background:none;border:0;cursor:pointer}

/* ---------- hero ---------- */
.hero{padding:64px 0 30px;position:relative}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:.5em;font-weight:700;text-transform:uppercase;
  letter-spacing:.16em;font-size:.74rem;color:var(--honey);margin-bottom:1.1rem}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--honey);display:inline-block}
.hero h1{font-family:var(--font-display);font-weight:600;font-size:clamp(2.5rem,5.4vw,4.2rem);
  line-height:1.02;letter-spacing:-.02em;color:var(--ink)}
.hero h1 em{font-style:italic;color:var(--plum)}
.hero p.lead{font-size:1.18rem;color:var(--ink-soft);max-width:30rem;margin:1.4rem 0 2rem}
.hero-cta{display:flex;gap:.9rem;flex-wrap:wrap}
.hero-meta{display:flex;align-items:center;gap:1.4rem;margin-top:2.1rem;flex-wrap:wrap}
.stars{color:var(--honey);font-size:1.1rem;letter-spacing:.06em}
.hero-meta .rev{font-size:.92rem;color:var(--ink-soft)}
.hero-meta .rev b{color:var(--ink)}

/* hero photo frame */
.hero-photo{position:relative;justify-self:center}
.hero-photo .frame{
  width:min(420px,90%);aspect-ratio:4/5;border-radius:230px 230px 26px 26px;overflow:hidden;
  border:10px solid var(--cream-card);box-shadow:var(--shadow);transform:rotate(2.2deg);
}
.hero-photo .frame img{width:100%;height:100%;object-fit:cover}
.hero-photo .badge{
  position:absolute;left:-22px;bottom:34px;background:var(--cream-card);border:1px solid var(--line);
  border-radius:18px;padding:.8rem 1rem;box-shadow:var(--shadow-sm);transform:rotate(-3deg);
  display:flex;align-items:center;gap:.6rem;max-width:220px}
.hero-photo .badge .big{font-family:var(--font-display);font-size:1.7rem;color:var(--plum);line-height:1}
.hero-photo .badge small{font-size:.74rem;color:var(--ink-soft);display:block;line-height:1.25}
.hero-photo .dot{position:absolute;top:-14px;right:8px;font-size:.72rem;font-weight:700;
  background:var(--plum);color:#fdf4ea;padding:.5em .9em;border-radius:999px;transform:rotate(6deg)}

/* ---------- trust strip ---------- */
.trust{margin-top:34px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:linear-gradient(var(--paper-2),var(--paper-2))}
.trust-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.trust-cell{background:var(--paper-2);padding:1.3rem 1rem;text-align:center}
.trust-cell .n{font-family:var(--font-display);font-size:1.7rem;color:var(--plum);line-height:1}
.trust-cell .l{font-size:.82rem;color:var(--ink-soft);margin-top:.3rem;letter-spacing:.02em}

/* ---------- sections ---------- */
section{padding:84px 0}
.sec-head{max-width:42rem;margin-bottom:3rem}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:var(--font-display);font-weight:600;font-size:clamp(2rem,3.8vw,3rem);
  line-height:1.05;letter-spacing:-.02em}
.sec-head h2 em{font-style:italic;color:var(--plum)}
.sec-head p{color:var(--ink-soft);font-size:1.1rem;margin-top:1rem}

/* about */
.about-grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:54px;align-items:center}
.about-photos{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.about-photos img{border-radius:18px;box-shadow:var(--shadow-sm);width:100%;height:100%;object-fit:cover}
.about-photos img:first-child{grid-row:span 2;height:100%}
.about-body p{margin-bottom:1.1rem;color:var(--ink-soft);font-size:1.06rem}
.about-body p strong{color:var(--ink)}
.sign{font-family:var(--font-display);font-style:italic;font-size:1.4rem;color:var(--plum);margin-top:.4rem}

/* services */
.services{background:var(--plum-deep);color:#f3e8da;position:relative}
.services .sec-head h2{color:#fdf6ec}
.services .sec-head h2 em{color:var(--honey-soft)}
.services .sec-head p{color:#d8c4cf}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:rgba(255,253,248,.06);border:1px solid rgba(233,179,119,.22);border-radius:var(--radius);
  padding:1.7rem 1.6rem;transition:transform .3s,background .3s,border-color .3s}
.svc-card:hover{transform:translateY(-6px);background:rgba(255,253,248,.10);border-color:var(--honey)}
.svc-card .ic{font-size:1.7rem;margin-bottom:.9rem;display:block}
.svc-card h3{font-family:var(--font-display);font-weight:600;font-size:1.32rem;color:#fdf6ec;margin-bottom:.5rem}
.svc-card p{font-size:.98rem;color:#d9c8d0}

/* why / differentiators */
.why-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.why-card{display:flex;gap:1.1rem;background:var(--cream-card);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.6rem;box-shadow:var(--shadow-sm)}
.why-card .ic{flex:none;width:48px;height:48px;border-radius:14px;background:var(--rose);
  display:grid;place-items:center;font-size:1.4rem}
.why-card h3{font-family:var(--font-display);font-weight:600;font-size:1.24rem;margin-bottom:.35rem}
.why-card p{color:var(--ink-soft);font-size:.99rem}

/* gallery */
.gallery{background:var(--paper-2)}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px}
.gal-grid figure{overflow:hidden;border-radius:18px;box-shadow:var(--shadow-sm);position:relative}
.gal-grid figure img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.8,.3,1)}
.gal-grid figure:hover img{transform:scale(1.07)}
.gal-grid .tall{grid-row:span 2}
.gal-grid .wide{grid-column:span 2}

/* testimonials */
.tst-grid{columns:3;column-gap:20px}
.tst{break-inside:avoid;margin-bottom:20px;background:var(--cream-card);border:1px solid var(--line);
  border-radius:var(--radius);padding:1.5rem 1.5rem 1.3rem;box-shadow:var(--shadow-sm)}
.tst .q{font-size:1.02rem;color:var(--ink);line-height:1.55}
.tst .stars{font-size:.95rem;margin-bottom:.7rem}
.tst .who{margin-top:1rem;font-weight:700;font-size:.92rem;color:var(--plum)}
.tst .who span{display:block;font-weight:500;color:var(--ink-soft);font-size:.8rem}

/* location / booking */
.book{background:linear-gradient(135deg,var(--plum),var(--plum-deep));color:#f5ecdf;border-radius:32px;
  padding:clamp(2.4rem,5vw,4rem);display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;
  box-shadow:var(--shadow)}
.book h2{font-family:var(--font-display);font-weight:600;font-size:clamp(1.9rem,3.6vw,2.8rem);line-height:1.05;color:#fdf6ec}
.book h2 em{font-style:italic;color:var(--honey-soft)}
.book p{color:#e3d3da;margin:1rem 0 1.7rem;font-size:1.08rem}
.book .cta-row{display:flex;gap:.8rem;flex-wrap:wrap}
.info-card{background:rgba(255,253,248,.08);border:1px solid rgba(233,179,119,.25);border-radius:20px;padding:1.6rem}
.info-row{display:flex;gap:.8rem;padding:.7rem 0;border-bottom:1px solid rgba(233,179,119,.18);font-size:.98rem}
.info-row:last-child{border-bottom:0}
.info-row .k{color:var(--honey-soft);font-weight:700;min-width:84px;flex:none}
.info-row .v{color:#f0e4d8}
.info-row .v b{color:#fff}

/* footer */
footer{background:var(--ink);color:#e7dccd;padding:60px 0 30px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:36px;border-bottom:1px solid rgba(231,220,205,.16)}
.foot-grid .brand{color:#fdf6ec;margin-bottom:1rem}
.foot-grid p{color:#bcae9c;font-size:.95rem;max-width:24rem}
.foot-col h4{font-family:var(--font-display);font-size:1.05rem;color:#fdf6ec;margin-bottom:.9rem}
.foot-col a{display:block;color:#bcae9c;font-size:.94rem;padding:.28rem 0;transition:color .2s}
.foot-col a:hover{color:var(--honey-soft)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  padding-top:22px;font-size:.84rem;color:#9c8f7e}

/* demo ribbon (pitch) */
.demo-pill{position:fixed;right:18px;bottom:18px;z-index:80;background:var(--honey);color:#3a2410;
  border-radius:999px;padding:.7rem 1.1rem;font-weight:700;font-size:.9rem;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:.5rem;transition:transform .25s}
.demo-pill:hover{transform:translateY(-3px)}
.demo-note{background:var(--honey-soft);color:#3a2410;text-align:center;font-size:.86rem;font-weight:600;padding:.55rem 1rem}
.demo-note a{text-decoration:underline}

/* faq accordion */
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{background:var(--cream-card);border:1px solid var(--line);border-radius:18px;
  padding:0 1.5rem;box-shadow:var(--shadow-sm);overflow:hidden}
.faq-item summary{list-style:none;cursor:pointer;padding:1.25rem 0;font-family:var(--font-display);
  font-weight:600;font-size:1.14rem;color:var(--ink);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.6rem;color:var(--honey);font-weight:400;transition:transform .3s;flex:none}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-a{padding:0 0 1.3rem}
.faq-item .faq-a p{color:var(--ink-soft);font-size:1.02rem}
.faq-item .faq-a a{color:var(--plum);font-weight:600;text-decoration:underline}

/* reveal animation — progressive enhancement: only hidden when JS adds .js to <html> */
html.js .reveal{opacity:0;transform:translateY(26px);transition:opacity .8s ease,transform .8s cubic-bezier(.2,.8,.3,1)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  html.js .reveal{opacity:1 !important;transform:none !important;transition:none}
}

/* ---------- responsive ---------- */
@media(max-width:920px){
  .hero-grid{grid-template-columns:1fr;gap:36px}
  .hero-photo{order:-1}
  .about-grid{grid-template-columns:1fr;gap:32px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .tst-grid{columns:2}
  .book{grid-template-columns:1fr;gap:28px}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  /* absolute (not fixed) so the header's backdrop-filter containing block doesn't break it;
     collapse via max-height so it's reliably hidden until toggled */
  .nav-links{position:absolute;top:74px;left:0;right:0;flex-direction:column;background:var(--paper);
    gap:0;border-bottom:1px solid var(--line);align-items:flex-start;
    max-height:0;overflow:hidden;padding:0 26px;
    transition:max-height .35s ease,padding .35s ease}
  .nav-links.open{max-height:420px;padding:.8rem 26px 1.3rem;gap:.4rem}
  .nav-links a{padding:.55rem 0;width:100%}
  .nav-links .nav-cta{width:auto;margin-top:.5rem;padding:.8em 1.4em}
  .nav-toggle{display:block}
  .trust-inner{grid-template-columns:1fr 1fr}
  .svc-grid,.why-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .tst-grid{columns:1}
  .foot-grid{grid-template-columns:1fr}
}
