@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:wght@400;500;600;700&display=swap');
:root{--pink:#be185d;--pink-lt:#ec4899;--pink-dk:#9d174d;--teal:#0d9488;--teal-lt:#14b8a6;--bg:#fdf2f8;--surface:#ffffff;--surface2:#fce7f3;--text:#1c1917;--muted:#6b7280;--border:#f9a8d4;--glow:rgba(190,24,93,.06);--font-h:'Outfit',sans-serif;--font-b:'DM Sans',sans-serif;--max-w:1100px;--r:14px;--tr:.35s ease}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-b);color:var(--text);background:var(--bg);line-height:1.8;font-size:15.5px}img{max-width:100%;height:auto;display:block}a{color:var(--pink);text-decoration:none;transition:color var(--tr)}a:hover{color:var(--teal)}ul,ol{list-style:none}.rs{max-width:var(--max-w);margin:0 auto;padding:0 32px}
h1,h2,h3,h4,h5{font-family:var(--font-h);color:var(--text);line-height:1.15}h1{font-size:clamp(3rem,8vw,6rem);font-weight:900;letter-spacing:-.04em}h2{font-size:clamp(1.4rem,3.5vw,2.2rem);font-weight:700}h3{font-size:1.05rem;font-weight:700}h4{font-size:.9rem;font-weight:600}h5{font-size:.8rem;font-weight:600;color:var(--pink)}p{margin-bottom:1rem}
.rs-label{display:inline-block;font-size:.5rem;font-weight:700;color:var(--pink);letter-spacing:3px;text-transform:uppercase;margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 30px;border-radius:100px;font-family:var(--font-h);font-weight:700;font-size:.82rem;border:none;cursor:pointer;transition:all var(--tr);text-decoration:none}
.btn-pink{background:var(--pink);color:#fff}.btn-pink:hover{background:var(--pink-dk);transform:translateY(-2px);box-shadow:0 10px 30px var(--glow);color:#fff}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:#0f766e;color:#fff}
.btn-line{background:transparent;border:1.5px solid var(--border);color:var(--text)}.btn-line:hover{border-color:var(--pink);color:var(--pink);transform:translateY(-2px)}

/* ═══ MINIMAL HAMBURGER NAV — always hamburger even on desktop! ═══ */
.rs-topbar{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(253,242,248,.92);backdrop-filter:blur(20px);display:flex;align-items:center;justify-content:space-between;height:60px;padding:0 32px;border-bottom:1px solid rgba(249,168,212,.3)}
.rs-logo{font-family:var(--font-h);font-size:.88rem;font-weight:800;color:var(--pink);text-decoration:none;letter-spacing:-.01em}
.rs-hamburger{width:36px;height:36px;background:none;border:1.5px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--tr);color:var(--pink);font-size:.7rem;font-family:var(--font-h);font-weight:700}
.rs-hamburger:hover{background:var(--pink);color:#fff;border-color:var(--pink)}
.rs-menu-overlay{position:fixed;inset:0;background:rgba(253,242,248,.98);backdrop-filter:blur(30px);z-index:300;display:none;flex-direction:column;align-items:center;justify-content:center;gap:18px}
.rs-menu-overlay.open{display:flex}
.rs-menu-overlay a{font-family:var(--font-h);font-size:clamp(1.4rem,4vw,2.4rem);font-weight:700;color:var(--text);text-decoration:none;transition:color var(--tr);letter-spacing:-.01em}
.rs-menu-overlay a:hover,.rs-menu-overlay a.active{color:var(--pink)}
.rs-menu-close{position:absolute;top:16px;right:32px;background:none;border:1.5px solid var(--border);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--pink);font-size:1rem;transition:all var(--tr)}
.rs-menu-close:hover{background:var(--pink);color:#fff;border-color:var(--pink)}

/* ═══ OVERSIZED TYPOGRAPHY HERO — giant heading fills viewport ═══ */
.rs-hero{min-height:80vh;display:flex;flex-direction:column;justify-content:center;padding:100px 0 40px;position:relative;overflow:hidden}
.rs-hero::before{content:'';position:absolute;top:10%;right:-5%;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(190,24,93,.04),transparent 70%);pointer-events:none}
.rs-hero::after{content:'';position:absolute;bottom:15%;left:-8%;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(13,148,136,.04),transparent 70%);pointer-events:none}
.rs-hero h1{position:relative;z-index:2}.rs-hero h1 span{display:block;color:var(--pink)}
.rs-hero-sub{color:var(--muted);font-size:.94rem;max-width:440px;margin-top:16px;position:relative;z-index:2}
.rs-hero-btns{display:flex;gap:10px;flex-wrap:wrap;margin-top:28px;position:relative;z-index:2}
.rs-hero-meta{display:flex;gap:28px;margin-top:40px;position:relative;z-index:2}
.rs-hero-stat{text-align:center}.rs-hero-stat strong{font-family:var(--font-h);font-size:1.6rem;font-weight:800;color:var(--pink);display:block;line-height:1}.rs-hero-stat span{font-size:.48rem;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:1px}

