/* ===========================================================
   Bella's Boutique — West Knoxville
   Palette: ink, bone, paper, blush, claret (signature), rose
   Display: Bodoni Moda  ·  Body: Hanken Grotesk
   Shape language: sharp corners, hairline borders, flat fills
   =========================================================== */

:root{
  --ink:#2A2024;
  --ink-soft:#6B5C55;
  --bone:#F4ECE3;
  --paper:#EFE4D9;
  --blush:#ECDAD4;
  --claret:#7A2E3A;
  --claret-deep:#5E222C;
  --rose:#C56E73;
  --bone-dim:#E1D2C6;

  --maxw:1180px;
  --pad:clamp(20px,5vw,64px);

  --serif:"Bodoni Moda",Georgia,serif;
  --sans:"Hanken Grotesk",-apple-system,system-ui,sans-serif;

  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--bone);
  line-height:1.6;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:-.01em}
h2{font-size:clamp(2rem,4.6vw,3.4rem)}
h3{font-size:1.3rem;font-weight:600;letter-spacing:0}
em{font-style:italic}

a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

.skip{position:absolute;left:-999px;top:0;background:var(--claret);color:var(--bone);padding:10px 16px;z-index:200}
.skip:focus{left:8px;top:8px}

/* ---- focus ---- */
:focus-visible{outline:2px solid var(--claret);outline-offset:3px}
.looks :focus-visible,.visit :focus-visible{outline-color:var(--rose)}

/* ---- eyebrow ---- */
.eyebrow{
  font-family:var(--sans);
  font-size:.74rem;font-weight:600;
  letter-spacing:.24em;text-transform:uppercase;
  color:var(--claret);margin-bottom:1.1rem;
}
.eyebrow-light{color:#F0B7BA}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(to bottom,rgba(42,32,36,.34),rgba(42,32,36,0));
  opacity:1;transition:opacity .4s var(--ease);
}
.site-header.scrolled{background:var(--bone);border-bottom-color:rgba(42,32,36,.12)}
.site-header.scrolled::before{opacity:0}

.header-inner{display:flex;align-items:center;justify-content:space-between;height:74px}

.brand{display:flex;align-items:center;gap:11px;color:var(--bone);transition:color .4s var(--ease)}
.scrolled .brand{color:var(--ink)}
.brand-mark{width:34px;height:34px;flex:none}
.brand-name{font-family:var(--serif);font-size:1.32rem;font-weight:500;letter-spacing:.01em}

.navlinks{display:flex;align-items:center;gap:30px}
.navlinks a{
  font-size:.86rem;font-weight:500;letter-spacing:.02em;
  color:var(--bone);position:relative;padding:6px 0;
  transition:color .3s var(--ease);
}
.scrolled .navlinks a{color:var(--ink)}
.navlinks a:not(.callbtn)::after{
  content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;
  background:var(--rose);transition:width .32s var(--ease);
}
.navlinks a:not(.callbtn):hover::after{width:100%}
.scrolled .navlinks a:not(.callbtn):hover{color:var(--claret)}

.navlinks a.callbtn{
  border:1.5px solid var(--bone);color:var(--bone);
  padding:9px 20px;letter-spacing:.04em;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
}
.navlinks a.callbtn:hover{background:var(--bone);color:var(--claret)}
.scrolled .navlinks a.callbtn{border-color:var(--claret);color:var(--claret)}
.scrolled .navlinks a.callbtn:hover{background:var(--claret);color:var(--bone)}

