@import url('https://fonts.googleapis.com/css2?family=Geist:wght@400;500;600;700;800&family=Geist+Mono:wght@500;600&display=swap');

:root{
  --ink:#14162B; --ink-2:#2E3150; --bg:#FFFFFF; --soft:#F6F6FB; --soft-2:#EEEEF6;
  --line:#E5E5F0; --muted:#5C5F7A; --muted-2:#7B7E9C;
  --brand:#34387A; --brand-d:#2C2F69; --brand-soft:#EEF0FB; --brand-ring:#C2C7EE; --accent:#FF7A66; --accent-soft:#FFE1DB;
  --ok:#16A34A; --radius:16px; --shadow:0 1px 2px rgba(11,16,32,.04), 0 12px 32px -12px rgba(11,16,32,.12);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;font-family:'Geist',system-ui,sans-serif;color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;line-height:1.5;letter-spacing:-.01em;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{margin:0;font-weight:700;letter-spacing:-.03em;line-height:1.08;}
p{margin:0;}
.wrap{max-width:1140px;margin:0 auto;padding:0 24px;}
.narrow{max-width:760px;}
.eyebrow{font-family:'Geist Mono',monospace;font-size:12px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--brand);}
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:11px;padding:12px 18px;font-weight:600;
  font-size:15px;cursor:pointer;border:1px solid transparent;transition:.16s;white-space:nowrap;}