/* ═══ SHOWCASE CARDS — large image with overlay on hover ═══ */
.rs-showcase{padding:70px 0}
.rs-show-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.rs-show-card{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:3/4;background:var(--surface);border:1px solid var(--border);transition:all var(--tr);text-decoration:none;color:var(--text);display:block}
.rs-show-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.06);color:var(--text)}
.rs-show-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.rs-show-card:hover img{transform:scale(1.05)}
.rs-show-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(190,24,93,.92) 0%,rgba(190,24,93,.4) 40%,transparent 100%);opacity:0;transition:opacity .4s ease;display:flex;flex-direction:column;justify-content:flex-end;padding:24px 20px;color:#fff}
.rs-show-card:hover .rs-show-overlay{opacity:1}
.rs-show-overlay h3{color:#fff;margin-bottom:4px;font-size:1.1rem}
.rs-show-overlay p{color:rgba(255,255,255,.8);font-size:.72rem;margin:0 0 8px}
.rs-show-price{font-family:var(--font-h);font-weight:700;font-size:.78rem}
.rs-show-card:nth-child(even) .rs-show-overlay{background:linear-gradient(to top,rgba(13,148,136,.92) 0%,rgba(13,148,136,.4) 40%,transparent 100%)}
@media(max-width:768px){.rs-show-grid{grid-template-columns:1fr 1fr}.rs-show-card{aspect-ratio:1/1}}
@media(max-width:480px){.rs-show-grid{grid-template-columns:1fr}.rs-show-card{aspect-ratio:4/3}}

/* ═══ SIDE-BY-SIDE CASES — before/after comparison ═══ */
.rs-sidebyside{padding:70px 0;background:var(--surface)}
.rs-sbs-grid{display:flex;flex-direction:column;gap:24px}
.rs-sbs-item{display:grid;grid-template-columns:1fr 1fr;gap:2px;border-radius:var(--r);overflow:hidden;border:1px solid var(--border);transition:all var(--tr)}
.rs-sbs-item:hover{box-shadow:0 8px 28px rgba(0,0,0,.04);transform:translateY(-2px)}
.rs-sbs-half{padding:28px 24px;display:flex;flex-direction:column;justify-content:center}
.rs-sbs-before{background:var(--bg)}.rs-sbs-after{background:var(--surface2)}
.rs-sbs-tag{font-size:.42rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;margin-bottom:6px}.rs-sbs-before .rs-sbs-tag{color:var(--muted)}.rs-sbs-after .rs-sbs-tag{color:var(--pink)}
.rs-sbs-val{font-family:var(--font-h);font-size:1.6rem;font-weight:800;margin-bottom:4px}.rs-sbs-before .rs-sbs-val{color:var(--muted)}.rs-sbs-after .rs-sbs-val{color:var(--pink)}
.rs-sbs-detail{font-size:.72rem;color:var(--muted);margin:0}
.rs-sbs-who{text-align:center;padding:8px;font-size:.56rem;color:var(--muted);font-weight:600;background:var(--surface);border-top:1px solid var(--border)}
@media(max-width:600px){.rs-sbs-item{grid-template-columns:1fr}}

/* ═══ PROGRESS BAR PROCESS — horizontal bar with dot milestones ═══ */
.rs-progress{padding:70px 0}
.rs-prog-bar{position:relative;max-width:800px;margin:0 auto;padding-top:30px}
.rs-prog-track{height:3px;background:var(--border);border-radius:2px;position:relative}
.rs-prog-fill{height:100%;background:linear-gradient(90deg,var(--pink),var(--teal));border-radius:2px;width:100%}
.rs-prog-dots{display:flex;justify-content:space-between;position:relative;margin-top:-9px}
.rs-prog-dot{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:2;flex:1}
.rs-prog-circle{width:16px;height:16px;border-radius:50%;background:var(--pink);border:3px solid var(--bg);box-shadow:0 0 0 2px var(--pink);margin-bottom:14px}
.rs-prog-dot:nth-child(2) .rs-prog-circle{background:var(--pink-lt);box-shadow:0 0 0 2px var(--pink-lt)}
.rs-prog-dot:nth-child(3) .rs-prog-circle{background:var(--teal);box-shadow:0 0 0 2px var(--teal)}
.rs-prog-dot:nth-child(4) .rs-prog-circle{background:var(--teal-lt);box-shadow:0 0 0 2px var(--teal-lt)}
.rs-prog-dot h3{font-size:.78rem;margin-bottom:2px}.rs-prog-dot p{color:var(--muted);font-size:.58rem;margin:0;max-width:140px}

/* ═══ PULL-QUOTE TESTIMONIALS — single large rotating quote ═══ */
.rs-pullquote{padding:80px 0;text-align:center;background:var(--surface2);border-top:1px solid var(--border);overflow:hidden}
.rs-pq-item{display:none;padding:0 20px}
.rs-pq-item.active{display:block}
.rs-pq-text{font-family:var(--font-h);font-size:clamp(1.2rem,3vw,1.8rem);font-weight:400;font-style:italic;color:var(--text);line-height:1.5;max-width:700px;margin:0 auto 20px;position:relative;padding-top:24px}
.rs-pq-text::before{content:'"';font-size:4rem;color:var(--pink);opacity:.15;position:absolute;top:-8px;left:50%;transform:translateX(-50%);font-style:normal;font-family:var(--font-h)}
.rs-pq-name{font-family:var(--font-h);font-weight:700;font-size:.82rem;color:var(--pink)}.rs-pq-role{font-size:.56rem;color:var(--muted)}
.rs-pq-dots{display:flex;justify-content:center;gap:6px;margin-top:18px}
.rs-pq-dot{width:8px;height:8px;border-radius:50%;background:var(--border);cursor:pointer;transition:all var(--tr)}.rs-pq-dot.active{background:var(--pink);transform:scale(1.3)}

/* ═══ SPLIT CONTACT CTA — text left + mini form right ═══ */
.rs-split-cta{padding:70px 0;border-top:1px solid var(--border)}
.rs-split-inner{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.rs-split-text h2{margin-bottom:8px}.rs-split-text p{color:var(--muted);font-size:.9rem;margin-bottom:18px}
.rs-split-text .rs-cta-meta{margin-top:14px}
.rs-cta-meta span{display:block;font-size:.5rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:10px}
.rs-cta-meta a{color:var(--pink)}
.rs-split-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:28px 24px}
.rs-split-form h3{margin-bottom:14px;font-size:1rem}
.rs-mini-form{display:flex;flex-direction:column;gap:10px}
.rs-mini-form input,.rs-mini-form textarea{padding:11px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--font-b);font-size:.86rem;transition:border-color var(--tr)}
.rs-mini-form input:focus,.rs-mini-form textarea:focus{outline:none;border-color:var(--pink)}
.rs-mini-form textarea{resize:vertical;min-height:70px}
@media(max-width:700px){.rs-split-inner{grid-template-columns:1fr}}