/* hamburger */
.menu-toggle{display:none;background:none;border:0;cursor:pointer;width:40px;height:40px;flex-direction:column;justify-content:center;gap:5px;padding:8px}
.menu-toggle span{display:block;height:2px;background:var(--bone);transition:background .3s,transform .3s var(--ease),opacity .2s}
.scrolled .menu-toggle span{background:var(--ink)}
.menu-toggle[aria-expanded="true"] span{background:var(--ink)}
.menu-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.menu-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav panel */
.mobile-nav{
  position:fixed;inset:74px 0 auto 0;z-index:99;
  background:var(--bone);border-bottom:1px solid rgba(42,32,36,.12);
  transform:translateY(-120%);transition:transform .42s var(--ease);
  visibility:hidden;
}
.mobile-nav.open{transform:translateY(0);visibility:visible}
.mobile-nav nav{display:flex;flex-direction:column;padding:14px var(--pad) 26px}
.mobile-nav a{padding:15px 0;font-size:1.05rem;font-weight:500;border-bottom:1px solid rgba(42,32,36,.1)}
.mobile-nav a.callbtn{margin-top:16px;border:1.5px solid var(--claret);color:var(--claret);text-align:center;padding:14px;font-weight:600}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  display:inline-block;font-family:var(--sans);font-size:.9rem;font-weight:600;
  letter-spacing:.04em;padding:14px 28px;cursor:pointer;
  transition:background .3s var(--ease),color .3s var(--ease),border-color .3s var(--ease);
  border:1.5px solid transparent;
}
.btn-fill{background:var(--claret);color:var(--bone)}
.btn-fill:hover{background:var(--claret-deep)}
.btn-line{border-color:var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:var(--bone)}
.btn-line-light{border-color:var(--bone);color:var(--bone)}
.btn-line-light:hover{background:var(--bone);color:var(--claret)}
.btn-block{width:100%;text-align:center}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;justify-content:center;
  background:
    radial-gradient(120% 90% at 80% 0%,#8E3744 0%,var(--claret) 42%,var(--claret-deep) 100%);
  color:var(--bone);
  padding-top:120px;padding-bottom:120px;overflow:hidden;
}
.hero-bg{position:absolute;inset:0;display:flex;align-items:center;justify-content:flex-end;pointer-events:none}
.ribbon{width:min(58vw,620px);color:rgba(244,236,227,.16);transform:translateX(12%)}
.ribbon-draw{stroke-dasharray:1600;stroke-dashoffset:1600}
.js-ready .ribbon-draw{transition:stroke-dashoffset 2.4s var(--ease) .3s}
.js-ready .hero.drawn .ribbon-draw{stroke-dashoffset:0}

.hero-inner{position:relative;z-index:2}
.hero-title{
  font-size:clamp(2.6rem,7vw,5.4rem);font-weight:400;line-height:1.02;
  margin:.3rem 0 1.6rem;max-width:14ch;
}
.hero-title em{color:var(--blush);font-weight:400}
.hero-sub{max-width:46ch;font-size:1.06rem;color:var(--bone-dim);margin-bottom:2.2rem}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn-line{border-color:rgba(244,236,227,.6);color:var(--bone)}
.hero .btn-line:hover{background:var(--bone);color:var(--claret);border-color:var(--bone)}

.hero-meta{
  position:relative;z-index:2;display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  margin-top:auto;padding-top:48px;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--bone-dim);
  max-width:var(--maxw);margin-left:auto;margin-right:auto;width:100%;
  padding-left:var(--pad);padding-right:var(--pad);
}
.hero-meta .dot{width:4px;height:4px;background:var(--rose);display:inline-block}

/* =========================================================
   MARQUEE STRIP
   ========================================================= */
.strip{background:var(--ink);color:var(--bone);overflow:hidden;border-top:1px solid var(--claret-deep)}
.strip-track{display:flex;align-items:center;gap:26px;white-space:nowrap;padding:16px 0;width:max-content;animation:marquee 34s linear infinite}
.strip-track span{font-family:var(--serif);font-size:1.15rem;font-style:italic;letter-spacing:.02em}
.strip-track .sep{color:var(--rose);font-style:normal;font-size:.8rem}
@keyframes marquee{to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.strip-track{animation:none;flex-wrap:wrap;white-space:normal;width:auto;justify-content:center}}

/* =========================================================
   WHAT WE CARRY
   ========================================================= */
.carry{padding:clamp(72px,11vw,140px) 0;background:var(--bone)}
.sec-head{max-width:620px;margin-bottom:clamp(40px,6vw,72px)}
.sec-head h2{margin-bottom:1.1rem}
.sec-lead{color:var(--ink-soft);font-size:1.05rem;max-width:48ch}

.carry-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(42,32,36,.14);border:1px solid rgba(42,32,36,.14)}
.carry-card{
  background:var(--bone);padding:38px 32px 42px;position:relative;
  transition:background .35s var(--ease);
}
.carry-card::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--claret);
  transition:width .4s var(--ease);
}
.carry-card:hover{background:var(--paper)}
.carry-card:hover::before{width:100%}
.carry-card .num{font-family:var(--serif);font-size:.95rem;color:var(--claret);letter-spacing:.1em;display:block;margin-bottom:1.4rem}
.carry-card h3{margin-bottom:.6rem;transition:color .3s var(--ease)}
.carry-card:hover h3{color:var(--claret)}
.carry-card p{color:var(--ink-soft);font-size:.97rem}

/* =========================================================
   LOOKS (dark band)
   ========================================================= */
