:root{--violet-400:#a78bfa;--violet-500:#7c3aed;--violet-600:#6d28d9;--teal-400:#2dd4bf;--teal-500:#14b8a6;--white:#fff;--gray-50:#fafaf9;--gray-100:#f5f5f4;--gray-200:#e7e5e4;--gray-300:#d6d3d1;--gray-400:#a8a29e;--gray-500:#78716c;--gray-600:#57534e;--gray-700:#44403c;--gray-800:#292524;--gray-900:#1c1917;--gray-950:#0f0e0d;--green:#10b981;--green-light:#10b98114;--red-500:#ef4444;--red-light:#ef44440f;--red-border:#ef444426;--amber-50:#fffbeb;--amber-200:#fde68a;--blue-400:#60a5fa;--indigo:#6366f1;--glass-bg:#fff9;--glass-border:#fff6;--glass-shadow:0 8px 32px #0000000f;--gradient-primary:linear-gradient(135deg, var(--violet-500), var(--teal-400));--gradient-bg:radial-gradient(circle, #7c3aed08 1px, transparent 1px), radial-gradient(ellipse 80% 50% at 50% 0%, #7c3aed0d 0%, transparent 60%), radial-gradient(ellipse 60% 40% at 80% 30%, #2dd4bf0a 0%, transparent 50%);--gradient-bg-size:24px 24px, 100% 100%, 100% 100%;--font-family:"Inter", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--radius-2xl:1.5rem;--radius-full:999px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s cubic-bezier(.16, 1, .3, 1)}*{box-sizing:border-box}body{font-family:var(--font-family);color:var(--gray-800);background:var(--gradient-bg);background-size:var(--gradient-bg-size);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f7f5f3;background-attachment:fixed;margin:0}#root{min-height:100vh}.app-shell{background:var(--gradient-bg);background-size:var(--gradient-bg-size);background-color:#f7f5f3;min-height:100vh}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.btn{border-radius:var(--radius-full);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);border:none;justify-content:center;align-items:center;gap:.5rem;font-weight:600;text-decoration:none;display:inline-flex;position:relative}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn--primary{background:var(--gradient-primary);color:var(--white);padding:.75rem 1.75rem;box-shadow:0 4px 20px #7c3aed40,0 2px 6px #7c3aed1a}.btn--primary:hover:not(:disabled){box-shadow:0 8px 28px #7c3aed4d,0 4px 10px #7c3aed26}.btn--ghost{background:var(--glass-bg);-webkit-backdrop-filter:blur(8px);color:var(--gray-700);border:1px solid var(--gray-200);padding:.625rem 1.25rem}.btn--ghost:hover:not(:disabled){border-color:var(--gray-300);background:#ffffffd9}.btn--danger{background:var(--red-light);color:var(--red-500);border:1px solid var(--red-border);padding:.625rem 1.25rem}.btn--danger:hover:not(:disabled){background:#ef44441a}.input{border:1.5px solid var(--gray-200);border-radius:var(--radius-full);width:100%;font-family:var(--font-family);font-size:var(--font-size-base);background:var(--white);color:var(--gray-800);transition:all var(--transition-fast);padding:.8125rem 1rem}.input::placeholder{color:var(--gray-400)}.input:focus{border-color:var(--violet-400);outline:none;box-shadow:0 0 0 3px #7c3aed1a}.input-group{position:relative}.input-group .input{padding-left:2.875rem}.input-group__icon{color:var(--gray-400);pointer-events:none;display:flex;position:absolute;top:50%;left:1rem;transform:translateY(-50%)}.auth-page{background:var(--gradient-bg);background-size:var(--gradient-bg-size);background-color:#f7f5f3;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;display:flex}.auth-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);width:100%;max-width:25rem;box-shadow:var(--glass-shadow);padding:2.5rem 2rem;animation:.5s cubic-bezier(.16,1,.3,1) fadeInUp}.auth-logo{justify-content:center;align-items:center;margin-bottom:2rem;display:flex}.auth-logo__icon{border-radius:var(--radius-lg);background:var(--gradient-primary);width:3.25rem;height:3.25rem;color:var(--white);justify-content:center;align-items:center;display:flex;box-shadow:0 6px 20px #7c3aed4d}.auth-card h1{font-size:var(--font-size-2xl);letter-spacing:-.02em;text-align:center;color:var(--gray-900);margin:0 0 .5rem;font-weight:800}.auth-card>p{color:var(--gray-500);text-align:center;font-size:var(--font-size-base);margin:0 0 2rem;line-height:1.55}.auth-card--center{text-align:center}.auth-card__actions{justify-content:center;margin-top:1.5rem;display:flex}.auth-card__actions--stack{flex-direction:column;align-items:center;gap:.75rem}.auth-form{flex-direction:column;gap:.875rem;display:flex}.auth-forgot{text-align:right;font-size:var(--font-size-sm);margin:-.25rem 0 0}.auth-forgot a{color:var(--violet-500);font-weight:600;text-decoration:none}.auth-forgot a:hover{color:var(--violet-600);text-decoration:underline}.auth-footer{font-size:var(--font-size-sm);text-align:center;color:var(--gray-500);margin-top:3rem;padding-top:.25rem}.auth-footer a{color:var(--violet-500);transition:color var(--transition-fast);font-weight:600;text-decoration:none}.auth-footer a:hover{color:var(--violet-600)}.auth-error{color:var(--red-500);font-size:var(--font-size-sm);margin:0}.auth-hint{color:var(--gray-500);margin:0;font-size:.8125rem}.auth-success{color:var(--green);font-size:var(--font-size-base);margin:0}.auth-info{font-size:var(--font-size-base);color:var(--gray-500);line-height:1.55}.auth-actions{flex-wrap:wrap;justify-content:center;align-items:center;gap:.75rem;margin-top:1.5rem;display:flex}.auth-actions .btn{min-width:9rem;padding:.75rem 1.5rem}.error-banner{background:var(--red-light);border:1px solid var(--red-border);color:var(--red-500);border-radius:var(--radius-full);font-size:var(--font-size-sm);margin-bottom:1.25rem;padding:.875rem 1.5rem;font-weight:500;animation:.3s fadeIn}.pairing-page{background:var(--gradient-bg);background-size:var(--gradient-bg-size);background-color:#f7f5f3;justify-content:center;align-items:center;min-height:100vh;padding:2rem 1.5rem;display:flex}.pairing-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);width:100%;max-width:27rem;box-shadow:var(--glass-shadow);padding:2.5rem 2rem;animation:.5s cubic-bezier(.16,1,.3,1) fadeInUp}.pairing-card__icon{background:var(--gradient-primary);width:3.75rem;height:3.75rem;color:var(--white);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 1.75rem;display:flex;box-shadow:0 10px 28px #7c3aed40}.pairing-card h1{font-size:var(--font-size-2xl);letter-spacing:-.02em;text-align:center;color:var(--gray-900);margin:0 0 .75rem;font-weight:800}.pairing-card>p{color:var(--gray-500);text-align:center;margin:0 0 2rem;line-height:1.65}.pairing-form{flex-direction:column;gap:.875rem;display:flex}.pairing-code-input{letter-spacing:.35em;text-align:center;background:var(--gray-50);border:2px dashed var(--gray-200);padding:1.125rem 1rem;font-size:1.75rem;font-weight:700;border-radius:var(--radius-2xl)!important}.pairing-code-input:focus{border-style:solid;border-color:var(--violet-400)}.pairing-code-display{border:2px dashed var(--gray-200);border-radius:var(--radius-2xl);background:var(--gray-50);flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.25rem;padding:1.5rem;display:flex}.pairing-code-display__code{letter-spacing:.3em;background:var(--gradient-primary);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:800}.pairing-code-display__meta{font-size:var(--font-size-sm);color:var(--gray-500)}.dashboard{max-width:72rem;margin:0 auto;padding:2rem 1.5rem;animation:.5s cubic-bezier(.16,1,.3,1) fadeInUp}@media (width>=768px){.dashboard{padding:2.5rem 2rem}}.dashboard-layout{align-items:start;gap:1.5rem;display:grid}@media (width>=960px){.dashboard-layout{grid-template-columns:minmax(17rem,22rem) minmax(0,1fr)}}.dashboard-sidebar,.dashboard-main{flex-direction:column;gap:1.5rem;min-width:0;display:flex}.dashboard-sidebar .panel,.dashboard-main .panel{margin-bottom:0}.panel--profile .dashboard-actions{margin-top:1rem}.panel__lede{color:var(--gray-500);font-size:var(--font-size-sm);margin:.5rem 0 1rem;line-height:1.6}.panel__note{color:var(--gray-500);font-size:var(--font-size-xs);margin:1rem 0 .75rem;line-height:1.5}.panel__header--compact{margin-bottom:0}.panel__header--compact h2{font-size:var(--font-size-lg);color:var(--gray-800);margin:0;font-weight:700}.insights-section{padding-top:.25rem}.insights-section>.panel__header{margin-bottom:.5rem}.profile-card{align-items:center;gap:.875rem;margin-top:.5rem;display:flex}.profile-card__avatar{background:var(--gradient-primary);width:3rem;height:3rem;color:var(--white);font-weight:700;font-size:var(--font-size-base);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.profile-card__info{flex-direction:column;gap:.125rem;min-width:0;display:flex}.profile-card__info strong{color:var(--gray-900);font-size:var(--font-size-base)}.profile-card__info span{color:var(--gray-500);font-size:var(--font-size-sm);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.companion-list{flex-direction:column;gap:.5rem;margin-bottom:.5rem;display:flex}.companion-list__item{border:1.5px solid var(--gray-200);border-radius:var(--radius-lg);background:var(--white);cursor:pointer;text-align:left;width:100%;font-family:var(--font-family);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);align-items:flex-start;gap:.75rem;padding:.875rem 1rem;display:flex}.companion-list__item:hover{border-color:var(--violet-400)}.companion-list__item--selected{border-color:var(--violet-500);box-shadow:0 0 0 3px #7c3aed1a}.companion-list__avatar{width:2.5rem;height:2.5rem;color:var(--violet-600);font-weight:700;font-size:var(--font-size-sm);background:linear-gradient(135deg,#7c3aed1f,#2dd4bf1a);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.companion-list__body{flex-direction:column;flex:1;gap:.125rem;min-width:0;display:flex}.companion-list__name{color:var(--gray-900);font-weight:600;font-size:var(--font-size-sm)}.companion-list__meta{color:var(--gray-500);font-size:var(--font-size-xs);line-height:1.4}.companion-list__status{font-size:var(--font-size-xs);border-radius:var(--radius-full);flex-shrink:0;padding:.2rem .5rem;font-weight:600}.companion-list__status--active{background:var(--green-light);color:var(--green)}.companion-list__status--paused{background:var(--amber-50);color:var(--gray-600)}.question-form{border-bottom:1px solid var(--gray-200);margin-bottom:1.25rem;padding-bottom:1.25rem}.question-form__row{flex-direction:column;gap:.75rem;display:flex}@media (width>=640px){.question-form__row{flex-direction:row;align-items:flex-end}}.question-form__input{border:1.5px solid var(--gray-200);border-radius:var(--radius-xl);width:100%;min-height:3.25rem;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--gray-800);resize:vertical;background:var(--white);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex:1;padding:.875rem 1rem}.question-form__input:focus{border-color:var(--violet-400);outline:none;box-shadow:0 0 0 3px #7c3aed1a}.question-form__submit{flex-shrink:0}.question-form__sent{color:var(--green);font-size:var(--font-size-sm);margin:.75rem 0 0}.insights-toolbar{flex-direction:column;gap:.5rem;margin-bottom:.625rem;display:flex}@media (width>=640px){.insights-toolbar{flex-flow:wrap;justify-content:space-between;align-items:center}}.insights-toolbar__single{color:var(--gray-500);font-size:var(--font-size-sm);margin:0}.companion-filter{font-size:var(--font-size-sm);color:var(--gray-600);align-items:center;gap:.5rem;display:flex}.companion-filter select{border:1.5px solid var(--gray-200);border-radius:var(--radius-full);background:var(--white);font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--gray-800);padding:.5rem .75rem}.insight-list{flex-direction:column;gap:.5rem;display:flex}.dashboard-header{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);margin-bottom:1.5rem;padding:1.75rem 2rem}.dashboard-header__top{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.dashboard-header__avatar{background:var(--gradient-primary);width:3.25rem;height:3.25rem;color:var(--white);font-weight:700;font-size:var(--font-size-lg);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 14px #7c3aed33}.dashboard-header__info h1{font-size:var(--font-size-xl);color:var(--gray-900);margin:0;font-weight:700}.dashboard-header__info p{color:var(--gray-500);font-size:var(--font-size-sm);margin:.125rem 0 0}.dashboard-actions{flex-wrap:wrap;gap:.5rem;display:flex}.tier-banner{border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--violet-600);text-align:center;background:linear-gradient(135deg,#7c3aed0f,#2dd4bf0a);border:1px solid #7c3aed1a;margin-bottom:1.5rem;padding:.875rem 1.5rem;font-weight:500}.panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-2xl);box-shadow:var(--glass-shadow);margin-bottom:1.5rem;padding:1.75rem 2rem}.panel__header{align-items:center;gap:.75rem;margin-bottom:.5rem;display:flex}.panel__header-icon{border-radius:var(--radius-md);width:2.25rem;height:2.25rem;color:var(--violet-500);background:linear-gradient(135deg,#7c3aed1a,#2dd4bf0f);flex-shrink:0;justify-content:center;align-items:center;display:flex}.panel h2{font-size:var(--font-size-lg);color:var(--gray-800);margin:0;font-weight:700}.panel>p,.panel>form>p{color:var(--gray-500);font-size:var(--font-size-base);margin:.5rem 0 1.25rem;line-height:1.65}.panel textarea{border:1.5px solid var(--gray-200);border-radius:var(--radius-xl);width:100%;min-height:7rem;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--gray-800);resize:vertical;background:var(--white);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:1rem 1.125rem}.panel textarea:focus{border-color:var(--violet-400);outline:none;box-shadow:0 0 0 3px #7c3aed1a}.tabs{background:var(--gray-100);border-radius:var(--radius-full);flex-wrap:wrap;gap:.25rem;width:fit-content;margin:.75rem 0 1.5rem;padding:.25rem;display:flex}.tab{border-radius:var(--radius-full);cursor:pointer;font-family:var(--font-family);font-size:var(--font-size-sm);color:var(--gray-500);transition:all var(--transition-base);background:0 0;border:none;padding:.5rem 1.125rem;font-weight:500}.tab:hover{color:var(--gray-700)}.tab--active{background:var(--white);color:var(--violet-600);font-weight:600;box-shadow:0 1px 4px #00000014}.insight-card{border:1px solid var(--gray-200);border-radius:var(--radius-md);background:var(--white);transition:all var(--transition-base);border-left-width:3px;margin-bottom:0;padding:.625rem .875rem}.insight-card:hover{transform:translate(3px);box-shadow:0 4px 14px #0000000a}.insight-card--health{border-left-color:var(--green)}.insight-card--memory{border-left-color:var(--violet-500)}.insight-card--interest{border-left-color:var(--blue-400)}.insight-card__label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--gray-500);margin-bottom:.2rem;font-weight:700}.insight-card p{line-height:1.45;font-size:var(--font-size-sm);margin:0}.voice-topbar{justify-content:flex-end;width:100%;max-width:28rem;margin-bottom:1rem;display:flex}.profile-chip{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);align-items:center;gap:.5rem;padding:.375rem 1rem .375rem .375rem;font-weight:500;display:inline-flex}.profile-chip__avatar{background:var(--gradient-primary);width:2rem;height:2rem;color:var(--white);border-radius:50%;justify-content:center;align-items:center;font-size:.8125rem;font-weight:700;display:flex}:is(html:has(.entry-page),body:has(.entry-page)){height:100%;overflow:hidden}.entry-page{background:#fafaf9;width:100%;height:100dvh;max-height:100dvh;display:flex;position:relative;overflow:hidden}.entry-divider{z-index:2;background:linear-gradient(#0000,#7c3aed26 20%,#2dd4bf26 80%,#0000);flex-shrink:0;width:1px}.entry-panel{cursor:pointer;text-align:left;min-width:0;min-height:0;font:inherit;color:inherit;border:none;flex:1;justify-content:center;align-items:center;padding:clamp(1.5rem,3vw,2.5rem) clamp(1.25rem,2.5vw,2rem);transition:background-color .2s,box-shadow .2s;display:flex;position:relative;overflow:hidden}.entry-panel:hover:not(:disabled){z-index:1}.entry-panel:disabled{cursor:wait;opacity:.85}.entry-panel:focus-visible{outline-offset:-3px;z-index:3;outline:3px solid #7c3aed}.entry-panel--companion{background:radial-gradient(circle,#7c3aed0d 1px,#0000 1px) 0 0/24px 24px,#fafaf9 linear-gradient(145deg,#7c3aed1f 0%,#fffffff2 45%,#2dd4bf1a 100%) 0 0/100% 100%}.entry-panel--companion:hover:not(:disabled){box-shadow:inset 0 0 80px #7c3aed14}.entry-panel__blob{filter:blur(80px);opacity:.55;pointer-events:none;border-radius:50%;position:absolute}.entry-panel__blob--1{background:#7c3aed1f;width:min(420px,80%);height:min(420px,80%);top:-12%;left:-8%}.entry-panel__blob--2{background:#2dd4bf1a;width:min(320px,60%);height:min(320px,60%);bottom:-8%;right:-8%}.entry-panel__blob--3{background:#60a5fa14;width:min(240px,45%);height:min(240px,45%);top:40%;right:10%}.entry-panel--caregiver{background:#f5f5f4 linear-gradient(160deg,#29252408 0%,#fffffffa 40%,#7c3aed0f 100%)}.entry-panel--caregiver:hover:not(:disabled){box-shadow:inset 0 0 60px #2925240d}.entry-panel__content{z-index:1;max-width:22rem;position:relative}.entry-panel__icon{border-radius:1rem;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;margin-bottom:1.5rem;display:inline-flex}.entry-panel__icon--warm{color:#7c3aed;background:linear-gradient(135deg,#7c3aed26,#2dd4bf33)}.entry-panel__icon--care{color:#44403c;background:#29252414}.entry-panel h1{letter-spacing:-.03em;color:#1c1917;margin:0 0 .75rem;font-size:clamp(1.35rem,2.5vw,1.875rem);font-weight:800;line-height:1.2}.entry-panel p{color:#57534e;margin:0 0 1.75rem;font-size:clamp(.9375rem,1.5vw,1rem);line-height:1.65}.entry-panel__cta{color:#7c3aed;align-items:center;gap:.5rem;font-size:.9375rem;font-weight:600;display:inline-flex}.entry-panel__cta--caregiver{color:#292524}.entry-error{color:#b91c1c;z-index:5;text-align:center;background:#fef2f2;border-radius:.5rem;max-width:min(90vw,24rem);margin:0;padding:.625rem 1rem;font-size:.875rem;position:absolute;bottom:1.25rem;left:50%;transform:translate(-50%)}@media (width<=768px){:is(html:has(.entry-page),body:has(.entry-page)){height:auto;overflow:auto}.entry-page{flex-direction:column;height:auto;min-height:100dvh;max-height:none;overflow:visible}.entry-divider{width:100%;height:1px}.entry-panel{min-height:50dvh;padding:2rem 1.5rem}}@keyframes pulse-glow{0%,to{box-shadow:0 0 #7c3aed4d,0 20px 50px #7c3aed26}50%{box-shadow:0 0 0 20px #7c3aed00,0 20px 50px #7c3aed33}}@keyframes pulse-glow-listening{0%,to{box-shadow:0 0 #ef444459,0 20px 50px #ef444426}50%{box-shadow:0 0 0 22px #ef444400,0 20px 50px #ef444433}}@keyframes ring-expand{0%{opacity:.5;transform:scale(.95)}to{opacity:0;transform:scale(1.45)}}@keyframes float-gentle{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.voice-screen{background:radial-gradient(circle,#7c3aed08 1px,#0000 1px) 0 0/24px 24px,linear-gradient(#f7f5f3 0%,#f0ecff 45%,#ecfdf5 100%) 0 0/100% 100%;flex-direction:column;align-items:center;min-height:100vh;padding:1.5rem 1.5rem 2.5rem;display:flex;position:relative;overflow:hidden}.voice-screen:before{content:"";pointer-events:none;background:radial-gradient(circle,#7c3aed0f 0%,#0000 65%);border-radius:50%;width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%)}.voice-header{text-align:center;z-index:1;margin-bottom:1.5rem;animation:.6s cubic-bezier(.16,1,.3,1) fadeInUp;position:relative}.voice-header h1{letter-spacing:-.035em;background:linear-gradient(135deg,#7c3aed,#2dd4bf);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:0;font-size:2.25rem;font-weight:800}.voice-subtitle{color:#a8a29e;margin:.375rem 0 0;font-size:1rem;font-weight:500}.voice-stage{z-index:1;flex-direction:column;flex:1;justify-content:center;align-items:center;width:100%;max-width:28rem;display:flex;position:relative}.voice-button{color:#fff;cursor:pointer;letter-spacing:.02em;z-index:2;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:none;border-radius:50%;justify-content:center;align-items:center;width:11rem;height:11rem;font-family:Inter,system-ui,sans-serif;font-size:1.125rem;font-weight:700;transition:all .3s cubic-bezier(.16,1,.3,1);animation:2.5s ease-in-out infinite pulse-glow;display:flex;position:relative}.voice-button:hover:not(:disabled){transform:scale(1.04)}.voice-button:active:not(:disabled){transform:scale(.97)}.voice-button:disabled{opacity:.5;cursor:not-allowed;animation:none}.voice-button--listening{background:linear-gradient(135deg,#ef4444,#dc2626);animation:1.5s ease-in-out infinite pulse-glow-listening}.voice-button--processing,.voice-button--speaking{background:linear-gradient(135deg,#7c3aed,#2dd4bf);animation:2s ease-in-out infinite float-gentle}.voice-button__pulse{pointer-events:none;border:2px solid #7c3aed2e;border-radius:50%;animation:2s ease-out infinite ring-expand;position:absolute;inset:-1rem}.voice-button--listening .voice-button__pulse{border-color:#ef44444d;animation-duration:1.2s}.voice-button--processing .voice-button__pulse,.voice-button--speaking .voice-button__pulse{border-color:#2dd4bf33}.voice-button__label{z-index:1;justify-content:center;align-items:center;display:flex;position:relative}.voice-status{text-align:center;color:#44403c;margin:2.25rem 0 .5rem;font-size:1.125rem;font-weight:600;animation:.4s fadeInUp}.voice-remaining{color:#a8a29e;margin:0;font-size:.9375rem;font-weight:500}.voice-caption{-webkit-backdrop-filter:blur(16px);border-radius:var(--radius-2xl,1.5rem);text-align:center;z-index:1;background:#fff9;border:1px solid #ffffff59;width:100%;max-width:34rem;margin-top:2.5rem;padding:1.25rem 1.75rem;animation:.4s cubic-bezier(.16,1,.3,1) fadeInUp;position:relative;box-shadow:0 4px 20px #0000000a}.voice-caption p{color:#44403c;margin:0;font-size:1rem;line-height:1.65}.voice-footer{z-index:1;gap:2rem;margin-top:auto;padding-top:2.5rem;display:flex;position:relative}.voice-footer a{color:#a8a29e;font-size:.875rem;font-weight:500;text-decoration:none;transition:color .15s}.voice-footer a:hover{color:#78716c}