/* ═══ Pricing ═══ */
.section{padding:70px 0}
.pg-head{padding:90px 0 32px;border-bottom:1px solid var(--border)}.pg-head h1{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:8px}.pg-head p{color:var(--muted);max-width:480px}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.price-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:28px 22px;display:flex;flex-direction:column;position:relative;transition:all var(--tr)}
.price-card.featured{border-color:var(--pink);box-shadow:0 0 30px var(--glow)}.price-card.featured::before{content:'POPULAR';position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--pink);color:#fff;font-family:var(--font-h);font-size:.42rem;font-weight:700;letter-spacing:2px;padding:4px 14px;border-radius:100px}
.price-card:hover{transform:translateY(-3px)}.price-card h3{font-size:1.1rem;margin-bottom:4px}
.pc-price{font-family:var(--font-h);font-size:1.8rem;font-weight:800;color:var(--pink);margin-bottom:14px}.pc-price small{font-size:.5rem;color:var(--muted);font-weight:400}
.pc-list{flex:1;margin-bottom:16px}.pc-list li{padding:5px 0;border-bottom:1px solid var(--border);font-size:.72rem;color:var(--muted);padding-left:18px;position:relative}.pc-list li::before{content:'✦';position:absolute;left:0;color:var(--pink);font-size:.5rem}
.price-card .btn{width:100%;justify-content:center}@media(max-width:700px){.price-grid{grid-template-columns:1fr}}