.btn-primary{background:var(--brand);color:#fff;}
.btn-primary:hover{background:var(--brand-d);transform:translateY(-1px);box-shadow:0 10px 22px -10px var(--brand);}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{background:var(--soft);}
.btn-lg{padding:14px 22px;font-size:16px;}

/* nav */
.hi{color:#C2412C;font-weight:600;}
header.nav{position:sticky;top:0;z-index:50;background:#14162B;
  backdrop-filter:blur(12px);border-bottom:1px solid #2C2E55;}
.nav-in{display:flex;align-items:center;gap:28px;height:64px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;font-size:19px;letter-spacing:-.03em;color:#fff;}
.logo{width:30px;height:30px;border-radius:9px;background:transparent;display:grid;place-items:center;
  font-weight:800;font-size:17px;}
.nav-links{display:flex;gap:26px;margin-left:8px;}
.nav-links a{font-size:14.5px;font-weight:500;color:#C5C7E0;transition:.15s;}
.nav-links a:hover{color:#fff;}
.nav-right{margin-left:auto;display:flex;align-items:center;gap:14px;}
.nav-right .signin{font-size:14.5px;font-weight:600;color:#fff;}

/* footer */
footer{border-top:1px solid #2C2E55;padding:46px 0;background:#14162B;color:#C5C7E0;}
.foot{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;}
.foot .links{display:flex;gap:24px;font-size:14px;color:#C5C7E0;flex-wrap:wrap;}
.foot .links a:hover{color:#fff;}
.foot .cp{font-size:13px;color:var(--muted-2);}

/* page hero */
.phero{position:relative;padding:72px 0 24px;overflow:hidden;background:#14162B;}
.phero::before{content:"";position:absolute;inset:-200px 0 auto 0;height:460px;z-index:-1;
  background:radial-gradient(55% 80% at 50% 0%, rgba(78,85,174,.20) 0%, rgba(20,22,43,0) 70%);}
.phero h1{font-size:46px;margin:16px 0 0;color:#fff;}
.phero .lead{margin-top:18px;font-size:18.5px;color:#C5C7E0;line-height:1.55;max-width:60ch;}
.phero .eyebrow{color:#9BA2E0;}
.phero .btn-ghost{background:transparent;color:#fff;border-color:#3A3D66;}
.phero .btn-ghost:hover{background:rgba(255,255,255,.08);}
.phero .cta{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;}

/* generic section */
.sec{padding:64px 0;}
.sec.alt{background:var(--soft);}
.sec-head{max-width:620px;margin:0 auto 44px;text-align:center;}
.sec-head h2{font-size:34px;margin-top:12px;}
.sec-head p{margin-top:14px;font-size:17px;color:var(--muted);line-height:1.55;}

/* feature rows (alternating) */
.frow{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:44px 0;}
.frow+.frow{border-top:1px solid var(--line);}
.frow.flip .ftext{order:2;}
.ftext .tag{font-family:'Geist Mono',monospace;font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);font-weight:600;}
.ftext h3{font-size:27px;margin-top:12px;}
.ftext p{margin-top:14px;color:var(--muted);font-size:16px;line-height:1.6;}
.ftext ul{margin:18px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px;}
.ftext li{display:flex;gap:10px;font-size:15px;color:var(--ink-2);}
.ftext li svg{color:var(--ok);flex:none;margin-top:2px;}
.fart{background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:18px;min-height:200px;display:flex;flex-direction:column;gap:10px;}
.fart .ic{width:44px;height:44px;border-radius:12px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;}
.fart .mini{background:var(--soft);border-radius:10px;padding:11px 13px;font-size:13px;color:var(--ink-2);display:flex;align-items:center;gap:9px;}
.fart .mini b{font-weight:600;}
.fart .mini .pill{margin-left:auto;font-size:10.5px;font-weight:600;padding:2px 9px;border-radius:20px;background:var(--brand-soft);color:var(--brand);}
.fart .mini .pill.ok{background:#E7F6EC;color:#0F7A37;}

/* ===== features page: kinetic reveal + hover replay (matches home page) ===== */
.frow .ftext,.frow .fart{opacity:0;transform:translateY(22px);transition:opacity .55s ease,transform .55s cubic-bezier(.22,1,.36,1);}
.frow.in .ftext{opacity:1;transform:none;transition-delay:.02s;}
.frow.in .fart{opacity:1;transform:none;transition-delay:.1s;}
.frow:hover .fart{transform:translateY(-3px);transition:transform .25s cubic-bezier(.22,1,.36,1);}
.frow:is(.go,:hover) .fart .ic{animation:mvPop .55s cubic-bezier(.34,1.56,.64,1) .08s both;}
.frow:is(.go,:hover) .fart .mini{animation:mvIn .5s cubic-bezier(.22,1,.36,1) both;}
.frow:is(.go,:hover) .fart .mini:nth-child(2){animation-delay:.14s;}
.frow:is(.go,:hover) .fart .mini:nth-child(3){animation-delay:.30s;}
.frow:is(.go,:hover) .fart .mini:nth-child(4){animation-delay:.46s;}
.frow:is(.go,:hover) .fart .mini .pill{animation:mvPop .5s cubic-bezier(.34,1.56,.64,1) both;}
.frow:is(.go,:hover) .fart .mini:nth-child(2) .pill{animation-delay:.40s;}
.frow:is(.go,:hover) .fart .mini:nth-child(3) .pill{animation-delay:.56s;}
.frow:is(.go,:hover) .fart .mini:nth-child(4) .pill{animation-delay:.72s;}
.frow:is(.go,:hover) .ftext li{animation:mvIn .5s ease both;}
.frow:is(.go,:hover) .ftext li:nth-child(1){animation-delay:.12s;}
.frow:is(.go,:hover) .ftext li:nth-child(2){animation-delay:.24s;}
.frow:is(.go,:hover) .ftext li:nth-child(3){animation-delay:.36s;}
@keyframes mvIn{from{opacity:0;transform:translateX(-34px);}to{opacity:1;transform:none;}}
@keyframes mvPop{0%{opacity:0;transform:scale(.4);}65%{opacity:1;}100%{opacity:1;transform:scale(1);}}
@media (prefers-reduced-motion:reduce){
  .frow .ftext,.frow .fart{opacity:1!important;transform:none!important;}
  .frow:hover .fart{transform:none!important;}
  .frow .fart .ic,.frow .fart .mini,.frow .fart .mini .pill,.frow .ftext li{animation:none!important;}
}

/* cta band */
.band{background:linear-gradient(135deg,var(--brand),#4D55AE);border-radius:24px;padding:54px;text-align:center;color:#fff;}
.band h2{font-size:34px;color:#fff;}
.band p{margin-top:13px;color:#DFE2F6;font-size:17px;}
.band .btn{margin-top:24px;background:#fff;color:var(--brand);}
.band .btn:hover{background:#EEF0FB;}

/* prose (legal) */
.prose{max-width:760px;margin:0 auto;padding:8px 0 24px;}
.prose .updated{font-size:13.5px;color:var(--muted-2);font-family:'Geist Mono',monospace;}
.prose h2{font-size:22px;margin:36px 0 0;}
.prose p{margin-top:12px;color:var(--ink-2);font-size:15.5px;line-height:1.7;}
.prose ul{margin-top:12px;padding-left:20px;color:var(--ink-2);font-size:15.5px;line-height:1.7;}
.prose li{margin:5px 0;}
.prose .note{margin-top:28px;font-size:13px;color:var(--muted-2);border-top:1px solid var(--line);padding-top:18px;line-height:1.6;}

/* form card (contact / auth) */
.center{min-height:calc(100vh - 64px);display:grid;place-items:center;padding:40px 24px;}
.card{width:100%;max-width:440px;background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:32px 30px;box-shadow:var(--shadow);}
.card.lg{max-width:540px;}
.card h1{font-size:26px;}
.card .sub{margin:8px 0 24px;color:var(--muted);font-size:14.5px;line-height:1.5;}
.field{margin-bottom:15px;}
.field label{display:block;font-size:13px;font-weight:600;margin:0 0 7px;}
.field input,.field textarea,.field select{width:100%;border:1.5px solid var(--line);border-radius:11px;
  padding:12px 13px;font:inherit;color:var(--ink);background:#fff;transition:.13s;resize:vertical;}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--brand);box-shadow:0 0 0 3px #DFE2F6;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.full{width:100%;justify-content:center;}
.formfoot{margin-top:18px;text-align:center;font-size:13.5px;color:var(--muted);}
.formfoot a{color:var(--brand);font-weight:600;}
.linkrow{display:flex;justify-content:flex-end;margin:-4px 0 16px;}
.linkrow a{font-size:13px;color:var(--brand);font-weight:600;}

/* 404 */
.nf{min-height:calc(100vh - 64px);display:grid;place-items:center;text-align:center;padding:40px 24px;}
.nf .code{font-family:'Geist Mono',monospace;font-size:13px;letter-spacing:.18em;color:var(--brand);}
.nf h1{font-size:48px;margin-top:14px;}
.nf p{margin-top:14px;color:var(--muted);font-size:17px;}
.nf .cta{margin-top:26px;display:flex;gap:12px;justify-content:center;}

@media (max-width:820px){
  .nav-links{display:none;}
  .frow{grid-template-columns:1fr;gap:24px;} .frow.flip .ftext{order:0;}
  .phero h1{font-size:34px;} .sec-head h2{font-size:27px;} .row2{grid-template-columns:1fr;}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto;}.btn:hover{transform:none;}}

/* ============================================================
   FEATURES PAGE — looping mini-scenes (home-page caliber)
   ============================================================ */
.fart{position:relative;}
.stage{position:relative;height:196px;width:100%;}
.stage .lbl{position:absolute;left:0;top:-4px;font-family:'Geist Mono',monospace;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);}
.stage .chip{font-size:11px;font-weight:600;border-radius:20px;padding:3px 10px;white-space:nowrap;}
.chip-ok{background:#E7F6EC;color:#0F7A37;}
.chip-br{background:var(--brand-soft);color:var(--brand);}

/* ---------- 1 · AI receptionist ---------- */
.sc-ai .ph{position:absolute;left:2px;top:30px;width:42px;height:42px;border-radius:50%;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;z-index:2;}
.sc-ai .pulse{position:absolute;left:2px;top:30px;width:42px;height:42px;border-radius:50%;border:2px solid var(--brand);}
.sc-ai .row{position:absolute;left:58px;right:0;border-radius:10px;padding:9px 11px;font-size:12px;opacity:0;}
.sc-ai .call{top:16px;background:#fff;border:1px solid var(--line);color:var(--ink);display:flex;align-items:center;gap:6px;font-weight:600;}
.sc-ai .msg{top:72px;background:var(--soft-2);color:var(--ink-2);}
.sc-ai .rep{top:118px;background:var(--brand);color:#fff;}
.sc-ai .bk{position:absolute;left:58px;top:164px;opacity:0;}
.frow.live .sc-ai .ph{animation:aiRing 1.5s ease-in-out infinite;}
.frow.live .sc-ai .pulse{animation:aiPulse 1.5s ease-out infinite;}
.frow.live .sc-ai .call{animation:s6a 6s ease infinite;}
.frow.live .sc-ai .msg{animation:s6b 6s ease infinite;}
.frow.live .sc-ai .rep{animation:s6c 6s ease infinite;}
.frow.live .sc-ai .bk{animation:s6d 6s ease infinite;}
@keyframes aiRing{0%,17%,100%{transform:rotate(0)}3%{transform:rotate(-13deg)}8%{transform:rotate(11deg)}13%{transform:rotate(-6deg)}}
@keyframes aiPulse{0%{transform:scale(1);opacity:.4}70%,100%{transform:scale(2.1);opacity:0}}
@keyframes s6a{0%,3%{opacity:0;transform:translateY(8px)}9%,86%{opacity:1;transform:none}93%,100%{opacity:0}}
@keyframes s6b{0%,22%{opacity:0;transform:translateY(8px)}29%,86%{opacity:1;transform:none}93%,100%{opacity:0}}
@keyframes s6c{0%,42%{opacity:0;transform:translateY(8px)}49%,86%{opacity:1;transform:none}93%,100%{opacity:0}}
@keyframes s6d{0%,62%{opacity:0;transform:scale(.6)}69%,86%{opacity:1;transform:scale(1)}93%,100%{opacity:0}}

/* ---------- 2 · Online booking ---------- */
.sc-book .cal{position:absolute;left:0;right:0;top:24px;display:flex;gap:7px;height:128px;}
.sc-book .day{flex:1;border-radius:9px;background:#fff;border:1px solid var(--line);position:relative;padding:6px 5px;}
.sc-book .day.open{border-style:dashed;border-color:var(--brand-ring);background:var(--brand-soft);}
.sc-book .s{height:15px;border-radius:5px;background:var(--brand);margin-bottom:6px;}
.sc-book .s.lo{background:#C2C7EE;}
.sc-book .drop{position:absolute;left:5px;right:5px;top:6px;height:15px;border-radius:5px;background:var(--brand);opacity:0;}
.sc-book .bk{position:absolute;left:0;top:162px;opacity:0;}
.frow.live .sc-book .drop{animation:bkDrop 5.5s cubic-bezier(.22,1,.36,1) infinite;}
.frow.live .sc-book .bk{animation:s55d 5.5s ease infinite;}
@keyframes bkDrop{0%,14%{opacity:0;transform:translateY(-18px)}24%,88%{opacity:1;transform:none}95%,100%{opacity:0;transform:translateY(-18px)}}
@keyframes s55d{0%,32%{opacity:0;transform:scale(.6)}40%,88%{opacity:1;transform:scale(1)}95%,100%{opacity:0}}

/* ---------- 3 · Customer CRM ---------- */
.sc-crm .prof{position:absolute;left:0;top:14px;display:flex;align-items:center;gap:10px;}
.sc-crm .av{width:42px;height:42px;border-radius:11px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:700;font-size:15px;}
.sc-crm .nm{font-weight:600;font-size:14px;color:var(--ink);}
.sc-crm .sb{font-size:11.5px;color:var(--muted);}
.sc-crm .dots{position:absolute;left:2px;top:82px;display:flex;gap:10px;}
.sc-crm .dot{width:14px;height:14px;border-radius:50%;background:var(--brand);opacity:0;}
.sc-crm .vl{position:absolute;left:2px;top:104px;font-size:11px;color:var(--muted);opacity:0;}
.sc-crm .nudge{position:absolute;left:0;right:0;top:138px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px 11px;font-size:12px;color:var(--ink-2);display:flex;align-items:center;font-weight:500;opacity:0;}
.frow.live .sc-crm .dot:nth-child(1){animation:cd1 6s ease infinite;}
.frow.live .sc-crm .dot:nth-child(2){animation:cd2 6s ease infinite;}
.frow.live .sc-crm .dot:nth-child(3){animation:cd3 6s ease infinite;}
.frow.live .sc-crm .dot:nth-child(4){animation:cd4 6s ease infinite;}
.frow.live .sc-crm .vl{animation:cdv 6s ease infinite;}
.frow.live .sc-crm .nudge{animation:s6d 6s ease infinite;}
@keyframes cd1{0%,6%{opacity:0;transform:scale(.4)}13%,90%{opacity:1;transform:scale(1)}96%,100%{opacity:0}}
@keyframes cd2{0%,16%{opacity:0;transform:scale(.4)}23%,90%{opacity:1;transform:scale(1)}96%,100%{opacity:0}}
@keyframes cd3{0%,26%{opacity:0;transform:scale(.4)}33%,90%{opacity:1;transform:scale(1)}96%,100%{opacity:0}}
@keyframes cd4{0%,36%{opacity:0;transform:scale(.4)}43%,90%{opacity:1;transform:scale(1)}96%,100%{opacity:0}}
@keyframes cdv{0%,40%{opacity:0}48%,90%{opacity:1}96%,100%{opacity:0}}

/* ---------- 4 · Sales pipeline ---------- */
.sc-pipe .cols{position:absolute;left:0;right:0;top:20px;bottom:0;display:flex;gap:8px;}
.sc-pipe .col{flex:1;border-radius:10px;background:#fff;border:1px solid var(--line);position:relative;}
.sc-pipe .col .h{position:absolute;top:8px;left:0;right:0;text-align:center;font-size:9.5px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--muted-2);}
.sc-pipe .won-fill{position:absolute;inset:0;border-radius:10px;background:#E7F6EC;border:1px solid #BFE6CC;opacity:0;}
.sc-pipe .lead{position:absolute;top:64px;left:3.5%;width:27%;height:52px;border-radius:9px;background:var(--brand);box-shadow:0 8px 16px -8px var(--brand);}
.sc-pipe .wt{position:absolute;left:50%;top:120px;transform:translateX(-50%);opacity:0;}
.frow.live .sc-pipe .lead{animation:pipeMove 6.5s cubic-bezier(.6,0,.3,1) infinite;}
.frow.live .sc-pipe .won-fill{animation:pipeWon 6.5s ease infinite;}
.frow.live .sc-pipe .wt{animation:pipeWt 6.5s ease infinite;}
@keyframes pipeMove{0%,9%{left:3.5%}29%,40%{left:36.5%}60%,88%{left:69.5%}95%,100%{left:3.5%}}
@keyframes pipeWon{0%,58%{opacity:0}66%,88%{opacity:1}95%,100%{opacity:0}}
@keyframes pipeWt{0%,66%{opacity:0;transform:translateX(-50%) scale(.7)}73%,88%{opacity:1;transform:translateX(-50%) scale(1)}95%,100%{opacity:0}}

/* ---------- 5 · Reporting ---------- */
.sc-report .val{position:absolute;right:0;top:-6px;font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-.03em;}
.sc-report .bars{position:absolute;left:0;right:0;top:34px;height:96px;display:flex;align-items:flex-end;gap:9px;}
.sc-report .bar{flex:1;background:var(--brand);border-radius:6px 6px 0 0;height:8px;}
.sc-report .bar:nth-child(even){background:#6E76C9;}
.frow.live .sc-report .bar{animation:barGrow 4.8s ease-in-out infinite;}
.frow.live .sc-report .bar:nth-child(2){animation-delay:.14s;}
.frow.live .sc-report .bar:nth-child(3){animation-delay:.28s;}
.frow.live .sc-report .bar:nth-child(4){animation-delay:.42s;}
.frow.live .sc-report .bar:nth-child(5){animation-delay:.56s;}
.sc-report .ask{position:absolute;left:0;right:0;border-radius:10px;padding:8px 11px;font-size:12px;opacity:0;}
.sc-report .q{top:140px;background:var(--soft-2);color:var(--ink-2);}
.sc-report .a{top:140px;background:var(--brand);color:#fff;font-weight:600;}
.frow.live .sc-report .q{animation:rq 5s ease infinite;}
.frow.live .sc-report .a{animation:ra 5s ease infinite;}
@keyframes barGrow{0%{height:8px}22%{height:var(--h)}82%{height:var(--h)}100%{height:8px}}
@keyframes rq{0%,8%{opacity:0;transform:translateY(6px)}16%,46%{opacity:1;transform:none}54%,100%{opacity:0}}
@keyframes ra{0%,54%{opacity:0;transform:translateY(6px)}62%,90%{opacity:1;transform:none}96%,100%{opacity:0}}

/* ---------- 6 · Payments & deposits ---------- */
.sc-pay .pcard{position:absolute;left:0;right:0;top:34px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;}
.sc-pay .pt{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink);margin-bottom:11px;}
.sc-pay .pt b{font-weight:600;}
.sc-pay .pt span{color:var(--muted);}
.sc-pay .track{height:10px;border-radius:6px;background:var(--soft-2);overflow:hidden;}
.sc-pay .fill{height:100%;background:var(--brand);border-radius:6px;transform:scaleX(0);transform-origin:left;}
.sc-pay .paid{position:absolute;left:0;top:128px;opacity:0;}
.frow.live .sc-pay .fill{animation:payFill 5.5s cubic-bezier(.6,0,.3,1) infinite;}
.frow.live .sc-pay .paid{animation:s55d 5.5s ease infinite;}
@keyframes payFill{0%,10%{transform:scaleX(0)}42%,88%{transform:scaleX(1)}95%,100%{transform:scaleX(0)}}

@media (prefers-reduced-motion:reduce){
  .stage *{animation:none!important;opacity:1!important;transform:none!important;}
  .sc-pay .fill{transform:scaleX(1)!important;}
  .sc-report .bar{height:var(--h)!important;}
  .sc-report .a,.sc-book .drop{opacity:0!important;}
}

/* ===================== See it in action — narrative showcases ===================== */
.show{padding:80px 0 24px;}
.show .sec-head{max-width:660px;margin:0 auto 42px;text-align:center;}
.show .sec-head h2{font-size:34px;margin-top:12px;}
.show .sec-head p{margin-top:14px;color:var(--muted);font-size:16.5px;line-height:1.55;}
.show-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.show-card{background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;min-height:496px;}
.sh-head{display:flex;align-items:center;gap:11px;padding:15px 17px;border-bottom:1px solid var(--line);flex:none;}
.sh-head .ic{width:34px;height:34px;border-radius:9px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;flex:none;}
.sh-head .ic.coral{background:var(--accent-soft);color:#C2412C;}
.sh-head h3{font-size:14.5px;line-height:1.15;}
.sh-head .sub{font-size:11.5px;color:var(--muted-2);margin-top:2px;}
.sh-head .live{margin-left:auto;display:flex;align-items:center;gap:6px;font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);flex:none;}
.sh-head .live i{width:6px;height:6px;border-radius:50%;background:var(--ok);animation:shPulse 1.8s infinite;}
@keyframes shPulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.5);}70%{box-shadow:0 0 0 6px rgba(22,163,74,0);}100%{box-shadow:0 0 0 0 rgba(22,163,74,0);}}

.sh-feed{flex:1;overflow:hidden;padding:14px;display:flex;flex-direction:column;gap:9px;background:var(--soft);}
.sh-row{display:flex;max-width:90%;animation:shIn .34s cubic-bezier(.22,1,.36,1) both;}
.sh-row.them{align-self:flex-start;}
.sh-row.ai{align-self:flex-end;}
.sh-msg{font-size:12.5px;line-height:1.42;padding:8px 11px;border-radius:13px;}
.sh-row.them .sh-msg{background:#fff;border:1px solid var(--line);color:var(--ink-2);border-bottom-left-radius:4px;}
.sh-row.ai .sh-msg{background:var(--brand);color:#fff;border-bottom-right-radius:4px;}
@keyframes shIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
.sh-typing{display:flex;gap:3px;padding:3px 1px;}
.sh-typing i{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.75);animation:shDot 1s infinite;}
.sh-typing i:nth-child(2){animation-delay:.15s;}
.sh-typing i:nth-child(3){animation-delay:.3s;}
@keyframes shDot{0%,60%,100%{opacity:.3;transform:translateY(0);}30%{opacity:1;transform:translateY(-3px);}}
.sh-link{display:inline-block;margin-top:7px;font-size:11.5px;font-weight:600;color:#fff;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.34);padding:5px 10px;border-radius:8px;text-decoration:none;}
.sh-sys{align-self:center;max-width:94%;font-size:10.5px;color:var(--muted);background:#fff;border:1px solid var(--line);border-radius:20px;padding:5px 12px;text-align:center;animation:shIn .34s both;}

.sh-log{border-top:1px solid var(--line);background:#fff;padding:11px 15px 13px;min-height:128px;flex:none;}
.sh-log-h{font-family:'Geist Mono',monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2);margin-bottom:8px;}
.sh-logrow{display:flex;gap:9px;align-items:baseline;font-size:11.5px;padding:3px 0;opacity:0;transform:translateX(-7px);transition:opacity .4s ease,transform .4s ease;}
.sh-logrow.in{opacity:1;transform:none;}
.sh-logk{font-size:10px;color:var(--muted-2);min-width:58px;flex:none;font-family:'Geist Mono',monospace;letter-spacing:.03em;}
.sh-logv{color:var(--ink-2);font-weight:500;}
.sh-logrow.done .sh-logv{color:#0F7A37;font-weight:600;}

.dash{flex:1;display:flex;flex-direction:column;background:var(--soft);}
.dash-kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:14px 14px 4px;flex:none;}
.dash-kpi{background:#fff;border:1px solid var(--line);border-radius:11px;padding:9px 10px;}
.dash-kpi span{font-size:9px;color:var(--muted);font-weight:500;display:block;text-transform:uppercase;letter-spacing:.04em;}
.dash-kpi strong{font-size:17px;letter-spacing:-.02em;display:block;margin-top:3px;transition:color .3s;}
.dash-kpi.flash strong{color:var(--accent);animation:shBump .55s;}
@keyframes shBump{0%{transform:scale(1);}40%{transform:scale(1.16);}100%{transform:scale(1);}}
.dash-feed{flex:1;overflow:hidden;padding:10px 14px 14px;display:flex;flex-direction:column;gap:7px;}
.dash-row{display:flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px 10px;animation:shIn .42s cubic-bezier(.22,1,.36,1) both;}
.dash-row .di{width:25px;height:25px;border-radius:7px;background:var(--brand-soft);color:var(--brand);display:grid;place-items:center;flex:none;}
.dash-row .dt{flex:1;min-width:0;}
.dash-row .dt b{font-weight:600;display:block;font-size:11.5px;color:var(--ink);}
.dash-row .dt span{font-size:10px;color:var(--muted-2);}
.dash-auto{font-family:'Geist Mono',monospace;font-size:8px;font-weight:700;letter-spacing:.08em;color:#0F7A37;background:#E7F6EC;border:1px solid #BFE6CC;border-radius:5px;padding:2px 6px;flex:none;}

.sh-fade{opacity:0;transition:opacity .45s ease;}
@media (max-width:920px){.show-grid{grid-template-columns:1fr;}.show-card{min-height:0;}.sh-feed{min-height:320px;}}

/* ===== voice-call treatment (AI receptionist) — visually distinct from chat ===== */
.show-card.voice .sh-feed{background:#14162B;}
.sh-wave{display:flex;align-items:center;gap:10px;padding:9px 15px;background:#1B1E3C;border-bottom:1px solid rgba(255,255,255,.07);flex:none;}
.sh-rec{display:flex;align-items:center;gap:6px;font-family:'Geist Mono',monospace;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:#FF8C77;flex:none;}
.sh-rec b{width:7px;height:7px;border-radius:50%;background:#FF7A66;animation:shBlink 1.4s infinite;}
@keyframes shBlink{0%,100%{opacity:1;}50%{opacity:.25;}}
.sh-bars{display:flex;align-items:center;gap:2.5px;height:18px;flex:1;}
.sh-bars i{width:2.6px;border-radius:2px;background:#FF8C77;transform-origin:center;animation:shBar 1.1s ease-in-out infinite;}
.sh-bars i:nth-child(1){height:7px;animation-delay:0s;}
.sh-bars i:nth-child(2){height:14px;animation-delay:.12s;}
.sh-bars i:nth-child(3){height:18px;animation-delay:.24s;}
.sh-bars i:nth-child(4){height:11px;animation-delay:.36s;}
.sh-bars i:nth-child(5){height:16px;animation-delay:.18s;}
.sh-bars i:nth-child(6){height:9px;animation-delay:.30s;}
.sh-bars i:nth-child(7){height:13px;animation-delay:.06s;}
@keyframes shBar{0%,100%{transform:scaleY(.35);}50%{transform:scaleY(1);}}
.sh-clock{font-family:'Geist Mono',monospace;font-size:11px;color:#AEB4EA;flex:none;font-variant-numeric:tabular-nums;}
.sh-cap{padding:3px 0;animation:shIn .34s both;}
.sh-spk{display:block;font-family:'Geist Mono',monospace;font-size:8.5px;letter-spacing:.11em;text-transform:uppercase;margin-bottom:2px;}
.sh-cap.them .sh-spk{color:#8E93C8;}
.sh-cap.ai .sh-spk{color:#FF8C77;}
.sh-txt{display:block;font-size:12.5px;line-height:1.46;}
.sh-cap.ai .sh-txt{color:#EDEEF7;}
.sh-cap.them .sh-txt{color:#C2C5E4;}
.sh-spk-dots{display:inline-flex;gap:3px;padding:4px 0;}
.sh-spk-dots i{width:5px;height:5px;border-radius:50%;background:#6E74B0;animation:shDot 1s infinite;}
.sh-spk-dots i:nth-child(2){animation-delay:.15s;}
.sh-spk-dots i:nth-child(3){animation-delay:.3s;}
.show-card.voice .sh-log{border-top:1px solid var(--line);}

/* ===== chat widget input bar (AI chat) ===== */
.sh-input{display:flex;align-items:center;gap:9px;padding:11px 13px;border-top:1px solid var(--line);background:#fff;flex:none;}
.sh-input span{flex:1;font-size:12px;color:var(--muted-2);background:var(--soft);border:1px solid var(--line);border-radius:18px;padding:8px 13px;}
.sh-input b{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-size:13px;flex:none;}