.looks{padding:clamp(72px,11vw,140px) 0;background:var(--ink);color:var(--bone)}
.looks .sec-head h2{color:var(--bone)}
.sec-lead-light{color:var(--bone-dim)}
.looks-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,36px)}
.look{display:flex;flex-direction:column}
.look-art{
  aspect-ratio:4/5;background:var(--claret);
  display:flex;align-items:center;justify-content:center;
  border:1px solid var(--claret-deep);overflow:hidden;
}
.look-art svg{width:62%;height:auto;color:var(--bone);transition:transform 1.2s var(--ease),color .4s var(--ease)}
.look:hover .look-art svg{transform:scale(1.05);color:var(--blush)}
.look figcaption{padding:22px 4px 0}
.look h3{color:var(--bone);margin-bottom:.4rem}
.look p{color:var(--bone-dim);font-size:.95rem}
.looks-note{margin-top:clamp(34px,5vw,56px);color:var(--bone-dim);font-style:italic;font-family:var(--serif);font-size:1.05rem;text-align:center}

/* =========================================================
   ABOUT
   ========================================================= */
.about{padding:clamp(72px,11vw,140px) 0;background:var(--paper)}
.about-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,84px);align-items:center}
.about-art{background:var(--bone);border:1px solid rgba(42,32,36,.14);padding:30px;color:var(--claret)}
.about-art svg{width:100%;height:auto;max-height:420px;margin:0 auto}
.about-copy h2{margin-bottom:1.3rem}
.about-copy p{color:var(--ink-soft);margin-bottom:1.1rem;max-width:52ch}
.about-points{margin-top:2rem;display:flex;flex-direction:column;gap:14px}
.about-points .pt{display:flex;align-items:center;gap:14px;font-weight:500;color:var(--ink);font-size:.98rem}
.pt-mark{width:14px;height:2px;background:var(--claret);flex:none;transition:width .3s var(--ease)}
.about-points .pt:hover .pt-mark{width:28px}

/* =========================================================
   FAQ
   ========================================================= */
.faq{padding:clamp(72px,11vw,140px) 0;background:var(--bone)}
.faq-list{border-top:1px solid rgba(42,32,36,.16)}
.faq-item{border-bottom:1px solid rgba(42,32,36,.16)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:26px 44px 26px 0;position:relative;
  font-family:var(--serif);font-size:clamp(1.15rem,2.2vw,1.5rem);font-weight:500;
  transition:color .3s var(--ease);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"";position:absolute;right:6px;top:50%;width:13px;height:13px;
  border-right:2px solid var(--claret);border-bottom:2px solid var(--claret);
  transform:translateY(-70%) rotate(45deg);transition:transform .3s var(--ease);
}
.faq-item[open] summary::after{transform:translateY(-30%) rotate(-135deg)}
.faq-item summary:hover{color:var(--claret)}
.faq-body{padding:0 44px 28px 0;color:var(--ink-soft);max-width:62ch}
.faq-body p{font-size:1rem}

/* =========================================================
   VISIT / CONTACT (claret band)
   ========================================================= */