/* ═══ Service detail pages ═══ */
.svc-hero{padding:90px 0 32px;border-bottom:1px solid var(--border)}.svc-fprice{font-family:var(--font-h);font-weight:700;color:var(--pink);font-size:.92rem;margin:6px 0 14px}.svc-hero .svc-img{margin-top:16px;border-radius:var(--r);height:240px;object-fit:cover;width:100%;max-width:600px;border:1px solid var(--border)}
.svc-body{max-width:660px;padding:40px 0}.svc-body h3{font-size:1.15rem;color:var(--text);margin:30px 0 10px;padding-top:20px;border-top:1px solid var(--border)}.svc-body h3:first-of-type{border-top:none;padding-top:0}.svc-body h4{font-size:.95rem;color:var(--pink);margin:20px 0 8px}.svc-body h5{font-size:.84rem;color:var(--teal);margin:16px 0 6px;font-weight:600}.svc-body p{color:var(--muted);font-size:.92rem;line-height:1.9}.svc-body ul{margin:10px 0 18px;padding-left:20px}.svc-body ul li{color:var(--muted);font-size:.86rem;padding:4px 0;list-style:none;padding-left:18px;position:relative}.svc-body ul li::before{content:'→';position:absolute;left:0;color:var(--pink);font-size:.72rem}
.svc-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:24px}

