/* components.css — cards, chat (AI), calendar/panel/dashboard, feats, about, reviews, cta band, contact, burger menu */

/* services */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.card{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:26px;transition:.3s;position:relative;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card .ic{width:52px;height:52px;border-radius:15px;background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:15px}
.card h3{font-size:23px;margin-bottom:5px}
.card .dur{font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--moss);margin-bottom:9px}
.card p{font-size:14px;color:var(--muted)}
.card .p{font-family:var(--serif);font-size:25px;font-weight:600;margin-top:13px}
/* price tiers (duration → price) */
.svc-tiers{margin-top:auto;padding-top:14px;display:flex;flex-direction:column;gap:0}
.svc-tier{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-top:1px solid var(--line)}
.svc-tier:first-child{border-top:none}
.svc-tier .td{font-size:13px;color:var(--muted)}
.svc-tier .tp{font-family:var(--serif);font-size:20px;font-weight:600;color:var(--ink)}

/* AI booking */
.ai-row{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.ai-copy h2{font-size:clamp(28px,4.2vw,44px);margin:12px 0 14px}
.ai-copy p{color:var(--muted);font-size:16px;margin-bottom:16px}
.ai-list{list-style:none;display:flex;flex-direction:column;gap:12px}
.ai-list li{display:flex;gap:12px;font-size:15px;font-weight:500}
.ai-list .ck{width:26px;height:26px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.chat{background:var(--white);border:1px solid var(--line);border-radius:26px;box-shadow:var(--shadow);padding:20px;max-width:430px;margin:0 auto;width:100%}
.chat-head{display:flex;align-items:center;gap:11px;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.chat-head .av{width:42px;height:42px;border-radius:50%;background:var(--grad);display:flex;align-items:center;justify-content:center;font-size:20px}
.chat-head .nm{font-weight:800;font-size:14.5px}
.chat-head .st{font-size:11.5px;color:var(--sage);font-weight:600;display:flex;align-items:center;gap:5px}
.chat-head .st .dot{width:7px;height:7px;border-radius:50%;background:var(--sage);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.chat-body{display:flex;flex-direction:column;gap:10px;min-height:280px}
.msg{max-width:82%;padding:11px 15px;border-radius:18px;font-size:14px;line-height:1.45;opacity:0;transform:translateY(10px);animation:msgin .4s forwards}
@keyframes msgin{to{opacity:1;transform:none}}
.msg.bot{background:var(--cream);border-bottom-left-radius:5px;align-self:flex-start}
.msg.user{background:var(--grad);color:#fff;border-bottom-right-radius:5px;align-self:flex-end}
.typing{display:flex;gap:4px;padding:14px 16px;background:var(--cream);border-radius:18px;border-bottom-left-radius:5px;align-self:flex-start;width:fit-content}
.typing span{width:7px;height:7px;border-radius:50%;background:var(--muted);animation:tdot 1.2s infinite}
.typing span:nth-child(2){animation-delay:.2s}.typing span:nth-child(3){animation-delay:.4s}
@keyframes tdot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}
.chat-foot{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.chat-foot .inp{flex:1;background:var(--cream);border-radius:30px;padding:10px 16px;font-size:13px;color:var(--muted)}
.chat-foot .snd{width:40px;height:40px;border-radius:50%;background:var(--grad);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px}

/* calendar + dashboard */
.cal-row{display:grid;grid-template-columns:1.25fr .75fr;gap:24px;align-items:start}
.panel{background:var(--white);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow-sm);padding:24px}
.panel-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.panel-h h3{font-size:21px}
.panel-h .pill{font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--moss);background:var(--cream);padding:5px 11px;border-radius:20px}
.cal{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}
.cal .dh{text-align:center;font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding-bottom:6px}
.slot{font-size:12px;font-weight:700;text-align:center;padding:9px 4px;border-radius:11px;margin-bottom:7px;cursor:pointer;transition:.18s}
.slot.free{background:rgba(134,156,120,.16);color:var(--moss)}
.slot.free:hover{background:var(--grad);color:#fff;transform:translateY(-2px)}
.slot.busy{background:var(--sand);color:#b7ac98;text-decoration:line-through;cursor:not-allowed}
.stat-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:16px}
.stat{background:var(--cream);border-radius:14px;padding:14px 10px;text-align:center}
.stat b{font-family:var(--serif);font-size:26px;display:block;line-height:1}
.stat small{font-size:10.5px;color:var(--muted);letter-spacing:.03em}
.toggle-row{display:flex;align-items:center;justify-content:space-between;background:var(--cream);border-radius:14px;padding:13px 16px;margin-bottom:14px}
.toggle-row .t{font-size:13.5px;font-weight:700}
.sw{width:46px;height:26px;border-radius:20px;background:var(--grad);position:relative;cursor:pointer}
.sw::after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:#fff;top:3px;right:3px;transition:.25s}
.booking-li{display:flex;align-items:center;gap:11px;padding:10px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.booking-li:last-child{border:none}
.booking-li .tm{font-weight:800;color:var(--moss);width:46px}
.booking-li .nm{flex:1}.booking-li .am{font-weight:700}

/* benefits */
.feats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat{text-align:center;padding:6px}
.feat .ic{width:62px;height:62px;border-radius:50%;background:var(--white);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 15px;box-shadow:var(--shadow-sm)}
.feat h4{font-size:20px;margin-bottom:6px}.feat p{font-size:13.5px;color:var(--muted)}

/* about */
.about{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.about h2{font-size:clamp(30px,4.2vw,46px);margin:12px 0 16px}
.about p{color:var(--muted);font-size:16px;margin-bottom:14px}
.about-photo{aspect-ratio:4/5;border-radius:24px;background:linear-gradient(160deg,#aec19f,#273221);box-shadow:var(--shadow);display:flex;align-items:flex-end;justify-content:center;color:rgba(255,255,255,.85);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding-bottom:22px}
.about-photo.has-photo{background-size:cover,cover;background-position:center top;background-repeat:no-repeat}
.chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.chip{font-size:12.5px;font-weight:700;padding:8px 15px;border-radius:30px;background:var(--cream);color:var(--moss)}

/* reviews */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rev{background:var(--white);border:1px solid var(--line);border-radius:20px;padding:26px}
.rev .stars{color:var(--gold);margin-bottom:11px;letter-spacing:2px}
.rev p{font-family:var(--serif);font-size:18px;font-style:italic;margin-bottom:14px;line-height:1.4}
.rev .who{font-size:13px;font-weight:700}.rev .who small{color:var(--muted);font-weight:400}

/* cta band */
.cta-band{background:var(--grad);color:#fff;text-align:center;border-radius:28px;padding:60px 30px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,255,255,.08);top:-100px;right:-60px}
.cta-band h2{font-size:clamp(30px,4.4vw,46px);color:#fff;position:relative}
.cta-band p{color:rgba(255,255,255,.86);font-size:16.5px;max-width:500px;margin:14px auto 26px;position:relative}
.cta-band .btn{background:#fff;color:var(--moss);border-color:#fff;font-size:15px;padding:15px 34px;position:relative}
.cta-band .btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px -10px rgba(0,0,0,.3)}

/* contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px}
.ci{display:flex;gap:14px;margin-bottom:18px}
.ci .ic{width:44px;height:44px;border-radius:50%;background:var(--cream);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ci .lbl{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.ci .val{font-size:16px}
.map{border-radius:20px;overflow:hidden;min-height:300px;border:1px solid var(--line)}.map iframe{width:100%;height:100%;min-height:300px;border:0;display:block}

/* ===== Responsive + reduced-motion =====
   Loaded last among non-noir stylesheets (noir.css has no layout rules) so these
   override the base grids defined above — which they could not when they lived in
   layout.css (loaded before this file). Ported verbatim from the reference's trailing
   media queries. */
@media(max-width:900px){.cards{grid-template-columns:1fr 1fr}.feats{grid-template-columns:1fr 1fr}.ai-row,.cal-row{grid-template-columns:1fr}}
@media(max-width:760px){
  .nav-links{display:none}
  .hero .wrap{grid-template-columns:1fr;gap:40px}.hero-visual{max-width:330px;margin:0 auto}
  .cards,.feats,.rev-grid{grid-template-columns:1fr}
  .about{grid-template-columns:1fr}.about-photo{max-width:360px}
  .contact-grid{grid-template-columns:1fr}.stat-row{grid-template-columns:1fr 1fr}
}
@media(prefers-reduced-motion:reduce){.hero-visual,.icon,.fbadge,.reveal{animation:none!important;transition:none;opacity:1;transform:none}}

/* ===== Burger navigation — slide-in panel from the right ===== */
.menu-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.62);opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}
.menu-overlay.open{opacity:1;visibility:visible}
.menu-panel{position:absolute;top:0;right:0;bottom:0;z-index:1;width:min(420px,88vw);display:flex;flex-direction:column;padding:24px 30px 30px;background:#000;border-left:1px solid var(--line);box-shadow:-40px 0 80px -30px rgba(0,0,0,.95);transform:translateX(100%);transition:transform .42s cubic-bezier(.22,.61,.36,1)}
.menu-overlay.open .menu-panel{transform:none}
.menu-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.menu-brand{font-family:var(--serif);font-size:17px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:#fff}
.menu-brand b{color:var(--moss)}
.menu-close{width:46px;height:46px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.05);color:#fff;border-radius:12px;font-size:26px;line-height:1;cursor:pointer;transition:.25s}
.menu-close:hover{border-color:var(--moss);color:var(--moss);transform:rotate(90deg)}
/* reset the leftover global nav{} cream bg + blur + sticky that this <nav> inherits */
.menu-links{flex:1;display:flex;flex-direction:column;justify-content:center;gap:0;background:none;backdrop-filter:none;border:none;position:static}
.menu-links a{display:flex;align-items:baseline;gap:14px;font-family:var(--serif);font-weight:600;text-transform:uppercase;letter-spacing:.03em;font-size:clamp(24px,4.4vw,33px);color:#fff;padding:13px 0;border-bottom:1px solid rgba(255,255,255,.07);opacity:0;transform:translateX(26px);transition:opacity .4s ease,transform .5s cubic-bezier(.22,.61,.36,1),color .2s ease}
.menu-links a .mn{font-family:var(--sans);font-size:12px;font-weight:700;color:var(--moss);letter-spacing:0;min-width:24px}
.menu-links a:hover{color:var(--moss)}
.menu-links a:hover .mn{color:#fff}
.menu-overlay.open .menu-links a{opacity:1;transform:none}
.menu-overlay.open .menu-links a:nth-child(1){transition-delay:.14s}
.menu-overlay.open .menu-links a:nth-child(2){transition-delay:.20s}
.menu-overlay.open .menu-links a:nth-child(3){transition-delay:.26s}
.menu-overlay.open .menu-links a:nth-child(4){transition-delay:.32s}
.menu-overlay.open .menu-links a:nth-child(5){transition-delay:.38s}
.menu-foot{display:flex;flex-direction:column;gap:14px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1);opacity:0;transform:translateY(14px);transition:opacity .4s ease,transform .4s ease}
.menu-overlay.open .menu-foot{opacity:1;transform:none;transition-delay:.44s}
.menu-lang{display:flex;gap:6px;border:none;background:none;padding:0;border-radius:0}
.menu-lang button{flex:1;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:rgba(255,255,255,.7);font-family:var(--sans);font-weight:700;font-size:12px;padding:10px 0;border-radius:8px;cursor:pointer;transition:.2s}
.menu-lang button:hover{border-color:var(--moss);color:#fff}
.menu-lang button.on{background:var(--grad);color:#fff;border-color:transparent}
.menu-ig{color:rgba(255,255,255,.72);font-size:14px;font-weight:600;letter-spacing:.02em}
.menu-ig:hover{color:var(--moss)}
.menu-cta{display:block;text-align:center;background:var(--grad);color:#fff;font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:15px;padding:15px;border-radius:8px;transition:.2s}
.menu-cta:hover{filter:brightness(1.08);color:#fff}

/* About photo pending placeholder */
.about-photo .photo-ph{color:rgba(255,255,255,.85);text-align:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;line-height:1.8}
.about-photo .photo-ph b{display:block;font-size:30px;letter-spacing:0;margin-bottom:6px}
