:root{
  --ink:#161616; --ink-soft:#4a4a4a; --muted:#8f8f8f; --line:#e6e6e6;
  --paper:#ffffff; --paper-2:#faf9f7; --blush:#fff4f2;
  --red:#d1000a; --red-2:#ea492e;
  --maxw:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:'Manrope',system-ui,sans-serif;color:var(--ink);
  background:var(--paper);line-height:1.6;font-size:17px;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Gloock',Georgia,serif;font-weight:400;line-height:1.12;letter-spacing:-.01em;margin:0}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.16em;color:var(--red);margin:0 0 14px}
.lead{font-size:19px;color:var(--ink-soft);max-width:60ch}
.muted{color:var(--muted)}
/* swatch motif */
.swatch{display:flex;height:6px;width:120px;border-radius:3px;overflow:hidden}
.swatch span{flex:1}
/* notice bar */
.notice{background:var(--ink);color:#fff;font-size:13px;letter-spacing:.02em;text-align:center;padding:9px 16px}
.notice b{color:#ffb3b3;font-weight:700}
/* nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:70px}
.brand{font-family:'Gloock',serif;font-size:22px;letter-spacing:.02em}
.brand b{color:var(--red);font-weight:400}
.nav ul{display:flex;gap:26px;list-style:none;margin:0;padding:0;font-size:14.5px}
.nav ul a{color:var(--ink-soft)}
.nav ul a:hover{color:var(--red)}
.btn{display:inline-block;background:var(--red);color:#fff;padding:12px 22px;border-radius:999px;
  font-weight:700;font-size:14.5px;letter-spacing:.02em;transition:.18s;border:1.5px solid var(--red)}
.btn:hover{background:#a80009;border-color:#a80009}
.btn.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:#fff}
.navtoggle{display:none;background:none;border:0;font-size:26px;cursor:pointer}
/* hero */
.hero{padding:84px 0 72px;border-bottom:1px solid var(--line)}
.hero .eyebrow{margin-bottom:20px}
.hero h1{font-size:clamp(40px,6vw,66px);max-width:15ch}
.hero p.lead{margin:24px 0 32px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero .appt{font-size:13.5px;color:var(--muted);margin-top:18px}
/* sections */
section{padding:66px 0}
.section-head{max-width:64ch;margin-bottom:38px}
.section-head h2{font-size:clamp(28px,3.6vw,40px)}
.alt{background:var(--paper-2)}
.blush{background:var(--blush)}
/* cards grid */
.grid{display:grid;gap:22px}
.grid.c3{grid-template-columns:repeat(3,1fr)}
.grid.c2{grid-template-columns:repeat(2,1fr)}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px;transition:.18s}
.card:hover{border-color:var(--ink);transform:translateY(-2px)}
.card .dur{font-size:12.5px;text-transform:uppercase;letter-spacing:.12em;color:var(--red);font-weight:700}
.card h3{font-size:22px;margin:10px 0 10px}
.card p{color:var(--ink-soft);font-size:15.5px;margin:0 0 16px}
.card a.more{font-weight:700;font-size:14px;color:var(--ink);border-bottom:2px solid var(--red);padding-bottom:2px}
/* steps */
.steps{counter-reset:s;display:grid;gap:24px;grid-template-columns:repeat(4,1fr)}
.step{position:relative;padding-top:14px;border-top:2px solid var(--ink)}
.step::before{counter-increment:s;content:"0" counter(s);font-family:'Gloock',serif;font-size:15px;color:var(--red)}
.step h3{font-size:18px;margin:8px 0 6px}
.step p{font-size:14.5px;color:var(--ink-soft);margin:0}
/* pricing */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tier{border:1px solid var(--line);border-radius:16px;padding:30px;background:#fff;display:flex;flex-direction:column}
.tier.feat{border:2px solid var(--red);box-shadow:0 12px 40px rgba(209,0,10,.08)}
.tier .badge{align-self:flex-start;background:var(--red);color:#fff;font-size:11px;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border-radius:999px;margin-bottom:14px}
.tier h3{font-size:21px}
.tier .price{font-family:'Gloock',serif;font-size:34px;margin:12px 0 4px}
.tier .dur{color:var(--muted);font-size:13.5px;text-transform:uppercase;letter-spacing:.1em}
.tier p{color:var(--ink-soft);font-size:15px;margin:16px 0 22px;flex:1}
/* prose */
.prose{max-width:70ch}
.prose h2{font-size:30px;margin:44px 0 16px}
.prose h3{font-size:21px;margin:30px 0 10px}
.prose p{margin:0 0 18px;color:var(--ink-soft)}
.prose ul{margin:0 0 18px;padding-left:20px;color:var(--ink-soft)}
.prose li{margin:6px 0}
.answer{background:var(--blush);border-left:3px solid var(--red);padding:18px 22px;border-radius:0 10px 10px 0;
  font-size:18px;color:var(--ink);margin:0 0 30px}
/* faq */
.faq{max-width:80ch}
.faq details{border-bottom:1px solid var(--line);padding:18px 0}
.faq summary{font-family:'Gloock',serif;font-size:19px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--red);font-family:'Manrope';font-weight:700}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--ink-soft);margin:14px 0 4px}
/* reviews */
.rev{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px}
.rev .stars{color:var(--red);letter-spacing:2px;font-size:14px}
.rev p{font-size:15.5px;color:var(--ink-soft);margin:12px 0}
.rev .who{font-weight:700;font-size:14px}
/* studio / contact */
.studio{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:center}
.studio .info p{margin:6px 0;color:var(--ink-soft)}
.studio .info b{color:var(--ink)}
.mapbox{border:1px solid var(--line);border-radius:16px;overflow:hidden;min-height:320px;background:var(--paper-2)}
.mapbox iframe{width:100%;height:100%;min-height:320px;border:0}
/* breadcrumb */
.crumb{font-size:13px;color:var(--muted);padding:18px 0 0}
.crumb a:hover{color:var(--red)}
/* cta band */
.band{background:var(--ink);color:#fff;text-align:center;padding:72px 24px}
.band h2{color:#fff;font-size:clamp(28px,4vw,42px);margin-bottom:12px}
.band p{color:#c9c9c9;max-width:52ch;margin:0 auto 26px}
/* footer */
footer{background:#0e0e0e;color:#cfcfcf;padding:60px 0 34px;font-size:14.5px}
footer .ftop{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:34px;padding-bottom:34px;border-bottom:1px solid #262626}
footer .fbrand{font-family:'Gloock',serif;font-size:26px;color:#fff}
footer h4{font-size:12px;text-transform:uppercase;letter-spacing:.14em;color:#888;margin:0 0 14px;font-family:'Manrope';font-weight:700}
footer a{color:#cfcfcf}footer a:hover{color:#fff}
footer ul{list-style:none;padding:0;margin:0}footer li{margin:8px 0}
footer .fbot{padding-top:24px;color:#7a7a7a;font-size:12.5px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.tag{font-family:'Gloock',serif;color:var(--red);font-size:18px}
/* responsive */
@media(max-width:860px){
  .nav ul,.nav .btn{display:none}
  .navtoggle{display:block}
  .nav.open ul{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;
    background:#fff;border-bottom:1px solid var(--line);padding:18px 24px;gap:16px}
  .nav.open .btn{display:inline-block;margin:0 24px 18px}
  .grid.c3,.grid.c2,.tiers,.steps{grid-template-columns:1fr}
  .studio{grid-template-columns:1fr}
  footer .ftop{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:3px solid var(--red);outline-offset:2px}

/* image slot (replace with COLOR AVENUE photos before launch) */
.imgslot{position:relative;background:linear-gradient(135deg,#faf4f2,#f3eae6);
  border:1.5px dashed #d9b5ae;border-radius:16px;min-height:280px;display:flex;
  align-items:center;justify-content:center;text-align:center;overflow:hidden}
.imgslot span{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:#b06a5c;font-weight:700;padding:0 18px}
.imgslot.tall{min-height:420px}
.hero.split{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero.split .imgslot{min-height:400px}
@media(max-width:860px){.hero.split{grid-template-columns:1fr}}