/* ═══ Standard form elements ═══ */
.builder-box{max-width:540px;margin:0 auto;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:24px 20px}.addon-stack{display:flex;flex-direction:column;gap:6px;margin-bottom:20px}.addon-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color var(--tr)}.addon-row:hover{border-color:var(--pink)}.addon-row label{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1;font-size:.82rem}.addon-row input[type="checkbox"]{accent-color:var(--pink);width:16px;height:16px}.addon-cost{font-family:var(--font-h);font-weight:700;color:var(--teal);font-size:.74rem}
.sup-block{margin-bottom:20px}.range-bar{display:flex;align-items:center;gap:8px}.range-bar input[type="range"]{flex:1;accent-color:var(--pink)}.range-val{font-family:var(--font-h);font-weight:700;color:var(--teal)}.build-total{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-top:2px solid var(--pink)}.bt-val{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:var(--pink)}
.co-wrap{max-width:460px;margin:0 auto}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group.full{grid-column:1/-1}.form-group label{font-size:.52rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{padding:11px 14px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-family:var(--font-b);font-size:.86rem;transition:border-color var(--tr)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--pink)}@media(max-width:500px){.form-grid{grid-template-columns:1fr}}
.cb-agree{display:flex;align-items:flex-start;gap:8px;margin-top:12px;font-size:.66rem;color:var(--muted)}.cb-agree input{margin-top:2px;accent-color:var(--pink)}.cb-agree a{color:var(--pink)}.order-box{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:18px}.order-box h3{margin-bottom:6px}.ol{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid var(--border);font-size:.8rem;color:var(--muted)}.ol.tot{border-bottom:none;border-top:2px solid var(--pink);margin-top:5px;padding-top:6px;font-weight:700;color:var(--text)}.ol.tot span:last-child{color:var(--pink)}
.about-body{max-width:600px}.about-body p{color:var(--muted);font-size:.92rem}.about-img{border-radius:var(--r);margin-bottom:20px;height:240px;object-fit:cover;width:100%;border:1px solid var(--border)}.vals-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:38px;padding-top:28px;border-top:1px solid var(--border)}.val-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:22px 18px}.val-card h3{color:var(--pink);font-size:.86rem;margin-bottom:6px}.val-card:nth-child(2) h3{color:var(--teal)}.val-card p{color:var(--muted);font-size:.74rem;margin:0}@media(max-width:600px){.vals-row{grid-template-columns:1fr}}
.faq-list{max-width:580px;margin:0 auto}.faq-item{border-bottom:1px solid var(--border)}.faq-q{width:100%;padding:16px 0;background:none;border:none;color:var(--text);font-family:var(--font-h);font-weight:700;font-size:.88rem;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center}.faq-q:hover{color:var(--pink)}.faq-ic{transition:transform var(--tr);color:var(--muted)}.faq-item.open .faq-ic{transform:rotate(45deg);color:var(--pink)}.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}.faq-a-inner{padding:0 0 16px;color:var(--muted);font-size:.86rem;line-height:1.85}
.ct-two{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:start}.ct-info p{color:var(--muted);font-size:.88rem;margin-bottom:12px}.ct-meta span{display:block;font-size:.5rem;font-weight:700;color:var(--muted);letter-spacing:2px;text-transform:uppercase;margin-top:14px}.ct-meta a{color:var(--pink)}.ct-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:22px 18px}@media(max-width:700px){.ct-two{grid-template-columns:1fr}}
.legal{max-width:660px;margin:0 auto}.legal h2{font-family:var(--font-h);font-size:.9rem;font-weight:700;color:var(--text);margin:24px 0 8px}.legal h2:first-child{margin-top:0}.legal p{color:var(--muted);font-size:.82rem;line-height:1.85}.legal a{color:var(--pink)}.legal strong{color:var(--text)}

/* ═══ Footer — elegant minimal ═══ */
.rs-footer{padding:48px 0 20px;border-top:1px solid var(--border)}
.ft-main{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:24px;margin-bottom:28px}
.ft-brand{font-family:var(--font-h);font-size:.92rem;font-weight:800;color:var(--pink);margin-bottom:8px}
.rs-footer p{color:var(--muted);font-size:.58rem;margin-bottom:4px}
.rs-footer h4{font-family:var(--font-h);font-size:.44rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--pink);margin-bottom:10px}
.rs-footer a{display:block;color:var(--muted);font-size:.58rem;margin-bottom:4px;text-decoration:none}.rs-footer a:hover{color:var(--pink)}
.ft-bottom{border-top:1px solid var(--border);padding-top:14px;font-size:.44rem;color:var(--muted);text-align:center}
@media(max-width:700px){.ft-main{grid-template-columns:1fr 1fr}}