.visit{padding:clamp(72px,11vw,140px) 0;background:var(--claret);color:var(--bone)}
.visit-inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,88px);align-items:start}
.visit-copy h2{color:var(--bone);margin-bottom:1.3rem}
.visit-copy p{color:var(--bone-dim);max-width:42ch;margin-bottom:2rem}
.visit-call{display:inline-flex;flex-direction:column;gap:2px;border-top:1px solid rgba(244,236,227,.3);padding-top:18px}
.visit-call-label{font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:#F0B7BA}
.visit-call-num{font-family:var(--serif);font-size:1.9rem;transition:color .3s var(--ease)}
.visit-call:hover .visit-call-num{color:var(--blush)}

/* form */
.form{background:var(--bone);color:var(--ink);padding:clamp(26px,4vw,40px)}
.field{margin-bottom:18px;display:flex;flex-direction:column}
.field label{font-size:.76rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:7px}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:1rem;color:var(--ink);
  background:var(--bone);border:1.5px solid rgba(42,32,36,.28);
  padding:12px 14px;transition:border-color .25s var(--ease);
  border-radius:0;
}
.field textarea{resize:vertical;min-height:104px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--claret)}
.field.invalid input,.field.invalid textarea{border-color:#B23B3B}
.err{color:#B23B3B;font-size:.8rem;margin-top:6px;min-height:1em}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-success{margin-top:16px;color:var(--claret);font-family:var(--serif);font-size:1.1rem;font-style:italic}

/* =========================================================
   HOURS + LOCATION
   ========================================================= */
.hours{padding:clamp(72px,11vw,140px) 0;background:var(--bone)}
.hours-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(36px,6vw,80px);align-items:center}
.hours-block h2{margin-bottom:1.6rem}
.hours-list{list-style:none;border-top:1px solid rgba(42,32,36,.16)}
.hours-list li{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 8px;border-bottom:1px solid rgba(42,32,36,.16);
  transition:background .25s var(--ease),padding-left .25s var(--ease);
}
.hours-list li:hover{background:var(--paper);padding-left:16px}
.hours-list li span:first-child{font-weight:600}
.hours-list li span:last-child{color:var(--ink-soft);font-variant-numeric:tabular-nums}

.loc-panel{background:var(--ink);color:var(--bone);overflow:hidden}
.loc-texture{position:relative;height:clamp(190px,28vw,260px);background:var(--claret-deep);color:var(--bone);display:flex;align-items:center;justify-content:center}
.loc-texture>svg:first-child{position:absolute;inset:0;width:100%;height:100%}
.loc-pin{width:44px;height:auto;position:relative;z-index:2;color:var(--rose);filter:drop-shadow(0 6px 10px rgba(0,0,0,.3))}
.loc-info{padding:30px clamp(24px,4vw,38px) 34px}
.loc-addr{font-family:var(--serif);font-size:1.5rem;line-height:1.25;margin-bottom:.5rem}
.loc-note{color:var(--bone-dim);font-size:.92rem;margin-bottom:1.6rem}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--ink);color:var(--bone-dim);padding:clamp(56px,8vw,88px) 0 30px}
.footer-inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:36px;padding-bottom:46px;border-bottom:1px solid rgba(244,236,227,.14)}
.footer-brand{max-width:30ch}
.footer-mark{width:40px;height:40px;color:var(--rose);margin-bottom:14px}
.footer-name{font-family:var(--serif);font-size:1.5rem;color:var(--bone);display:block;margin-bottom:.5rem}
.footer-tag{font-size:.95rem}
.footer-col h4{font-family:var(--sans);font-size:.74rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--bone);margin-bottom:1rem}
.footer-col p{font-size:.95rem;margin-bottom:.7rem}
.footer-col a{display:block;font-size:.95rem;margin-bottom:.5rem;position:relative;width:max-content;transition:color .25s var(--ease)}
.footer-col a::after{content:"";position:absolute;left:0;bottom:-1px;height:1px;width:0;background:var(--rose);transition:width .3s var(--ease)}
.footer-col a:hover{color:var(--bone)}
.footer-col a:hover::after{width:100%}
.footer-base{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;padding-top:24px;font-size:.85rem}
.credit{color:#A8978C}

/* =========================================================
   REVEAL ANIMATIONS (js-ready gated)
   ========================================================= */
.js-ready .reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js-ready .reveal.in{opacity:1;transform:none}
.js-ready [data-hero]{opacity:0;transform:translateY(26px)}
.js-ready .hero.drawn [data-hero]{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
.js-ready .hero.drawn .eyebrow[data-hero]{transition-delay:.05s}
.js-ready .hero.drawn .hero-title[data-hero]{transition-delay:.18s}
.js-ready .hero.drawn .hero-sub[data-hero]{transition-delay:.32s}
.js-ready .hero.drawn .hero-cta[data-hero]{transition-delay:.46s}
.js-ready .hero.drawn .hero-meta[data-hero]{transition-delay:.6s}

@media (prefers-reduced-motion:reduce){
  .js-ready .reveal,.js-ready [data-hero]{opacity:1!important;transform:none!important;transition:none!important}
  .js-ready .ribbon-draw{transition:none!important;stroke-dashoffset:0!important}
  .look:hover .look-art svg,.hours-list li:hover{transition:none}
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:900px){
  .carry-grid{grid-template-columns:repeat(2,1fr)}
  .looks-grid{grid-template-columns:1fr;max-width:440px;margin:0 auto;gap:40px}
  .about-inner{grid-template-columns:1fr;gap:40px}
  .about-art{order:2;max-width:360px}
  .visit-inner{grid-template-columns:1fr;gap:36px}
  .hours-inner{grid-template-columns:1fr;gap:40px}
  .footer-inner{grid-template-columns:1fr 1fr;gap:30px 24px}
  .footer-brand{grid-column:1 / -1}
}

@media (max-width:760px){
  .navlinks{display:none}
  .menu-toggle{display:flex}
}

@media (max-width:560px){
  body{font-size:16px}
  .header-inner{height:64px}
  .mobile-nav{inset:64px 0 auto 0}
  .hero{min-height:92svh;padding-top:104px}
  .hero-title{margin-bottom:1.3rem}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{text-align:center}
  .hero-meta{font-size:.68rem;gap:10px}
  .carry-grid{grid-template-columns:1fr}
  .carry-card{padding:30px 26px 34px}
  .footer-inner{grid-template-columns:1fr}
  .footer-base{flex-direction:column;align-items:flex-start}
  .faq-item summary{font-size:1.12rem}
}
