:root{--color-bg: #f5f0e6;--color-surface: #fdfaf4;--color-surface2: #f5f0e6;--color-border: #e4d8c0;--color-border2: #c8b898;--color-text: #1a2e1a;--color-text-muted: #7a6040;--color-dim: #9a8060;--color-accent: #3d6428;--color-accent-dark: #2e4a1e;--color-accent-light: #e8f5d0;--color-danger: #ef4444;--color-danger-light: #fee2e2;--color-warning: #f59e0b;--color-warning-light: #fef3c7;--color-ok: #22c55e;--color-progress-dark: #1c1c2e;--color-white: #ffffff;--color-nav: #2e4a1e;--color-nav-text: #c8e6a0;--color-nav-muted: rgba(200, 230, 160, .55);--color-nav-pill: rgba(200, 230, 160, .18);--color-cream: #f5f0e6;--color-cream-dark: #e4d8c0;--color-forest: #3d6428;--color-forest-deep: #2e4a1e;--color-forest-muted: #7a6040;--color-text-on-dark: rgba(255, 255, 255, .92);--color-text-muted-on-dark: rgba(255, 255, 255, .65);--color-danger-soft: #fee2e2;--font-sans: "Plus Jakarta Sans", system-ui, -apple-system, sans-serif;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--shadow-soft: 0 1px 3px rgba(30, 50, 20, .08), 0 1px 2px rgba(30, 50, 20, .05);--shadow-card: 0 4px 16px rgba(30, 50, 20, .1);--shadow-nav: 0 1px 0 rgba(200, 230, 160, .1);font-family:var(--font-sans);line-height:1.6;font-weight:400;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%}button,input,select,textarea{font-family:inherit}code{font-size:.85em;background:var(--color-surface2);padding:.15em .45em;border-radius:4px}h1,h2,h3{font-weight:700;letter-spacing:-.01em;color:var(--color-text)}.section-title{margin:0 0 1rem;font-size:1.125rem;font-weight:700;color:var(--color-text)}.section-title--sm{font-size:1rem}.btn-primary,.btn-secondary{border:none;border-radius:var(--radius-pill);padding:.5rem 1.25rem;font-size:.8125rem;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-dark)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border2)}.btn-secondary:hover:not(:disabled){border-color:var(--color-accent)}.generate-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;box-shadow:var(--shadow-soft)}.generate-panel h2{margin:0 0 .75rem}.generate-panel-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end}.generate-panel-row label{display:flex;flex-direction:column;gap:.35rem;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);min-width:10rem}.generate-panel-row input,.generate-panel-row select{padding:.5rem .75rem;border:1px solid var(--color-border2);border-radius:var(--radius-sm);font-size:.875rem;font-family:inherit;background:var(--color-surface);color:var(--color-text)}.generate-panel-row input:focus,.generate-panel-row select:focus{outline:none;border-color:var(--color-accent)}.generate-panel-hint,.generate-panel-progress{font-size:.8125rem;color:var(--color-text-muted);margin:.5rem 0 0}.generate-panel-error{color:var(--color-danger)}.h-scroll{width:100%;min-width:0;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-accent) var(--color-border)}.h-scroll::-webkit-scrollbar{height:8px}.h-scroll::-webkit-scrollbar-track{margin:0 .25rem;border-radius:var(--radius-pill);background:linear-gradient(90deg,transparent,var(--color-surface2) 8%,var(--color-surface2) 92%,transparent)}.h-scroll::-webkit-scrollbar-thumb{border-radius:var(--radius-pill);background:linear-gradient(180deg,#4a7a32 0%,var(--color-accent) 50%,var(--color-accent-dark) 100%);border:2px solid var(--color-surface2);box-shadow:inset 0 1px #fff3}.h-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#568a3c 0%,#4a7a32 50%,var(--color-accent) 100%)}.h-scroll::-webkit-scrollbar-thumb:active{background:var(--color-accent-dark)}.waveform-visualizer{display:flex;align-items:center;gap:3px;height:48px}.waveform-bar{flex:1;border-radius:999px;background:var(--color-nav-text);min-height:4px;max-height:48px}.app-icon{display:inline-block;flex-shrink:0;color:var(--color-accent);vertical-align:middle}.app-icon--on-dark{color:var(--color-nav-text)}.app-icon--white{color:#fff}.empty-state-icon{display:grid;place-items:center;width:4rem;height:4rem;margin:0 auto .75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:50%;box-shadow:var(--shadow-soft)}.empty-state-icon .app-icon{width:1.75rem;height:1.75rem}.app-header{position:sticky;top:0;z-index:100;background:var(--color-nav);border-bottom:1px solid rgba(200,230,160,.15);box-shadow:0 2px 12px #14230f2e}.app-header-inner{display:flex;align-items:center;justify-content:space-between;gap:1rem;max-width:1280px;margin:0 auto;padding:.75rem 1.5rem}.app-header-brand{position:relative;display:flex;align-items:center;gap:.75rem;min-width:0}.app-header-company-trigger{display:flex;align-items:center;gap:.625rem;margin:0;padding:.35rem .5rem .35rem .35rem;border:1px solid rgba(200,230,160,.28);border-radius:var(--radius-pill);background:#ffffff0f;font:inherit;color:inherit;cursor:pointer;max-width:min(100%,240px);transition:background .18s ease,border-color .18s ease,box-shadow .18s ease,transform .18s ease}.app-header-company-trigger:hover{background:#ffffff1c;border-color:#c8e6a073;box-shadow:0 2px 10px #0000001f}.app-header-company-trigger:focus-visible{outline:none;border-color:#c8e6a0bf;box-shadow:0 0 0 3px #c8e6a038}.app-header-company-trigger.is-open{background:#ffffff24;border-color:#c8e6a08c;box-shadow:0 4px 14px #00000029}.app-header-logo{display:flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border-radius:50%;background:var(--color-nav-text);color:var(--color-nav);font-size:.75rem;font-weight:700;flex-shrink:0}.app-header-brand-text{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;min-width:0;text-align:left}.app-header-company-chevron{display:flex;align-items:center;justify-content:center;width:1.375rem;height:1.375rem;margin-right:.125rem;border-radius:999px;background:#c8e6a024;color:var(--color-nav-text);flex-shrink:0;transition:transform .18s ease,background .18s ease}.app-header-company-trigger:hover .app-header-company-chevron,.app-header-company-trigger.is-open .app-header-company-chevron{background:#c8e6a03d}.app-header-company-trigger.is-open .app-header-company-chevron{transform:rotate(180deg)}.app-header-company{margin:0;font-size:.875rem;font-weight:700;letter-spacing:-.01em;color:var(--color-nav-text);line-height:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.app-header-company-menu{position:absolute;top:calc(100% + .5rem);left:0;z-index:200;min-width:11rem;max-width:16rem;max-height:16rem;overflow-y:auto;margin:0;padding:.375rem;list-style:none;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:0 8px 24px #14230f33}.app-header-company-option{display:block;width:100%;padding:.5rem .625rem;border:none;border-radius:calc(var(--radius-sm) - 2px);background:transparent;color:var(--color-text);font-family:inherit;font-size:.8125rem;text-align:left;cursor:pointer}.app-header-company-option:hover{background:var(--color-bg)}.app-header-company-option.active{background:#16a34a1f;color:var(--color-accent);font-weight:600}.app-header-subtitle{margin:0;font-size:.625rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;color:var(--color-nav-muted);line-height:1}.app-header-company-trigger .app-header-subtitle{color:#c8e6a0b8}.app-header-company-trigger:hover .app-header-subtitle,.app-header-company-trigger.is-open .app-header-subtitle{color:#e6f5d2eb}.app-header-nav{display:flex;align-items:center;gap:.25rem}.app-header-tab{border:none;background:transparent;color:var(--color-nav-muted);font-size:.875rem;font-weight:500;font-family:inherit;padding:.375rem 1rem;border-radius:var(--radius-pill);cursor:pointer;text-decoration:none;display:inline-block;position:relative;transition:color .15s}.app-header-tab:hover:not(.active){color:var(--color-nav-text);background:transparent}.app-header-tab.active{color:var(--color-nav-text);background:transparent}.nav-active-pill{position:absolute;inset:0;border-radius:var(--radius-pill);background:var(--color-nav-pill);z-index:0}.nav-tab-label{position:relative;z-index:1}.app-header-right{display:flex;align-items:center;gap:.75rem}.app-header-xp{display:flex;flex-direction:column;align-items:flex-end;gap:.2rem}.app-header-xp-label{display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;color:var(--color-nav-text);white-space:nowrap}.xp-bolt-icon{color:var(--color-accent)}.xp-sep,.xp-level-name{color:var(--color-nav-muted);font-weight:400}.app-header-xp-bar{width:6rem;height:4px;background:#c8e6a026;border-radius:var(--radius-pill);overflow:hidden}.app-header-xp-fill{height:100%;background:var(--color-nav-text);border-radius:var(--radius-pill)}.app-header-company-select{font-family:inherit;font-size:.8125rem;padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);cursor:pointer}.app-header-company-select:focus{outline:none;border-color:var(--color-accent)}@media(max-width:640px){.app-header-inner{flex-wrap:wrap;gap:.5rem}.app-header-nav{order:3;width:100%;justify-content:center}.app-header-right{margin-left:auto}}.persona-gen-banner{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;padding:.5rem 1.5rem;background:#16a34a26;border-top:1px solid rgba(200,230,160,.2);color:var(--color-nav-text);font-size:.8125rem}.persona-gen-banner-spinner{width:.875rem;height:.875rem;border:2px solid rgba(255,255,255,.35);border-top-color:var(--color-nav-text);border-radius:50%;animation:persona-gen-spin .7s linear infinite;flex-shrink:0}.persona-gen-banner-text{flex:1;min-width:0}.persona-gen-banner-meta{display:flex;align-items:center;gap:.75rem;margin-left:auto;flex-shrink:0}.persona-gen-banner-time{font-variant-numeric:tabular-nums;font-weight:600;font-size:.75rem;color:#ffffffe6}.persona-gen-banner-step{color:#ffffffbf;font-size:.75rem;max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes persona-gen-spin{to{transform:rotate(360deg)}}.practice-call{width:100%;background:var(--color-bg);min-height:100vh}.page-content{max-width:860px;margin:0 auto;padding:2rem 1.5rem 3rem}.page-hint,.page-error{font-size:.875rem;color:var(--color-text-muted);margin:.75rem 0}.page-error{color:var(--color-danger)}.practice-page-header{margin-bottom:1.75rem}.practice-page-eyebrow{margin:0 0 .35rem;font-size:.6875rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent)}.practice-page-title{margin:0;font-size:clamp(1.625rem,4vw,2rem);font-weight:800;letter-spacing:-.02em;color:var(--color-text);line-height:1.15}.practice-page-subtitle{margin:.5rem 0 0;max-width:36rem;font-size:.9375rem;line-height:1.55;color:var(--color-text-muted)}.settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin:1rem 0;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:.75rem}.settings-panel label{display:flex;flex-direction:column;gap:.3rem;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.settings-panel input{padding:.5rem .75rem;border:1px solid var(--color-border2);border-radius:var(--radius-sm);font-size:.875rem;background:var(--color-surface);font-family:inherit}.settings-panel input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #16a34a1a}.practice-empty{margin-bottom:1.5rem}.practice-empty__card{position:relative;overflow:hidden;text-align:center;padding:2.25rem 1.75rem 2rem;background:linear-gradient(165deg,var(--color-surface) 0%,#f8f4eb 55%,var(--color-accent-light) 100%);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.practice-empty__card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,var(--color-accent-dark),var(--color-accent),#6b9e4a)}.practice-empty__visual{display:flex;justify-content:center;margin-bottom:1rem}.practice-empty__icon{display:grid;place-items:center;width:4.5rem;height:4.5rem;background:var(--color-white);border:1px solid var(--color-border);border-radius:50%;box-shadow:var(--shadow-soft)}.practice-empty__icon .app-icon{width:2rem;height:2rem}.practice-empty__title{margin:0;font-size:1.25rem;font-weight:800;letter-spacing:-.02em;color:var(--color-text)}.practice-empty__body{margin:.65rem auto 0;max-width:22rem;font-size:.9375rem;line-height:1.55;color:var(--color-text-muted)}.practice-empty__steps{list-style:none;margin:1.5rem auto 0;padding:0;max-width:16rem;text-align:left;display:flex;flex-direction:column;gap:.65rem}.practice-empty__steps li{display:flex;align-items:center;gap:.65rem;font-size:.8125rem;color:var(--color-text)}.practice-empty__step-num{display:grid;place-items:center;flex-shrink:0;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--color-accent);color:var(--color-white);font-size:.6875rem;font-weight:700}.practice-empty__cta{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;margin-top:1.75rem;padding:.75rem 1.75rem;border-radius:var(--radius-pill);background:var(--color-accent);color:var(--color-white);font-size:.9375rem;font-weight:600;text-decoration:none;box-shadow:0 4px 14px #2e4a1e38;transition:background .15s,transform .15s,box-shadow .15s}.practice-empty__cta:hover{background:var(--color-accent-dark);transform:translateY(-1px);box-shadow:0 6px 18px #2e4a1e47}.practice-loading{margin-bottom:1.5rem}.practice-loading__card{display:flex;gap:1rem;padding:1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.practice-loading__avatar{flex-shrink:0;width:3.5rem;height:3.5rem;border-radius:50%;background:linear-gradient(90deg,var(--color-border) 0%,#eee5d4 50%,var(--color-border) 100%);background-size:200% 100%;animation:practice-shimmer 1.4s ease-in-out infinite}.practice-loading__lines{flex:1;display:flex;flex-direction:column;gap:.65rem;padding-top:.35rem}.practice-loading__line{height:.75rem;border-radius:var(--radius-pill);background:linear-gradient(90deg,var(--color-border) 0%,#eee5d4 50%,var(--color-border) 100%);background-size:200% 100%;animation:practice-shimmer 1.4s ease-in-out infinite}.practice-loading__line--short{width:40%}.practice-loading__line--medium{width:85%}@keyframes practice-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.selected-persona-panel{position:relative;overflow:hidden;margin-bottom:1.5rem;padding:0 1.5rem 1.5rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.selected-persona-panel__accent{height:4px;margin:0 -1.5rem 1.25rem;background:linear-gradient(90deg,var(--color-accent-dark),var(--color-accent),#6b9e4a)}.selected-persona-panel__head{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}.selected-persona-panel__avatar{display:grid;place-items:center;flex-shrink:0;width:3.5rem;height:3.5rem;background:var(--color-accent-light);border:1px solid rgba(61,100,40,.15);border-radius:50%;box-shadow:inset 0 1px #fff9;color:var(--color-accent)}.selected-persona-panel__title-block{flex:1;min-width:0}.selected-persona-panel__name{margin:0;font-size:1.25rem;font-weight:800;letter-spacing:-.02em;color:var(--color-text);line-height:1.2}.selected-persona-panel__badges{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.45rem}.practice-badge{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:var(--radius-pill);font-size:.6875rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.practice-badge--tag{background:var(--color-accent-light);color:var(--color-accent-dark);border:1px solid rgba(61,100,40,.12)}.practice-badge--easy{background:#ecfdf5;color:#166534;border:1px solid rgba(22,101,52,.15)}.practice-badge--medium{background:var(--color-warning-light);color:#92400e;border:1px solid rgba(146,64,14,.15)}.practice-badge--hard{background:var(--color-danger-light);color:#991b1b;border:1px solid rgba(153,27,27,.15)}.practice-badge--easy,.practice-badge--medium,.practice-badge--hard{text-transform:capitalize}.selected-persona-panel__switch{flex-shrink:0;align-self:center;padding:.4rem .875rem;border-radius:var(--radius-pill);border:1px solid var(--color-border2);background:var(--color-white);font-size:.8125rem;font-weight:600;color:var(--color-text-muted);text-decoration:none;transition:border-color .15s,color .15s,background .15s}.selected-persona-panel__switch:hover{border-color:var(--color-accent);color:var(--color-accent-dark);background:var(--color-accent-light)}.selected-persona-panel__scenario{margin-top:1.125rem;padding:1rem 1rem 1rem 1.125rem;background:linear-gradient(135deg,#e8f5d059,#fdfaf4e6);border:1px solid var(--color-border);border-left:3px solid var(--color-accent);border-radius:var(--radius-md)}.selected-persona-panel__scenario-label{display:block;margin-bottom:.35rem;font-size:.6875rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-accent)}.selected-persona-panel__description{margin:0;font-size:.9375rem;line-height:1.6;color:var(--color-text)}.selected-persona-panel__actions{display:flex;justify-content:center;margin-top:1.35rem}.practice-start-call{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-width:min(100%,14rem);padding:.85rem 2rem;border:none;border-radius:var(--radius-pill);background:linear-gradient(180deg,var(--color-accent) 0%,var(--color-accent-dark) 100%);color:var(--color-white);font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 16px #2e4a1e47;transition:transform .15s,box-shadow .15s}.practice-start-call:hover{box-shadow:0 6px 20px #2e4a1e57}.practice-start-call__icon{font-size:1.125rem;line-height:1}.persona-section{padding:1.5rem 0}.persona-section-head{display:flex;flex-direction:column;align-items:center;gap:.85rem;margin-bottom:1.25rem}.filters{display:flex;flex-wrap:wrap;justify-content:center;gap:.4rem}.filters select{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);font-size:.8125rem;font-family:inherit}.practice-persona-scroll{display:flex;gap:.75rem;scroll-snap-type:x proximity;padding:.25rem .25rem .5rem;margin-bottom:1.25rem}.practice-persona-scroll .persona-card{flex:0 0 min(220px,78vw);scroll-snap-align:start}.persona-card{display:flex;align-items:stretch;text-align:left;padding:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;box-shadow:var(--shadow-soft);transition:box-shadow .15s}.persona-card:hover{box-shadow:var(--shadow-card)}.persona-card.selected{outline:2px solid var(--color-accent);outline-offset:1px}.persona-card-body{flex:1;padding:.875rem .75rem .875rem 1rem;display:flex;flex-direction:column;gap:.2rem}.persona-card-arrow{display:flex;align-items:center;justify-content:center;width:2rem;margin:.5rem .5rem .5rem 0;align-self:center;height:2rem;border-radius:var(--radius-pill);background:var(--color-surface2);color:var(--color-accent);font-size:.875rem}.persona-emoji{font-size:1.375rem}.persona-name{font-size:1rem;font-weight:700;color:var(--color-text)}.persona-scenario{font-size:.8rem;color:var(--color-text-muted);line-height:1.4}.persona-meta{margin-top:.2rem;font-size:.6875rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-accent)}.btn-danger{border:none;border-radius:var(--radius-pill);padding:.5rem 1.25rem;font-size:.8125rem;font-weight:600;cursor:pointer;font-family:inherit;background:var(--color-danger);color:#fff}.btn-primary--wide{display:block;width:100%;max-width:280px;margin:0 auto}.btn-ghost{border:1px solid var(--color-border2);background:transparent;color:var(--color-text-muted);font-size:.8125rem;font-weight:500;padding:.4rem .875rem;border-radius:var(--radius-pill);cursor:pointer;font-family:inherit}.btn-ghost:hover{background:var(--color-surface);border-color:var(--color-accent);color:var(--color-text)}.active-call{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;margin:1rem 0;box-shadow:var(--shadow-soft)}.call-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:var(--color-text)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);flex-shrink:0}.status-dot.connecting{background:var(--color-warning);animation:pulse 1s infinite}.status-dot.active{background:var(--color-accent)}@keyframes pulse{50%{opacity:.35}}.timer{margin-left:auto;font-weight:600;font-size:.875rem;color:var(--color-accent);font-variant-numeric:tabular-nums}.volume-control{display:flex;flex-direction:column;gap:.35rem;margin:.75rem 0;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.volume-control input[type=range]{accent-color:var(--color-accent)}.transcript-panel{padding:.5rem 0 0}.transcript-panel--session{padding-top:0}.transcript-panel__head{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;margin-bottom:.65rem}.transcript-panel__head .section-title{margin-bottom:0}.transcript-panel__hint{font-size:.75rem;font-weight:500;color:var(--color-dim);font-style:italic}.transcript-list{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);min-height:160px;max-height:320px;overflow-y:auto;padding:1rem;box-shadow:var(--shadow-soft);margin-bottom:.65rem}.transcript-panel--session .transcript-list{border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.transcript-header{padding:.5rem 1rem;border-bottom:1px solid var(--color-border);margin-bottom:.75rem}.transcript-header span{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.transcript-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;min-height:120px;padding:1.5rem 1rem;text-align:center}.transcript-empty__icon{display:grid;place-items:center;margin-bottom:.5rem;opacity:.85}.transcript-empty__icon .app-icon{width:1.75rem;height:1.75rem}.transcript-empty p{margin:0;max-width:16rem;font-size:.875rem;line-height:1.5;color:var(--color-text-muted)}.transcript-line{margin-bottom:.85rem;padding-bottom:.85rem;border-bottom:1px solid var(--color-border)}.transcript-line:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.transcript-role{display:block;font-size:.6875rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.2rem}.transcript-line.employee .transcript-role{color:var(--color-accent)}.transcript-line.customer .transcript-role{color:var(--color-text-muted)}.transcript-text{font-size:.875rem;line-height:1.5}.employee-input-row{display:flex;gap:.5rem}.employee-input-row input{flex:1;padding:.625rem 1rem;border:1px solid var(--color-border2);border-radius:var(--radius-pill);font-size:.875rem;background:var(--color-surface);font-family:inherit}.employee-input-row input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #16a34a1a}.employee-input-row input:disabled{background:var(--color-surface2);color:var(--color-text-muted)}.employee-input-row .btn-primary{flex-shrink:0}.call-ended{text-align:center;padding:1.5rem;margin-top:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-soft)}.call-ended-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.call-ended-header p{margin:0;flex:1;min-width:0;text-align:left;font-size:.875rem;color:var(--color-text-muted)}.call-ended-practice-again{background:none;border:none;padding:.25rem 0;font-size:.8125rem;font-weight:500;font-family:inherit;color:var(--color-accent);cursor:pointer;text-decoration:underline;text-underline-offset:2px;flex-shrink:0;white-space:nowrap}.call-ended-practice-again:hover{color:var(--color-accent-dark)}.call-ended p{margin:0;font-size:.875rem;color:var(--color-text-muted)}.call-ended-chip{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;text-align:center;margin-top:.6rem;padding:.55rem 1.5rem;border-radius:var(--radius-pill);font-size:.875rem;font-weight:500;cursor:default;text-decoration:none;transition:background .25s ease,color .25s ease,border-color .25s ease;width:fit-content;margin-left:auto;margin-right:auto}.call-ended-chip--ghost{background:var(--color-accent-light);border:1.5px solid var(--color-accent);color:var(--color-accent-dark);font-style:italic}.call-ended-chip--solid{background:var(--color-accent);border:1.5px solid var(--color-accent-dark);color:#fff;cursor:pointer}.call-ended-chip--solid:hover{background:var(--color-accent-dark)}.call-ended-chip--error{background:transparent;border:1.5px solid var(--color-danger);color:var(--color-danger)}.settings-toggle-row{text-align:center;margin:.5rem 0}.knowledge-shell{display:flex;flex-direction:column;min-height:100vh;background:var(--color-bg)}.knowledge-layout{flex:1;display:flex;flex-direction:column;width:100%;max-width:48rem;margin:0 auto;padding:0 1.25rem;min-height:0}.knowledge-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1.5rem 0 1rem;flex-shrink:0}.knowledge-page-header-main{min-width:0}.knowledge-page-title{margin:0;font-size:1.25rem;font-weight:700;color:var(--color-text)}.knowledge-page-subtitle{margin:.2rem 0 0;font-size:.8125rem;color:var(--color-text-muted)}.knowledge-company{display:flex;flex-direction:column;gap:.375rem;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);flex-shrink:0}.knowledge-company select{font-size:.875rem;padding:.5rem .75rem;border:1px solid var(--color-border2);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-family:inherit;text-transform:none;letter-spacing:normal;font-weight:400;min-width:10rem;max-width:280px}.knowledge-company select:focus{outline:none;border-color:var(--color-accent)}.knowledge-chat{flex:1;display:flex;flex-direction:column;min-height:0}.knowledge-thread{flex:1;overflow-y:auto;padding:.5rem 0 1rem;scroll-behavior:smooth}.knowledge-thread--empty{display:flex;align-items:center;justify-content:center}.knowledge-empty-hint{margin:0;font-size:.9375rem;color:var(--color-text-muted);text-align:center;max-width:20rem;line-height:1.5}.knowledge-msg{margin-bottom:1.25rem;font-size:.9375rem;display:flex}.knowledge-msg--user{justify-content:flex-end}.knowledge-msg--assistant,.knowledge-msg--error{justify-content:flex-start}.knowledge-msg-body{max-width:85%}.knowledge-msg--user .knowledge-msg-body{background:var(--color-accent-light);border:1px solid var(--color-border);padding:.75rem 1rem;border-radius:1.25rem 1.25rem .375rem}.knowledge-msg--user p{margin:0;color:var(--color-text);line-height:1.55}.knowledge-msg--assistant p{margin:0;color:var(--color-text);line-height:1.65}.knowledge-msg--error .knowledge-msg-body{background:var(--color-danger-light);border:1px solid rgba(239,68,68,.25);padding:.75rem 1rem;border-radius:var(--radius-md)}.knowledge-msg--error p{margin:0;color:var(--color-danger)}.knowledge-sources{margin:.625rem 0 0;padding-left:1.1rem;font-size:.75rem;color:var(--color-text-muted)}.knowledge-typing{display:flex;gap:.25rem;align-items:center;padding:.25rem 0 .5rem}.knowledge-typing-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--color-accent);animation:pulse 1s infinite}.knowledge-composer{flex-shrink:0;position:sticky;bottom:0;padding:.75rem 0 1.25rem;background:linear-gradient(to bottom,transparent 0%,var(--color-bg) 28%)}.knowledge-composer-error{margin:0 0 .5rem;text-align:center}.knowledge-input-pill{display:flex;align-items:flex-end;gap:.5rem;padding:.5rem .5rem .5rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-card)}.knowledge-input-pill:focus-within{border-color:var(--color-accent);box-shadow:var(--shadow-card),0 0 0 3px #3d64281f}.knowledge-input{flex:1;min-height:1.5rem;max-height:8rem;padding:.375rem 0;border:none;background:transparent;font-size:.9375rem;line-height:1.5;color:var(--color-text);resize:none;field-sizing:content}.knowledge-input:focus{outline:none}.knowledge-input:disabled{color:var(--color-text-muted)}.knowledge-input::placeholder{color:var(--color-dim)}.knowledge-send-btn{flex-shrink:0;width:2.25rem;height:2.25rem;border:none;border-radius:50%;background:var(--color-accent);color:var(--color-white);font-size:1.125rem;font-weight:700;line-height:1;cursor:pointer;transition:background .15s,opacity .15s}.knowledge-send-btn:hover:not(:disabled){background:var(--color-accent-dark)}.knowledge-send-btn:disabled{opacity:.4;cursor:not-allowed}.knowledge-composer-hint{margin:.5rem 0 0;font-size:.6875rem;color:var(--color-dim);text-align:center}@media(max-width:600px){.page-content{padding:1.5rem 1rem 2rem}.knowledge-layout{padding:0 1rem}.knowledge-page-header{padding-top:1rem}.knowledge-msg-body{max-width:92%}.generate-panel-row{flex-direction:column;align-items:stretch}.employee-input-row{flex-direction:column}.employee-input-row .btn-primary{width:100%}.selected-persona-panel__switch{width:100%;text-align:center}.practice-empty__steps{max-width:none}.practice-start-call{width:100%}}.history-page{max-width:1100px;margin:0 auto;padding:2rem 1.5rem}.history-page-header{margin-bottom:1.5rem}.history-page-title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 .25rem}.history-page-subtitle{font-size:.875rem;color:var(--color-text-muted);margin:0}.history-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.history-card{display:flex;flex-direction:column;gap:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;box-shadow:var(--shadow-soft);text-align:left;cursor:pointer;width:100%;font-family:inherit;transition:box-shadow .2s,border-color .2s}.history-card:hover{box-shadow:var(--shadow-card);border-color:var(--color-accent)}.history-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.history-card-label{display:block;font-size:.625rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.125rem}.history-card-name{display:block;font-size:1rem;font-weight:700;color:var(--color-text);line-height:1.2}.history-card-tags{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.history-card-company{font-size:.75rem;color:var(--color-text-muted)}.history-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:.25rem}.history-card-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--color-text-muted)}.history-meta-sep{color:var(--color-border)}.history-badge-ready{display:inline-flex;align-items:center;gap:.375rem;padding:.2rem .625rem;border-radius:999px;background:#dcfce7;color:#15803d;font-size:.75rem;font-weight:600}.history-badge-dot{display:inline-block;width:6px;height:6px;border-radius:50%}.history-badge-none{display:inline-flex;align-items:center;padding:.2rem .625rem;border-radius:999px;background:var(--color-surface2);border:1px solid var(--color-border);color:var(--color-text-muted);font-size:.75rem}.history-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 0;text-align:center}.history-empty-title{font-size:.9375rem;font-weight:600;color:var(--color-text);margin:0}.history-empty-sub{font-size:.875rem;color:var(--color-text-muted);margin:0}.personas-page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.personas-page-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--color-text)}.personas-page-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--color-text-muted);max-width:540px}.personas-page-actions{display:flex;flex-wrap:wrap;gap:.5rem;flex-shrink:0}.personas-action-btn{white-space:nowrap}.personas-action-btn.is-active{box-shadow:0 0 0 2px var(--color-accent)}.btn-create-persona{display:inline-block;padding:.5rem 1.25rem;background:var(--color-accent);color:#fff;border:none;border-radius:999px;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:background .15s}.btn-create-persona:hover:not(:disabled){background:var(--color-accent-dark)}.btn-create-persona:disabled{opacity:.45;cursor:not-allowed}.personas-panel-slot{margin-bottom:1.5rem}.personas-grid--scroll{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),360px));justify-content:start;gap:1.25rem;align-items:stretch;align-content:start;padding-bottom:.5rem;margin-bottom:1.25rem}.personas-grid-item{display:flex;height:100%;min-height:300px;scroll-snap-align:start}.personas-loading{text-align:center;padding:3rem 1rem;color:var(--color-text-muted);font-size:.875rem}.personas-empty{text-align:center;padding:4rem 1rem;color:var(--color-text-muted);font-size:.875rem}.personas-empty .empty-state-icon{margin-bottom:.75rem}.persona-manager{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.5rem;box-shadow:var(--shadow-soft)}.persona-editor-panel-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.persona-editor-panel-header .section-title{margin:0}.persona-editor-close{flex-shrink:0}.persona-editor-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.persona-editor-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.persona-editor-grid .span-2{grid-column:span 2}.persona-editor-grid input,.persona-editor-grid select,.persona-editor-grid textarea{font-size:.875rem;padding:.5rem .75rem;border:1px solid var(--color-border2);border-radius:var(--radius-sm);font-weight:400;text-transform:none;letter-spacing:normal;background:var(--color-surface);color:var(--color-text);font-family:inherit}.persona-editor-grid input:focus,.persona-editor-grid select:focus,.persona-editor-grid textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #16a34a1a}.prompt-editor-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin:1.25rem 0 .75rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;text-transform:none;letter-spacing:normal;color:var(--color-text);cursor:pointer}.system-prompt-label{display:flex;flex-direction:column;gap:.5rem;font-size:.6875rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.system-prompt-hint{font-size:.8125rem;font-weight:400;letter-spacing:normal;text-transform:none;color:var(--color-text-muted);line-height:1.45}.system-prompt-textarea{font-family:ui-monospace,SF Mono,Monaco,monospace;font-size:.78rem;line-height:1.5;resize:vertical;text-transform:none;letter-spacing:normal}.system-prompt-textarea:read-only{background:var(--color-surface2);color:var(--color-text-muted)}.persona-editor-footer{display:flex;gap:.65rem;margin-top:1.25rem}@media(max-width:600px){.persona-editor-grid{grid-template-columns:1fr}.persona-editor-grid .span-2{grid-column:span 1}.personas-page-header{flex-direction:column}}.progress-section{margin-top:2rem;background:var(--color-progress-dark);border-radius:12px;padding:1.5rem}.progress-section-label{margin:0 0 1rem;font-size:.6875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ffffff80}.progress-section-grid{display:flex;gap:1rem;padding-bottom:.75rem;scrollbar-color:rgba(200,230,160,.55) rgba(255,255,255,.08)}.progress-section-grid.h-scroll::-webkit-scrollbar-track{margin:0;background:#ffffff14}.progress-section-grid.h-scroll::-webkit-scrollbar-thumb{border-width:1px;border-color:#ffffff14;background:linear-gradient(180deg,#c8e6a0b3,#4a7a32d9);box-shadow:none}.progress-section-grid.h-scroll::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#c8e6a0d9,#4a7a32)}.progress-section-grid.h-scroll::-webkit-scrollbar-thumb:active{background:#4a7a32}.progress-item{display:flex;flex:0 0 auto;align-items:center;gap:.75rem;min-width:11rem}.progress-item-info{min-width:0}.progress-item-name{margin:0;font-size:.9375rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.progress-item-badge{display:inline-flex;align-items:center;gap:.3rem;margin-top:.25rem;padding:.2rem .5rem;border-radius:999px;font-size:.6875rem;font-weight:600}.progress-item-dot{display:inline-block;width:6px;height:6px;border-radius:50%}.persona-card-new{display:flex;flex-direction:column;gap:1rem;height:100%;width:100%;min-height:300px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:1.25rem;box-shadow:var(--shadow-soft);transition:border-color .15s,box-shadow .15s}.persona-card-new--editing{border-color:var(--color-accent);box-shadow:0 0 0 3px #16a34a1f}.pcn-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.pcn-title{display:flex;flex-wrap:wrap;align-items:baseline;gap:.4rem;min-width:0}.pcn-name{font-size:1rem;font-weight:700;color:var(--color-text);line-height:1.2}.pcn-age{font-size:.8125rem;color:var(--color-text-muted);font-weight:400}.pcn-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}.pcn-badge-dot{display:inline-block;width:6px;height:6px;border-radius:50%}.pcn-body{flex:1;display:flex;flex-direction:column;gap:.75rem;min-height:0}.pcn-desc{margin:0;flex:1;border-left:2px solid var(--color-accent);padding-left:.75rem;font-size:.875rem;line-height:1.6;color:var(--color-text-muted);display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:calc(.875rem * 1.6 * 3)}.pcn-desc--empty{color:var(--color-text-muted);opacity:.65;font-style:italic}.pcn-tags{display:flex;flex-wrap:wrap;align-content:flex-start;gap:.375rem;min-height:3.875rem;max-height:3.875rem;overflow:hidden;flex-shrink:0}.pcn-tag{display:inline-block;padding:.2rem .625rem;background:var(--color-surface2);border:1px solid var(--color-border);border-radius:999px;font-size:.75rem;color:var(--color-text-muted)}.pcn-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap;margin-top:auto;flex-shrink:0;padding-top:.25rem}.pcn-sessions{display:flex;align-items:center;gap:.5rem}.pcn-dots{display:flex;gap:.25rem}.pcn-dot{display:inline-block;width:8px;height:8px;border-radius:50%}.pcn-session-label{font-size:.75rem;color:var(--color-text-muted)}.pcn-actions{display:flex;align-items:center;gap:.5rem}.pcn-btn-practice{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem 1rem;background:var(--color-accent);color:#fff;border-radius:999px;font-size:.8125rem;font-weight:600;text-decoration:none;transition:background .15s;cursor:pointer}.pcn-btn-practice:hover{background:var(--color-accent-dark)}.pcn-btn-secondary{padding:.4rem .75rem;background:transparent;border:1px solid var(--color-border2);border-radius:999px;font-size:.75rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;font-family:inherit;transition:border-color .15s,color .15s}.pcn-btn-secondary:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-text)}.pcn-btn-secondary:disabled{opacity:.4;cursor:not-allowed}.pcn-btn-danger{padding:.4rem .75rem;background:transparent;border:1px solid var(--color-danger);border-radius:999px;font-size:.75rem;font-weight:500;color:var(--color-danger);cursor:pointer;font-family:inherit;transition:background .15s}.pcn-btn-danger:hover:not(:disabled){background:var(--color-danger-light)}.pcn-btn-danger:disabled{opacity:.4;cursor:not-allowed}.dashboard-page{--primary: #3d6428;--primary-shadow: rgba(61,100,40,.22);--vivid: #22C55E;--accent1: #EF4444;--accent2: #F59E0B;--accent3: #EAB308;--card: #fdfaf4;--card-2: #f5f0e6;--ink: #1a2e1a;--ink-soft: #7a6040;--ink-faint: #9a8060;--line: #e4d8c0;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 3px rgba(30,50,20,.08), 0 1px 2px rgba(30,50,20,.05);--shadow-lg: 0 4px 16px rgba(30,50,20,.1), 0 2px 6px rgba(30,50,20,.05);background:#f5f0e6;min-height:100vh;color:var(--ink)}.dashboard-page .wrap{max-width:1340px;margin:0 auto;padding:0 28px 72px}.dashboard-page .back-link{display:inline-flex;align-items:center;gap:4px;font-size:13px;color:var(--ink-soft);text-decoration:none;margin:20px 0 8px;transition:color .15s}.dashboard-page .back-link:hover{color:var(--primary)}.dash-topbar{background:#fdfaf4;border-bottom:1px solid var(--line);box-shadow:0 1px 3px #1e32140f}.dash-topbar-inner{max-width:1340px;margin:0 auto;padding:14px 28px;display:flex;align-items:center;gap:22px;flex-wrap:wrap}.dash-topbar .sess-id{display:flex;flex-direction:column;gap:2px;padding-right:22px;border-right:1px solid var(--line)}.dash-topbar .eyebrow{font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-faint)}.dash-topbar .code{font-size:13px;font-weight:700;color:var(--primary);font-feature-settings:"tnum";letter-spacing:.01em;max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-topbar .emp{display:flex;align-items:center;gap:13px}.dash-topbar .avatar{width:42px;height:42px;border-radius:50%;background:var(--primary);color:#fff;display:grid;place-items:center;font-weight:700;font-size:16px;flex:none;box-shadow:0 2px 8px var(--primary-shadow)}.dash-topbar .emp-meta .name{font-size:15px;font-weight:700}.dash-topbar .emp-meta .sub{font-size:12px;color:var(--ink-soft)}.dash-topbar .topbar-spacer{flex:1}.dash-topbar .meta-pill{display:flex;flex-direction:column;gap:1px;padding:0 18px;border-right:1px solid var(--line)}.dash-topbar .meta-pill .k{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.dash-topbar .meta-pill .v{font-size:14px;font-weight:600;color:var(--ink)}.dash-topbar .focus{display:flex;align-items:center;gap:12px;padding-left:18px}.dash-topbar .focus-badge{padding:6px 13px;border-radius:999px;font-size:12.5px;font-weight:700;background:#ef44441a;color:#dc2626;display:inline-flex;align-items:center;gap:7px}.dash-topbar .focus-badge .dot{width:7px;height:7px;border-radius:50%;background:#dc2626;flex:none}.dash-topbar .focus-text .lbl{font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-faint)}.dash-topbar .focus-text .word{font-size:13px;font-weight:700;color:var(--ink-soft)}.dashboard-page .warn-banner{margin:20px 0 0;padding:13px 18px;background:#fef3c7;border:1px solid #FCD34D;border-left:4px solid #F59E0B;border-radius:8px;display:flex;align-items:flex-start;gap:12px;font-size:13px;color:#78350f;line-height:1.55}.dashboard-page .warn-banner svg{flex:none;margin-top:1px;color:#f59e0b}.dashboard-page .section-title{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin:34px 0 14px;display:flex;align-items:center;gap:10px}.dashboard-page .section-title:before{content:"";width:4px;height:15px;border-radius:2px;background:var(--primary);flex:none}.dashboard-page .card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.dashboard-page .card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.dashboard-page .card-h{display:flex;align-items:center;gap:11px;margin-bottom:14px}.dashboard-page .ch-ico{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex:none;background:#3d642817;color:var(--primary)}.dashboard-page .ch-ico svg{width:19px;height:19px}.dashboard-page .card-h h3{font-size:16px;font-weight:700}.dashboard-page .card-sub{font-size:12px;color:var(--ink-soft);margin-top:3px}.dashboard-page .def-row{display:grid;grid-template-columns:116px 1fr;gap:14px;padding:12px 0;border-bottom:1px solid var(--line)}.dashboard-page .def-row:last-child{border-bottom:none;padding-bottom:2px}.dashboard-page .def-row:first-of-type{padding-top:2px}.dashboard-page .def-k{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--primary);padding-top:2px}.dashboard-page .def-v{font-size:13px;color:var(--ink);line-height:1.5}.dashboard-page .overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.dashboard-page .overview-grid .card{display:flex;flex-direction:column}.dashboard-page .overview-grid .def-v{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;cursor:help}.dashboard-page .persona-split{display:grid;grid-template-columns:auto 1fr;gap:20px;align-items:start;margin-top:8px;padding-top:16px;border-top:1px solid var(--line)}.dashboard-page .persona-traits-col{display:flex;flex-direction:column;gap:8px}.dashboard-page .persona-traits-col .traits{flex-direction:column;flex-wrap:nowrap;gap:6px;margin-bottom:0}.dashboard-page .context-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}.dashboard-page .context-card{display:flex;flex-direction:column}.dashboard-page .context-body{font-size:13.5px;color:var(--ink);line-height:1.65;margin:0;padding-top:4px;flex:1}.dashboard-page .card-h h3{margin:0}.dashboard-page .persona-card .card-sub,.dashboard-page .context-card .card-sub{font-size:11px}.dashboard-page .persona-top{display:flex;align-items:center;gap:12px;margin-bottom:14px}.dashboard-page .persona-av{width:44px;height:44px;border-radius:50%;flex:none;background:var(--primary);color:#fff;display:grid;place-items:center;font-size:18px;font-weight:800;box-shadow:0 3px 8px var(--primary-shadow)}.dashboard-page .persona-id{display:flex;flex-direction:column;gap:2px}.dashboard-page .pname{font-size:15px;font-weight:800;line-height:1.2}.dashboard-page .psub{font-size:11px;color:var(--ink-soft)}.dashboard-page .traits-label{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:9px}.dashboard-page .traits{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:0}.dashboard-page .trait{font-size:12px;font-weight:600;color:var(--primary);background:#3d642812;border:1px solid rgba(61,100,40,.18);padding:5px 12px;border-radius:999px;transition:transform .2s,box-shadow .2s,background .2s}.dashboard-page .trait:hover{transform:translateY(-2px);background:#3d64281f;box-shadow:0 4px 12px -4px #3d642859}.dashboard-page .kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}.dashboard-page .kpi{position:relative;overflow:hidden}.dashboard-page .kpi .topline{display:flex;align-items:center;justify-content:space-between}.dashboard-page .kpi .ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none}.dashboard-page .kpi .ico svg{width:18px;height:18px}.dashboard-page .kpi .trend{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700}.dashboard-page .kpi .trend svg{width:13px;height:13px}.dashboard-page .trend.up{color:var(--primary)}.dashboard-page .trend.down{color:var(--accent1)}.dashboard-page .trend.flat{color:var(--ink-faint)}.dashboard-page .kpi .num{font-size:38px;font-weight:800;letter-spacing:-.03em;margin-top:14px;line-height:1;font-feature-settings:"tnum"}.dashboard-page .kpi .num .unit{font-size:19px;font-weight:700;color:var(--ink-faint)}.dashboard-page .kpi .lbl{font-size:13px;font-weight:600;color:var(--ink-soft);margin-top:7px}.dashboard-page .kpi .ctx{font-size:11.5px;color:var(--ink-faint);margin-top:3px}.dashboard-page .mirror-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:4px}.dashboard-page .mirror-col+.mirror-col{padding-left:24px;border-left:1px solid var(--line)}.dashboard-page .mirror-col h4{font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;margin-bottom:13px;display:flex;align-items:center;gap:8px}.dashboard-page .mirror-col.pos h4{color:var(--primary)}.dashboard-page .mirror-col.neg h4{color:var(--accent1)}.dashboard-page .mirror-col h4 svg{width:16px;height:16px;flex:none}.dashboard-page .bubble{display:flex;gap:11px;align-items:flex-start;padding:13px 15px;border-radius:10px;margin-bottom:11px;font-size:13px;line-height:1.45;color:var(--ink);transition:transform .2s ease,box-shadow .2s ease}.dashboard-page .bubble:last-child{margin-bottom:0}.dashboard-page .bubble.pos{background:#3d64280f;border:1px solid rgba(61,100,40,.14)}.dashboard-page .bubble.neg{background:#ef44440d;border:1px solid rgba(239,68,68,.14)}.dashboard-page .bubble.pos:hover{transform:translate(3px);box-shadow:0 4px 14px -6px #3d642866}.dashboard-page .bubble.neg:hover{transform:translate(3px);box-shadow:0 4px 14px -6px #ef444459}.dashboard-page .b-ico{flex:none;width:17px;height:17px;margin-top:1px}.dashboard-page .bubble.pos .b-ico{color:var(--primary)}.dashboard-page .bubble.neg .b-ico{color:var(--accent1)}.dashboard-page .bubble-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent1);margin-right:5px}.dashboard-page .sc-list{display:flex;flex-direction:column;gap:10px}.dashboard-page .sc-item{display:flex;align-items:center;gap:13px;padding:13px 15px;border-radius:8px;background:var(--card-2);border:1px solid var(--line)}.dashboard-page .sc-badge{width:25px;height:25px;border-radius:50%;display:grid;place-items:center;flex:none;color:#fff}.dashboard-page .sc-badge svg{width:14px;height:14px}.dashboard-page .sc-item.done .sc-badge{background:var(--primary)}.dashboard-page .sc-item.slightly_insufficient .sc-badge{background:var(--accent2)}.dashboard-page .sc-item.insufficient .sc-badge{background:var(--accent1)}.dashboard-page .sc-text{font-size:14px;color:var(--ink);flex:1}.dashboard-page .sc-status{margin-left:auto;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}.dashboard-page .sc-item.done .sc-status{color:var(--primary)}.dashboard-page .sc-item.slightly_insufficient .sc-status{color:var(--accent2)}.dashboard-page .sc-item.insufficient .sc-status{color:var(--accent1)}.dashboard-page .ns-list{display:flex;flex-direction:column;gap:12px}.dashboard-page .ns-item{display:flex;gap:14px;padding:15px 16px;border-radius:8px;background:var(--card-2);border:1px solid var(--line)}.dashboard-page .ns-num{width:27px;height:27px;border-radius:8px;background:var(--primary);color:#fff;font-weight:800;display:grid;place-items:center;flex:none;font-size:13px}.dashboard-page .ns-text{font-size:14px;color:var(--ink);line-height:1.55}.dashboard-page .chart-card{padding:24px 26px 14px}.dashboard-page .chart-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.dashboard-page .chart-head h3{font-size:17px;font-weight:700}.dashboard-page .chart-head p{font-size:12.5px;color:var(--ink-soft);margin-top:2px}.dashboard-page .legend{display:flex;gap:16px;align-items:center}.dashboard-page .legend .item{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink-soft)}.dashboard-page .legend .sw{width:13px;height:13px;border-radius:4px;flex:none}.dashboard-page .chart-pt{cursor:pointer}.chart-tip{position:fixed;z-index:300;pointer-events:none;transform:translate(-50%,-108%);background:#2e4a1e;color:#fff;padding:11px 13px;border-radius:8px;max-width:290px;box-shadow:0 8px 24px #1e321438;transition:opacity .12s}.chart-tip .tip-spk{font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:4px}.chart-tip .tip-spk.cus{color:#fca5a5}.chart-tip .tip-sent{font-size:11px;color:#c8e6a0bf}.dashboard-page .infl-list{display:flex;flex-direction:column;gap:10px}.dashboard-page .infl-item{display:flex;gap:13px;padding:13px 15px;border-radius:8px;background:var(--card-2);border:1px solid var(--line);align-items:flex-start}.dashboard-page .infl-dir{font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:99px;flex:none}.dashboard-page .infl-item.de-escalation .infl-dir{background:#3d64281f;color:var(--primary)}.dashboard-page .infl-item.escalation .infl-dir{background:#ef44441a;color:var(--accent1)}.dashboard-page .infl-text{font-size:13.5px;color:var(--ink-soft);line-height:1.55}.dashboard-page .infl-turn{font-weight:700;color:var(--ink)}.dashboard-page .foot{text-align:center;font-size:11.5px;color:var(--ink-faint);margin-top:48px}.sdp-skeleton-page{max-width:1340px;margin:0 auto;padding:32px 28px;display:flex;flex-direction:column;gap:16px}.sdp-skeleton{height:96px;border-radius:12px;background:#e4d8c0;animation:sdp-pulse 1.5s ease-in-out infinite}@keyframes sdp-pulse{0%,to{opacity:1}50%{opacity:.45}}.sdp-error-page{max-width:640px;margin:0 auto;padding:32px 28px}.sdp-error{padding:14px 18px;border-radius:8px;background:#fee2e2;border:1px solid rgba(239,68,68,.25);color:#b91c1c;font-size:14px}.intro-overlay{position:absolute;inset:0;background:#f5f0e6;overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none}.intro-slide{position:absolute;inset:0;display:none;opacity:0;align-items:center;justify-content:center;padding:56px 40px 130px;transition:opacity .15s ease,transform .15s ease;transform:translateY(0)}.intro-slide.visible{display:flex;opacity:1}.intro-slide.leaving{opacity:0;transform:translateY(-18px);pointer-events:none}.slide-inner{width:100%;max-width:940px;text-align:center}.slide-inner.wide{max-width:1120px}.wd-badge{width:84px;height:84px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;color:#fff;background:var(--primary);box-shadow:0 8px 24px var(--primary-shadow)}.wd-badge svg{width:42px;height:42px}.wd-eyebrow{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}.wd-title{font-size:44px;font-weight:800;letter-spacing:-.02em;margin-top:8px;color:var(--ink)}.wd-sub{font-size:17px;color:var(--ink-soft);margin-top:12px;max-width:640px;margin-left:auto;margin-right:auto}.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px}.hstat{background:#fdfaf4;border:1px solid var(--line);border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);text-align:left}.hstat-num{font-size:50px;font-weight:800;color:var(--c, var(--primary));letter-spacing:-.02em;line-height:1;font-feature-settings:"tnum"}.hstat-den{font-size:18px;font-weight:600;color:var(--ink-faint);margin-left:5px}.hstat-label{margin-top:10px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft)}.hstat-bar{height:8px;border-radius:99px;background:var(--line);margin:15px 0 12px;overflow:hidden}.hstat-fill{height:100%;border-radius:99px}.hstat-sub{font-size:12.5px;color:var(--ink-soft);line-height:1.5}.slide2-title{font-size:36px;font-weight:800;letter-spacing:-.02em;color:var(--ink)}.slide2-sub{font-size:16px;color:var(--ink-soft);margin-top:10px}.arc-chart-wrap{margin:26px auto 0;background:#fdfaf4;border:1px solid var(--line);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow)}.arc-bars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:26px;text-align:left}.abar-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.abar-label{font-size:13px;font-weight:700;color:var(--ink)}.abar-pct{font-size:15px;font-weight:800;color:var(--primary);font-feature-settings:"tnum"}.abar-track{height:10px;border-radius:99px;background:var(--line);overflow:hidden}.abar-fill{height:100%;border-radius:99px;background:var(--primary)}.intro-progress{position:absolute;top:30px;left:50%;transform:translate(-50%);display:flex;gap:8px;z-index:5}.intro-dot{width:8px;height:8px;border-radius:50%;background:var(--line);transition:all .2s;display:block}.intro-dot.active{background:var(--primary);width:22px;border-radius:99px}.intro-nav{position:absolute;left:0;right:0;bottom:40px;display:flex;flex-direction:column;align-items:center;gap:12px;z-index:5;cursor:default}.intro-btn{display:inline-flex;align-items:center;gap:9px;border:none;cursor:pointer;font:inherit;font-size:15px;font-weight:700;color:#fff;background:var(--primary);padding:13px 26px;border-radius:999px;box-shadow:0 6px 20px var(--primary-shadow);transition:transform .15s,box-shadow .15s}.intro-btn:hover{transform:translateY(-2px);box-shadow:0 10px 26px #3d642852}.intro-btn svg{width:18px;height:18px}.intro-hint{font-size:12.5px;color:var(--ink-faint)}.intro-hint kbd{font:inherit;font-size:11px;background:var(--line);border-radius:5px;padding:1px 6px}@media(max-width:1080px){.dashboard-page .kpi-row{grid-template-columns:repeat(2,1fr)}.dashboard-page .overview-grid,.dashboard-page .context-grid,.dashboard-page .mirror-grid{grid-template-columns:1fr}.dashboard-page .mirror-col+.mirror-col{padding-left:0;border-left:none;border-top:1px solid var(--line);padding-top:20px}.dash-topbar-inner{flex-wrap:wrap;gap:12px}.hero-stats,.arc-bars{grid-template-columns:1fr}.wd-title{font-size:34px}.slide2-title{font-size:28px}}@media(max-width:640px){.dashboard-page .kpi-row{grid-template-columns:1fr 1fr}.dashboard-page .wrap{padding:0 16px 56px}.dashboard-page .kpi .num{font-size:30px}.intro-slide{padding:40px 20px 110px}.wd-title{font-size:28px}}.App{width:100%;min-height:100vh;background:var(--color-bg)}