/* ═══ Cookie + Chat ═══ */
.cookie-banner{position:fixed;bottom:14px;left:50%;transform:translateX(-50%);z-index:300;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:10px 24px;display:none;align-items:center;gap:14px;font-size:.7rem;color:var(--muted);box-shadow:0 4px 20px rgba(0,0,0,.06)}.cookie-banner.show{display:flex}.cookie-banner a{color:var(--pink)}.cb-btns{display:flex;gap:5px}.cb-btn{padding:6px 14px;border-radius:100px;font-weight:700;font-size:.52rem;border:1px solid var(--border);background:transparent;cursor:pointer;transition:all var(--tr);color:var(--muted)}.cb-accept{border-color:var(--pink);background:var(--pink);color:#fff}.cb-decline:hover{border-color:var(--pink)}
.chat-fab{position:fixed;bottom:18px;right:18px;z-index:250;width:52px;height:52px;border-radius:50%;background:var(--pink);color:#fff;border:none;cursor:pointer;box-shadow:0 6px 20px var(--glow);display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:all var(--tr)}.chat-fab:hover{transform:scale(1.08)}.chat-fab.hide{display:none}
.chat-box{position:fixed;bottom:18px;right:18px;z-index:250;width:340px;max-width:calc(100vw - 24px);background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:0 16px 50px rgba(0,0,0,.08);display:none;flex-direction:column;overflow:hidden;max-height:500px}.chat-box.open{display:flex}
.chat-head{background:var(--pink);color:#fff;padding:14px 16px;display:flex;align-items:center;justify-content:space-between}.chat-head-left{display:flex;align-items:center;gap:8px}.chat-avatar{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:.85rem}.chat-head-info h4{font-size:.76rem;font-weight:700;margin:0;color:#fff}.chat-head-info p{font-size:.46rem;margin:0;opacity:.4}.chat-close{background:none;border:none;color:#fff;font-size:.9rem;cursor:pointer;opacity:.6}.chat-close:hover{opacity:1}
.chat-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:8px;min-height:160px;max-height:280px}.chat-msg{max-width:85%;padding:10px 14px;border-radius:var(--r);font-size:.76rem;line-height:1.5}.chat-msg.bot{background:var(--surface2);color:var(--text);align-self:flex-start}.chat-msg.user{background:var(--pink);color:#fff;align-self:flex-end}.msg-time{font-size:.42rem;color:var(--muted);margin-top:3px;display:block}
.msg-feedback{display:flex;gap:5px;margin-top:5px}.fb-btn{background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:2px 8px;font-size:.46rem;cursor:pointer;transition:all var(--tr);display:flex;align-items:center;gap:3px;color:var(--muted)}.fb-btn:hover{border-color:var(--pink)}.fb-btn.voted{background:var(--pink);color:#fff;border-color:var(--pink)}
.chat-qr{display:flex;flex-wrap:wrap;gap:5px;padding:0 14px 10px}.qr-btn{padding:4px 10px;border-radius:100px;border:1px solid var(--border);background:transparent;font-size:.5rem;font-weight:600;color:var(--pink);cursor:pointer;transition:all var(--tr)}.qr-btn:hover{background:var(--pink);color:#fff}
.chat-typing{align-self:flex-start;padding:10px 14px;background:var(--surface2);border-radius:var(--r);font-size:.62rem;color:var(--muted);display:none}.chat-typing.show{display:block}.chat-typing span{animation:tDot 1.4s infinite;display:inline-block}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes tDot{0%,60%,100%{opacity:.3}30%{opacity:1}}
.chat-input-bar{display:flex;gap:6px;padding:12px;border-top:1px solid var(--border)}.chat-input{flex:1;padding:10px 14px;border:1px solid var(--border);border-radius:100px;font-family:var(--font-b);font-size:.78rem;color:var(--text);background:var(--bg);outline:none;transition:border-color var(--tr)}.chat-input:focus{border-color:var(--pink)}.chat-send{padding:10px 16px;background:var(--pink);color:#fff;border:none;border-radius:100px;font-weight:700;font-size:.58rem;cursor:pointer}
.res-page{min-height:60vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 28px 40px}.res-icon{font-size:2.5rem;margin-bottom:14px}.res-page h1{font-size:clamp(1.6rem,3vw,2.4rem);margin-bottom:8px}.res-page p{color:var(--muted);max-width:360px;margin:0 auto 22px}
.fade-in{opacity:0;transform:translateY(10px);transition:opacity .6s ease,transform .6s ease}.fade-in.visible{opacity:1;transform:translateY(0)}.text-center{text-align:center}.mt-4{margin-top:22px}.alert{padding:10px 14px;border-radius:var(--r);margin-bottom:10px;font-size:.76rem}.alert-error{background:var(--glow);border:1px solid rgba(190,24,93,.1);color:var(--pink-dk)}
