*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:light dark;--color-primary: #25d366;--color-primary-dark: #1da851;--color-primary-bright: #2ee077;--color-primary-light: #dcf8c6;--color-secondary: #128c7e;--color-accent: #007aff;--color-bg: #ffffff;--color-page-bg: #f5f5f7;--color-bg-secondary: #f5f5f7;--color-bg-tertiary: #e8e8ed;--color-surface: #ffffff;--color-border: #d2d2d7;--color-text-primary: #1d1d1f;--color-text-secondary: #6e6e73;--color-text-muted: #86868b;--color-text-tertiary: #8e8e93;--color-on-accent: #ffffff;--color-success: #34c759;--color-success-strong: #059669;--color-success-dark: #047857;--color-success-glow: rgba(5, 150, 105, .4);--color-error: #ff3b30;--color-warning: #ff9500;--color-danger-strong: #b91c1c;--heatmap-empty: #ebedf0;--heatmap-level-1: #9be9a8;--heatmap-level-2: #40c463;--heatmap-level-3: #30a14e;--heatmap-level-4: #216e39;--heatmap-tooltip-bg: rgba(30, 34, 38, .95);--emoji-bar-start: #ffd700;--emoji-bar-end: #ffa500;--hero-title-whatsapp: #8b6f47;--hero-title-gradient-start: #30d158;--hero-title-gradient-mid: #25d366;--hero-title-gradient-end: #1da851;--hero-title-underline: #25d366;--privacy-notice-bg: rgba(52, 199, 89, .08);--privacy-notice-border: rgba(52, 199, 89, .2);--date-filter-surface: #ffffff;--wrapped-section-surface: var(--date-filter-surface);--wrapped-section-border: #e3e3e8;--wrapped-result-surface: #f8f8fa;--wrapped-result-border: #e8e8ee;--time-section-night: #6366f1;--time-section-morning: #f59e0b;--time-section-afternoon: #f97316;--time-section-evening: #8b5cf6;--time-label-night: #4f46e5;--time-label-night-bg: rgba(99, 102, 241, .1);--time-label-morning: #b45309;--time-label-morning-bg: rgba(245, 158, 11, .1);--time-label-afternoon: #c2410c;--time-label-afternoon-bg: rgba(249, 115, 22, .1);--time-label-evening: #7c3aed;--time-label-evening-bg: rgba(139, 92, 246, .1);--gap-highlight-stripe-soft: rgba(239, 68, 68, .15);--gap-highlight-stripe-strong: rgba(239, 68, 68, .35);--gap-highlight-bar-start: #fca5a5;--gap-overlay-surface: rgba(255, 255, 255, .95);--gap-overlay-shadow: 0 2px 8px rgba(0, 0, 0, .15);--gap-participant-highlight-shadow: 0 2px 8px rgba(99, 102, 241, .3);--gap-insight-bg: linear-gradient( 135deg, rgba(99, 102, 241, .1) 0%, rgba(139, 92, 246, .1) 100% );--gap-insight-border: rgba(99, 102, 241, .2);--font-family-base: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-family-heading: var(--font-family-base);--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;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--border-radius-sm: var(--radius-sm);--border-radius-md: var(--radius-md);--border-radius-lg: var(--radius-lg);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 28px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--container-max-width: 1200px;--container-padding: var(--spacing-lg)}[data-theme=dark]{--color-primary: #30d158;--color-primary-dark: #25b34b;--color-primary-bright: #4adf7b;--color-primary-light: rgba(48, 209, 88, .22);--color-secondary: #20b8a6;--color-accent: #0a84ff;--color-bg: #1c1c1e;--color-page-bg: #1c1c1e;--color-bg-secondary: #2a2a2d;--color-bg-tertiary: #3a3a3c;--color-surface: #323236;--color-border: #5a5a5f;--color-text-primary: #f5f5f7;--color-text-secondary: #a1a1a6;--color-text-muted: #8e8e93;--color-text-tertiary: #7c7c80;--color-on-accent: #ffffff;--color-success: #30d158;--color-success-strong: #12a97a;--color-success-dark: #0f8b64;--color-success-glow: rgba(18, 169, 122, .45);--color-error: #ff6961;--color-warning: #ff9f0a;--color-danger-strong: #ff8a84;--heatmap-empty: #2c2c2e;--heatmap-level-1: #0e4429;--heatmap-level-2: #006d32;--heatmap-level-3: #26a641;--heatmap-level-4: #39d353;--heatmap-tooltip-bg: rgba(20, 20, 22, .95);--emoji-bar-start: #fcd34d;--emoji-bar-end: #f59e0b;--hero-title-whatsapp: #d1b087;--hero-title-gradient-start: #4adf7b;--hero-title-gradient-mid: #30d158;--hero-title-gradient-end: #25b34b;--hero-title-underline: #30d158;--privacy-notice-bg: rgba(48, 209, 88, .14);--privacy-notice-border: rgba(48, 209, 88, .26);--date-filter-surface: #323236;--wrapped-section-surface: var(--date-filter-surface);--wrapped-section-border: #4a4a4f;--wrapped-result-surface: #3a3a3c;--wrapped-result-border: #4a4a4e;--time-label-night: #a5b4fc;--time-label-night-bg: rgba(99, 102, 241, .2);--time-label-morning: #fbbf24;--time-label-morning-bg: rgba(245, 158, 11, .2);--time-label-afternoon: #fdba74;--time-label-afternoon-bg: rgba(249, 115, 22, .2);--time-label-evening: #c4b5fd;--time-label-evening-bg: rgba(139, 92, 246, .2);--gap-highlight-stripe-soft: rgba(255, 105, 97, .2);--gap-highlight-stripe-strong: rgba(255, 105, 97, .35);--gap-highlight-bar-start: #ff8a84;--gap-overlay-surface: rgba(44, 44, 46, .95);--gap-overlay-shadow: 0 2px 10px rgba(0, 0, 0, .35);--gap-participant-highlight-shadow: 0 2px 8px rgba(99, 102, 241, .45);--gap-insight-bg: linear-gradient( 135deg, rgba(99, 102, 241, .2) 0%, rgba(139, 92, 246, .22) 100% );--gap-insight-border: rgba(139, 92, 246, .35);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 20px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 28px rgba(0, 0, 0, .55)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-page-bg);min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}p{margin-bottom:var(--spacing-md)}button{font-family:inherit;cursor:pointer}html.theme-transition *,html.theme-transition *:before,html.theme-transition *:after{transition:background-color var(--transition-slow),color var(--transition-slow),border-color var(--transition-slow),box-shadow var(--transition-slow)}.theme-toggle{position:fixed;top:var(--spacing-md);right:var(--spacing-md);width:44px;height:44px;border-radius:50%;border:1px solid var(--color-border);background-color:var(--color-bg-secondary);color:var(--color-text-primary);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;z-index:1200;transition:transform var(--transition-base),background-color var(--transition-base),border-color var(--transition-base)}.theme-toggle:hover{transform:scale(1.08)}.theme-toggle:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.theme-toggle-icon{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.theme-toggle-icon--sun,[data-theme=dark] .theme-toggle-icon--moon{display:none}[data-theme=dark] .theme-toggle-icon--sun{display:block}.container{width:100%;max-width:var(--container-max-width);margin:0 auto;padding:0 var(--container-padding);overflow-x:hidden}.main{flex:1;padding:var(--spacing-xl) 0;display:flex;align-items:center}.main--centered{min-height:100vh}.upload-section{max-width:650px;margin:0 auto;width:100%;padding-bottom:var(--spacing-md)}.upload-card{background-color:var(--color-surface);border-radius:var(--radius-xl);padding:var(--spacing-2xl) var(--spacing-2xl) var(--spacing-xl);box-shadow:var(--shadow-md);text-align:center;position:relative}.upload-card:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(37,211,102,.01) 2px,rgba(37,211,102,.01) 4px);pointer-events:none;opacity:.5;z-index:0}.hero-title{display:flex;flex-direction:column;align-items:center;gap:0;margin:0 auto var(--spacing-xl);max-width:500px;position:relative;z-index:1;padding:var(--spacing-md) 0;animation:fadeInUp .8s ease-out}.hero-title__whatsapp{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;font-size:1rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--hero-title-whatsapp);margin-bottom:-1rem;opacity:.85}.hero-title__recapped{font-family:Iowan Old Style,Palatino Linotype,Book Antiqua,Palatino,Georgia,serif;font-size:clamp(2.75rem,9vw,4rem);font-weight:700;font-style:italic;line-height:1;background:linear-gradient(135deg,var(--hero-title-gradient-start) 0%,var(--hero-title-gradient-mid) 40%,var(--hero-title-gradient-end) 100%);background-size:100% 100%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;color:var(--hero-title-gradient-start);position:relative;letter-spacing:-.01em;transform:rotate(-1deg);display:inline-block;padding:.05em .15em;max-width:100%}.hero-title__underline{width:100%;max-width:280px;height:12px;color:var(--hero-title-underline);margin-top:.25rem;opacity:.7;animation:drawLine 1.2s ease-out .4s backwards}@keyframes drawLine{0%{opacity:0;transform:scaleX(0)}to{opacity:.7;transform:scaleX(1)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.upload-card__description{color:var(--color-text-secondary);margin-bottom:var(--spacing-xl);font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);max-width:500px;margin-left:auto;margin-right:auto}.upload-area{position:relative;margin-bottom:var(--spacing-lg)}.upload-area__input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.upload-area__label{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;padding:var(--spacing-xl);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-bg-secondary);cursor:pointer;transition:all var(--transition-base)}.upload-area__label:hover,.upload-area__label:focus-within{border-color:var(--color-primary);background-color:var(--color-primary-light)}.upload-area__icon{width:48px;height:48px;color:var(--color-text-muted);margin-bottom:var(--spacing-md);transition:color var(--transition-base)}.upload-area__label:hover .upload-area__icon,.upload-area__label:focus-within .upload-area__icon{color:var(--color-primary-dark)}.upload-area__text{display:block;font-size:var(--font-size-base);color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.upload-area__hint{display:block;font-size:var(--font-size-sm);color:var(--color-text-muted)}.upload-area--dragging .upload-area__label{border-color:var(--color-primary);background-color:var(--color-primary-light);transform:scale(1.02)}.privacy-notice{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--privacy-notice-bg);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);border:1px solid var(--privacy-notice-border)}.privacy-notice__icon{width:20px;height:20px;color:var(--color-success);flex-shrink:0}.privacy-notice__github{display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-muted);transition:color var(--transition-fast);flex-shrink:0;margin-left:auto}.privacy-notice__github:hover{color:var(--color-text-primary)}.privacy-notice__github svg{width:18px;height:18px}.export-guide{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.export-guide__toggle{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-md);background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:color var(--transition-base)}.export-guide__toggle:hover{color:var(--color-text-primary)}.export-guide__icon{width:18px;height:18px;flex-shrink:0}.export-guide__chevron{width:16px;height:16px;flex-shrink:0;transition:transform var(--transition-base)}.export-guide__toggle[aria-expanded=true] .export-guide__chevron{transform:rotate(180deg)}.export-guide__content{overflow:hidden;transition:max-height var(--transition-slow)}.export-guide__content[hidden]{display:none}.export-guide__steps{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-md);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);margin-top:var(--spacing-sm)}.export-guide__platform{text-align:left}.export-guide__platform-label{display:inline-block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-surface);border-radius:var(--radius-sm)}.export-guide__list{margin:0;padding-left:var(--spacing-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.export-guide__list li{margin-bottom:var(--spacing-xs)}.export-guide__list li:last-child{margin-bottom:0}.export-guide__list strong{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}@media(max-width:600px){.export-guide__steps{grid-template-columns:1fr}}.results-section{animation:fadeIn var(--transition-slow);padding-top:var(--spacing-md)}.results-section:not([style*="display: none"])~* .main--centered,body:has(.results-section:not([style*="display: none"])) .main--centered{min-height:auto;align-items:flex-start}#resultsContainer{display:grid;gap:var(--spacing-xl);padding-bottom:7rem}#detailedStatsContainer{display:grid;gap:var(--spacing-xl);overflow:hidden;width:100%;max-width:100%}.date-filter{background:var(--date-filter-surface);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm),inset 0 1px #ffffff73;width:100%;max-width:100%}[data-theme=dark] .date-filter{background:var(--date-filter-surface);box-shadow:var(--shadow-sm),inset 0 1px #ffffff14}.date-filter-presets{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.date-filter-preset{border:1px solid var(--color-border);background-color:var(--color-bg);color:var(--color-text-secondary);border-radius:var(--radius-full);padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:border-color var(--transition-fast),background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.date-filter-preset:hover{border-color:var(--color-primary);color:var(--color-text-primary);transform:translateY(-1px)}.date-filter-preset:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.date-filter-preset--active{background-color:var(--color-primary);border-color:var(--color-primary-dark);color:var(--color-on-accent)}.date-filter-preset--active:hover{color:var(--color-on-accent);transform:none}.date-filter-custom{display:flex;flex-wrap:wrap;align-items:flex-end;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.date-filter-custom[hidden]{display:none}.date-filter-field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.date-filter-field__label{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:var(--font-weight-medium)}.date-filter-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-bg);color:var(--color-text-primary);padding:.5rem .625rem;min-width:150px}html:not([data-theme=dark]) .date-filter-preset,html:not([data-theme=dark]) .date-filter-input{border-color:#b8b8bf}.date-filter-input:focus-visible{outline:2px solid var(--color-primary);outline-offset:1px}.date-filter-custom__separator{color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:0 var(--spacing-xs) var(--spacing-sm)}.date-filter-apply{border:1px solid var(--color-primary-dark);background-color:var(--color-primary);color:var(--color-on-accent);border-radius:var(--radius-sm);padding:.5rem .9rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);min-height:40px;transition:opacity var(--transition-fast),transform var(--transition-fast)}.date-filter-apply:hover{background-color:var(--color-primary-dark)}.date-filter-apply:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.date-filter-apply:active{transform:scale(.98)}.date-filter-error{min-height:1.125rem;margin-bottom:var(--spacing-xs);color:var(--color-error);font-size:var(--font-size-xs)}.date-filter-info{margin-bottom:0;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.date-filter-range{margin-left:var(--spacing-xs)}.range-feedback{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);background:var(--color-surface);box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.range-feedback h3{margin:0 0 var(--spacing-sm);font-size:var(--font-size-lg)}.range-feedback p{margin:0;color:var(--color-text-secondary);line-height:var(--line-height-normal)}.range-feedback--empty{border-color:#ff950059;background:linear-gradient(180deg,#ff950014,#ff950008)}.range-feedback--limited{border-color:#34c75940;background:linear-gradient(180deg,#34c75914,#34c75908)}.range-feedback__action{border:1px solid var(--color-primary-dark);background:var(--color-primary);color:var(--color-on-accent);border-radius:var(--radius-md);padding:.625rem .875rem;font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);white-space:nowrap;transition:background-color var(--transition-fast),transform var(--transition-fast)}.range-feedback__action:hover{background-color:var(--color-primary-dark)}.range-feedback__action:active{transform:scale(.98)}.range-feedback__action:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media(max-width:768px){.date-filter-custom{align-items:stretch}.date-filter-field{width:100%}.date-filter-input{min-width:0;width:100%}.date-filter-custom__separator{padding:0;width:100%;text-align:center}.date-filter-apply{width:100%}.range-feedback{flex-direction:column;align-items:flex-start}.range-feedback__action{width:100%}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border:none;border-radius:var(--radius-md);transition:all var(--transition-base);min-height:44px;text-decoration:none}.btn:focus{outline:2px solid var(--color-primary);outline-offset:2px}.btn--secondary{background-color:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn--secondary:hover{background-color:var(--color-bg-secondary)}.btn--export{background-color:var(--color-surface);color:var(--color-text-primary);border:1px solid var(--color-border);display:flex;align-items:center;gap:var(--spacing-sm);font-weight:var(--font-weight-medium)}.btn--export:hover{background-color:var(--color-bg-secondary)}.btn__icon{width:20px;height:20px}.export-options{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-top:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.export-options__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-md);text-align:center}.export-options--inline{background-color:transparent;border:none;padding:0;margin:var(--spacing-xl) 0;display:flex;justify-content:center}.detailed-stats-toggle{display:flex;justify-content:center;margin:var(--spacing-xl) 0}.action-buttons{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);z-index:1000;display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);background:#ffffffb3;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-full);padding:var(--spacing-sm) var(--spacing-lg);box-shadow:0 10px 30px #00000014,0 2px 10px #0000000a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);max-width:90%;width:max-content;transition:all var(--transition-base);animation:slideUp var(--transition-slow)}[data-theme=dark] .action-buttons{background:#2a2a2dbf;border:1px solid rgba(255,255,255,.08);box-shadow:0 10px 30px #0000004d,0 2px 10px #0003}.action-buttons .btn{flex:0 0 auto;font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-lg);min-height:40px;border-radius:var(--radius-full)}.action-buttons .btn--secondary{background-color:transparent;border:1px solid var(--color-border)}.action-buttons .btn--secondary:hover{background-color:var(--color-bg-secondary)}.action-buttons--single{justify-content:center}.btn-text-extra{display:inline}@keyframes slideUp{0%{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%)}}@media(max-width:768px){.action-buttons{bottom:1rem;padding:var(--spacing-xs) var(--spacing-md);max-width:95%;width:max-content;gap:var(--spacing-sm)}.action-buttons .btn{padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-xs);min-height:36px}}@media(max-width:600px){.btn-text-extra{display:none}.action-buttons{max-width:95%;width:auto;display:flex;flex-direction:row;flex-wrap:nowrap;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;justify-content:flex-start;scrollbar-width:none}.action-buttons::-webkit-scrollbar{display:none}.action-buttons .btn{flex:0 0 auto;scroll-snap-align:center}}#detailedStatsContainer{margin-top:var(--spacing-lg)}.export-buttons{display:flex;gap:var(--spacing-md);flex-wrap:wrap;justify-content:center}@media(max-width:768px){.export-buttons{flex-direction:column}.btn--export{width:100%;justify-content:center}}@media print{.header,.footer,.export-options,.upload-section{display:none!important}body{background:#fff;color:#000}.result-card{page-break-inside:avoid;border:1px solid #ddd;margin-bottom:20px;padding:15px}.data-table{font-size:10px}.frequency-bar,.time-bar,.heatmap-day{print-color-adjust:exact;-webkit-print-color-adjust:exact}}.footer{background-color:var(--color-surface);border-top:1px solid var(--color-border);padding:var(--spacing-xl) 0;margin-top:auto}.footer__text{text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){:root{--container-padding: var(--spacing-md)}.main{padding:var(--spacing-sm) 0}.upload-card{padding:var(--spacing-lg) var(--spacing-lg) var(--spacing-md)}.hero-title{max-width:100%}.hero-title__whatsapp{font-size:.875rem;letter-spacing:.12em}.hero-title__recapped{font-size:clamp(2.5rem,15vw,4rem)}.hero-title__underline{max-width:200px}.upload-card__description{font-size:var(--font-size-base)}.upload-area__label{min-height:180px;padding:var(--spacing-lg)}}@media(max-width:480px){.hero-title__recapped{font-size:clamp(2rem,13vw,3rem)}.upload-card__description{font-size:var(--font-size-sm)}}.result-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl);box-shadow:var(--shadow-md);overflow:visible;word-wrap:break-word}[data-theme=dark] .result-card{box-shadow:0 8px 24px #00000059,0 2px 6px #00000040}.expand-promo-card{background:linear-gradient(135deg,#25d3660a,#128c7e0a);border:2px dashed rgba(37,211,102,.3)!important;padding:var(--spacing-xl);text-align:left;transition:all var(--transition-base)}[data-theme=dark] .expand-promo-card{background:linear-gradient(135deg,#30d1580d,#0a84ff0d);border:2px dashed rgba(48,209,88,.25)!important}.expand-promo-card:hover{border-color:var(--color-primary)!important;transform:translateY(-2px);box-shadow:0 12px 28px #00000014}[data-theme=dark] .expand-promo-card:hover{box-shadow:0 12px 28px #0000004d}.expand-promo-card__content{display:flex;align-items:center;gap:var(--spacing-xl);width:100%}.expand-promo-card__icon{font-size:var(--font-size-4xl);flex-shrink:0;animation:promoIconPulse 2s infinite ease-in-out}.expand-promo-card__text{flex:1}.expand-promo-card__text h4{font-size:var(--font-size-xl);margin-bottom:var(--spacing-xs);border-bottom:none!important;padding-bottom:0!important}.expand-promo-card__text p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin-bottom:0;line-height:var(--line-height-normal)}.expand-promo-card__btn{border:1px solid var(--color-primary-dark);background-color:var(--color-primary);color:var(--color-on-accent);border-radius:var(--radius-full);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);white-space:nowrap;box-shadow:0 4px 12px #25d36640;transition:all var(--transition-base)}.expand-promo-card__btn:hover{background-color:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #25d36659;color:var(--color-on-accent)}.expand-promo-card__btn:active{transform:translateY(0)}@keyframes promoIconPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media(max-width:768px){.expand-promo-card__content{flex-direction:column;text-align:center;gap:var(--spacing-md)}.expand-promo-card__icon{font-size:var(--font-size-3xl)}.expand-promo-card__btn{width:100%;justify-content:center}}.result-card h3{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.result-card p{margin-bottom:var(--spacing-sm)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg);overflow:hidden}.stat-item{display:flex;flex-direction:column;gap:var(--spacing-xs)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}[data-animate-to]{font-variant-numeric:tabular-nums}.stat-value[data-animate-to],.frequency-count[data-animate-to]{display:inline-block;min-width:3ch}.table-container{overflow-x:auto;overflow-y:visible;margin-top:var(--spacing-md);-webkit-overflow-scrolling:touch;max-width:100%}.data-table{width:100%;min-width:500px;border-collapse:collapse;font-size:var(--font-size-sm)}.data-table thead{background-color:var(--color-bg-secondary)}.data-table th{padding:var(--spacing-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);border-bottom:2px solid var(--color-border)}.data-table td{padding:var(--spacing-md);border-bottom:1px solid var(--color-border)}.data-table tbody tr:hover{background-color:var(--color-bg-secondary)}.data-table tbody tr:last-child td{border-bottom:none}.breakdown-section{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.breakdown-section h4{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-sm);color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.breakdown-section h4:first-child{margin-top:0}.breakdown-toggle{width:100%;margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center}.breakdown-toggle:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-primary)}.breakdown-toggle:active{transform:scale(.98)}@media(max-width:768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.stat-value{font-size:var(--font-size-xl)}.data-table{font-size:var(--font-size-xs)}.data-table th,.data-table td{padding:var(--spacing-sm)}}.frequency-list{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.frequency-item{display:grid;grid-template-columns:30px 1fr auto;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.frequency-item:hover{background-color:var(--color-bg-secondary)}.frequency-rank{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-muted);text-align:center}.frequency-content{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1;min-width:0}.frequency-label{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-transform:capitalize;word-break:break-word;overflow-wrap:break-word}.emoji-label{font-size:var(--font-size-2xl);text-transform:none}.frequency-bar-container{width:100%;height:8px;background-color:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden}.frequency-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius-full);transition:width var(--transition-slow)}.frequency-bar--emoji{background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark))}.frequency-count{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);min-width:40px;text-align:right}.frequency-list__hidden{display:flex;flex-direction:column;gap:var(--spacing-sm)}.frequency-list__show-more{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center}.frequency-list__show-more:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-primary)}.frequency-list__show-more:active{transform:scale(.98)}.catchphrase-list{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-md)}.catchphrase-item{display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md);transition:all var(--transition-fast);overflow:hidden;box-sizing:border-box}.catchphrase-item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.catchphrase-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-style:italic;word-wrap:break-word;overflow-wrap:break-word}.catchphrase-stats{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-sm)}.participant-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary-light);color:var(--color-primary-dark);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap}.catchphrase-total{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-left:auto;white-space:nowrap}.catchphrase-list__hidden{display:flex;flex-direction:column;gap:var(--spacing-md)}.catchphrase-list__show-more{margin-top:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center}.catchphrase-list__show-more:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-primary)}.catchphrase-list__show-more:active{transform:scale(.98)}.vocabulary-tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);border-bottom:2px solid var(--color-bg-secondary);overflow-x:auto;overflow-y:hidden;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.vocabulary-tabs::-webkit-scrollbar,.table-container::-webkit-scrollbar,.heatmap-scrollable::-webkit-scrollbar,.membership-timeline::-webkit-scrollbar{height:6px}.vocabulary-tabs::-webkit-scrollbar-track,.table-container::-webkit-scrollbar-track,.heatmap-scrollable::-webkit-scrollbar-track,.membership-timeline::-webkit-scrollbar-track{background:transparent}.vocabulary-tabs::-webkit-scrollbar-thumb,.table-container::-webkit-scrollbar-thumb,.heatmap-scrollable::-webkit-scrollbar-thumb,.membership-timeline::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full);transition:background var(--transition-fast)}.vocabulary-tabs::-webkit-scrollbar-thumb:hover,.table-container::-webkit-scrollbar-thumb:hover,.heatmap-scrollable::-webkit-scrollbar-thumb:hover,.membership-timeline::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.vocabulary-tab{padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-bottom:3px solid transparent;color:var(--color-text-secondary);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;margin-bottom:-2px}.vocabulary-tab:hover{color:var(--color-text-primary);background-color:var(--color-bg-secondary)}.vocabulary-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary);background-color:transparent}.vocabulary-tab-content{display:none}.vocabulary-tab-content--active{display:block}.vocabulary-non-qualifying{display:flex;flex-direction:column;margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px dashed var(--color-border);animation:fadeIn var(--transition-base) ease-in-out}.non-qualifying-header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xs)}.non-qualifying-icon{font-size:var(--font-size-lg)}.non-qualifying-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.non-qualifying-note{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-md)}.non-qualifying-list{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.non-qualifying-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:default;white-space:nowrap}.non-qualifying-list__hidden{display:none}.non-qualifying-list__hidden--visible{display:contents}.non-qualifying-list__show-more{width:100%;margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-align:center}.non-qualifying-list__show-more:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-primary)}.non-qualifying-list__show-more:active{transform:scale(.98)}.vocabulary-no-unique-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;background-color:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px dashed var(--color-border);margin-bottom:var(--spacing-md)}.vocabulary-no-unique-fallback .fallback-icon{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-sm)}.vocabulary-no-unique-fallback .fallback-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin:0;max-width:400px;line-height:var(--line-height-relaxed)}.card-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-md)}.no-data{text-align:center;color:var(--color-text-muted);font-style:italic;padding:var(--spacing-lg)}@media(max-width:768px){.frequency-item{grid-template-columns:25px 1fr 35px;gap:var(--spacing-sm)}.frequency-rank{font-size:var(--font-size-xs)}.frequency-label{font-size:var(--font-size-sm)}.emoji-label{font-size:var(--font-size-xl)}.frequency-count{font-size:var(--font-size-sm);min-width:30px}.catchphrase-text{font-size:var(--font-size-base)}.catchphrase-total{margin-left:0;width:100%}}.time-chart{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-md)}.time-chart-item{display:grid;grid-template-columns:80px 1fr 60px;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm);border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.time-chart-item:hover{background-color:var(--color-bg-secondary)}.time-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:left}.time-bar-container{width:100%;height:24px;background-color:var(--color-bg-secondary);border-radius:var(--radius-sm);overflow:hidden}.time-bar{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-dark));border-radius:var(--radius-sm);transition:width var(--transition-slow)}.time-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-align:right}.hour-bar-chart{display:flex;align-items:flex-end;gap:4px;height:200px;padding-top:20px;position:relative;margin-top:var(--spacing-md)}.time-section{position:absolute;top:0;bottom:24px;opacity:.15;border-radius:var(--radius-md)}.time-section--night{left:0;width:calc(25% - 2px);background:var(--time-section-night)}.time-section--morning{left:25%;width:calc(25% - 2px);background:var(--time-section-morning)}.time-section--afternoon{left:50%;width:calc(25% - 2px);background:var(--time-section-afternoon)}.time-section--evening{left:75%;width:calc(25% - 2px);background:var(--time-section-evening)}.hour-chart-time-labels{display:flex;margin-top:var(--spacing-xs)}.hour-chart-time-label{flex:1;text-align:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-xs) 0;border-radius:var(--radius-sm)}.hour-chart-time-label--night{color:var(--time-label-night);background:var(--time-label-night-bg)}.hour-chart-time-label--morning{color:var(--time-label-morning);background:var(--time-label-morning-bg)}.hour-chart-time-label--afternoon{color:var(--time-label-afternoon);background:var(--time-label-afternoon-bg)}.hour-chart-time-label--evening{color:var(--time-label-evening);background:var(--time-label-evening-bg)}.hour-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;height:100%;position:relative;z-index:1}.hour-bar-wrapper{flex:1;width:100%;display:flex;flex-direction:column;justify-content:flex-end}.hour-bar{width:100%;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:var(--radius-sm) var(--radius-sm) 0 0;min-height:2px;transition:all var(--transition-base);cursor:pointer}.hour-bar-item:hover .hour-bar{background:linear-gradient(180deg,var(--color-primary-bright) 0%,var(--color-primary) 100%);transform:scaleX(1.1)}.hour-bar-label{font-size:.65rem;color:var(--color-text-muted);margin-top:var(--spacing-xs);font-weight:var(--font-weight-medium)}.hour-bar-item--peak .hour-bar{background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);box-shadow:0 0 8px var(--color-success-glow)}.hour-chart-tooltip{position:fixed;background:var(--color-text-primary);color:var(--color-on-accent);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:100;white-space:nowrap;box-shadow:var(--shadow-md)}.hour-chart-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--color-text-primary)}.hour-chart-tooltip--visible{opacity:1}.hour-chart-summary{display:flex;justify-content:center;gap:var(--spacing-lg);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.hour-chart-summary-item strong{color:var(--color-primary)}.streak-details{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.streak-details h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-top:var(--spacing-md);margin-bottom:var(--spacing-sm)}.streak-details h4:first-child{margin-top:0}.streak-details p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.streak-active{color:var(--color-primary)!important}.streak-active-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--color-primary);color:var(--color-on-accent);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);margin-top:var(--spacing-xs)}.streak-inactive{color:var(--color-text-muted);font-style:italic;margin-top:var(--spacing-md)}.gap-details{margin-top:var(--spacing-lg);padding:var(--spacing-md);background-color:var(--color-bg-secondary);border-radius:var(--radius-md)}.gap-details p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin:0}.gap-details strong{color:var(--color-text-primary)}.gap-visualization{margin-top:var(--spacing-md)}.gap-chart-container{position:relative;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:var(--spacing-md)}.gap-chart{display:flex;align-items:flex-end;height:100px;gap:3px;position:relative}.gap-sparkline-bar{flex:1;min-width:4px;max-width:none;background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border-radius:3px 3px 0 0;min-height:4px;transition:all var(--transition-fast);cursor:pointer;position:relative}.gap-sparkline-bar:hover{filter:brightness(1.1);transform:scaleY(1.05);z-index:20}.gap-sparkline-bar--gap{background:linear-gradient(180deg,var(--gap-highlight-bar-start) 0%,var(--color-error) 100%);opacity:.5}.gap-sparkline-bar--no-tooltip{cursor:default}.gap-sparkline-bar--no-tooltip:before,.gap-sparkline-bar--no-tooltip:after{display:none}.gap-sparkline-bar--no-tooltip:hover{filter:none;transform:none}.gap-sparkline-bar:after{content:attr(data-date) "\a" attr(data-count);white-space:pre;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--color-text-primary);color:var(--color-on-accent);padding:6px 10px;border-radius:var(--radius-sm);font-size:.7rem;line-height:1.4;text-align:center;opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100;pointer-events:none;box-shadow:0 2px 8px #00000026}.gap-sparkline-bar:before{content:"";position:absolute;bottom:calc(100% + 2px);left:50%;transform:translate(-50%);border:5px solid transparent;border-top-color:var(--color-text-primary);opacity:0;visibility:hidden;transition:all var(--transition-fast);z-index:100}.gap-sparkline-bar:hover:after,.gap-sparkline-bar:hover:before{opacity:1;visibility:visible}.gap-overlay{position:absolute;top:0;height:100%;background:repeating-linear-gradient(45deg,var(--gap-highlight-stripe-soft),var(--gap-highlight-stripe-soft) 6px,var(--gap-highlight-stripe-strong) 6px,var(--gap-highlight-stripe-strong) 12px);border-left:3px solid var(--color-error);border-right:3px solid var(--color-error);display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none}.gap-overlay-content{display:flex;flex-direction:column;align-items:center;gap:2px;background:var(--gap-overlay-surface);padding:8px 16px;border-radius:var(--radius-md);box-shadow:var(--gap-overlay-shadow)}.gap-overlay-duration{font-size:1.1rem;font-weight:var(--font-weight-bold);color:var(--color-error);line-height:1}.gap-overlay-exact{font-size:.6rem;color:var(--color-text-muted);margin-top:2px}.gap-overlay-label{font-size:.65rem;font-weight:var(--font-weight-semibold);color:var(--color-error);text-transform:uppercase;letter-spacing:1.5px;opacity:.8}.gap-chart-labels{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);position:relative}.gap-chart-dates{position:absolute;transform:translate(-50%);color:var(--color-danger-strong);font-weight:var(--font-weight-bold);font-size:.7rem;background:var(--color-bg-secondary);padding:0 8px;z-index:5}.gap-chart-year-marker{position:absolute;transform:translate(-50%);font-size:.65rem;color:var(--color-text-muted);opacity:.7}.gap-participants{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-bg-secondary);border-radius:var(--radius-md)}.gap-participant{display:flex;align-items:center;gap:var(--spacing-sm)}.gap-participant--after{flex-direction:row-reverse}.gap-participant-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-border) 0%,var(--color-bg-tertiary) 100%);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:var(--font-weight-bold);color:var(--color-text-secondary);flex-shrink:0}.gap-participant-avatar--highlight{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-on-accent);box-shadow:var(--gap-participant-highlight-shadow)}.gap-participant-info{display:flex;flex-direction:column;gap:2px}.gap-participant-label{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.gap-participant-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.gap-participant-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.gap-participant-insight{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-md);background:var(--gap-insight-bg);border-radius:var(--radius-full);border:1px solid var(--gap-insight-border)}.gap-insight-icon{font-size:1rem}.gap-insight-text{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.gap-insight-name{color:var(--color-secondary);font-weight:var(--font-weight-bold)}@media(max-width:768px){.gap-chart{height:80px;gap:2px}.gap-sparkline-bar{min-width:3px}.gap-overlay-content{padding:6px 10px}.gap-overlay-duration{font-size:.9rem}.gap-overlay-label{font-size:.55rem}.gap-chart-labels{font-size:.65rem}.gap-chart-dates{font-size:.6rem}.gap-chart-year-marker{display:none}.gap-participants{flex-direction:column;gap:var(--spacing-sm)}.gap-participant{width:100%;justify-content:flex-start}.gap-participant--after{flex-direction:row}.gap-participant--after .gap-participant-info{text-align:left}.gap-participant-avatar{width:36px;height:36px;font-size:.75rem}.gap-participant-insight{order:-1;width:100%;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-xs)}}.heatmap-container{margin-top:var(--spacing-md)}.heatmap-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);flex-wrap:wrap;gap:var(--spacing-md)}.heatmap-year-tabs{display:flex;gap:var(--spacing-xs);flex-wrap:wrap}.heatmap-year-tab{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-base)}.heatmap-year-tab:hover{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-text-primary)}.heatmap-year-tab--active{background-color:var(--color-primary);border-color:var(--color-primary);color:var(--color-on-accent)}.heatmap-year-tab--active:hover{background-color:var(--color-primary-dark);border-color:var(--color-primary-dark)}.heatmap-year-count{font-size:var(--font-size-xs);opacity:.8}.heatmap-year-tab--active .heatmap-year-count{opacity:1}.heatmap-year-contents{position:relative}.heatmap-year-content{display:none}.heatmap-year-content--active{display:block}.heatmap-year-stats{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.heatmap-legend{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--color-text-muted)}.heatmap-legend-squares{display:flex;gap:var(--spacing-xs)}.heatmap-grid-wrapper{display:flex;gap:3px;position:relative}.heatmap-day-labels{display:flex;flex-direction:column;gap:3px;padding-top:calc(var(--font-size-xs) + var(--spacing-xs) + 3px);width:32px;flex-shrink:0}.heatmap-day-label{height:12px;font-size:10px;color:var(--color-text-muted);line-height:12px;text-align:right;padding-right:4px;white-space:nowrap}.heatmap-day-label--hidden{visibility:hidden}.heatmap-scrollable{overflow-x:auto;max-width:100%}.heatmap-month-labels{display:flex;gap:3px;margin-bottom:var(--spacing-xs)}.heatmap-month-label{width:12px;font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:left;white-space:nowrap;flex-shrink:0;overflow:visible}.heatmap-grid{display:flex;gap:3px;padding:0}.heatmap-week{display:flex;flex-direction:column;gap:3px}.heatmap-day{width:12px;height:12px;border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast)}.heatmap-day:hover:not(.heatmap-day--empty){transform:scale(1.2);box-shadow:var(--shadow-sm)}.heatmap-day--empty{background-color:transparent;cursor:default}.heatmap-day--level-0{background-color:var(--heatmap-empty)}.heatmap-day--level-1{background-color:var(--heatmap-level-1)}.heatmap-day--level-2{background-color:var(--heatmap-level-2)}.heatmap-day--level-3{background-color:var(--heatmap-level-3)}.heatmap-day--level-4{background-color:var(--heatmap-level-4)}.heatmap-info{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center}.heatmap-tooltip{position:fixed;background:var(--heatmap-tooltip-bg);color:var(--color-on-accent);padding:8px 12px;border-radius:var(--radius-md);font-size:var(--font-size-sm);pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:1000;box-shadow:0 4px 12px #00000026;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.heatmap-tooltip--visible{opacity:1}.heatmap-tooltip__count{font-weight:600;font-size:var(--font-size-base);margin-bottom:2px}.heatmap-tooltip__date{font-size:var(--font-size-xs);opacity:.85}@media(max-width:768px){.time-chart-item{grid-template-columns:70px 1fr 50px;gap:var(--spacing-sm)}.time-label{font-size:var(--font-size-xs)}.time-bar-container{height:20px}.time-count{font-size:var(--font-size-xs)}.hour-bar-chart{height:160px}.hour-bar-label{font-size:.55rem}.hour-chart-time-label{font-size:.6rem}.heatmap-header{flex-direction:column;align-items:stretch}.heatmap-year-tabs{justify-content:center}.heatmap-year-tab{flex:1;min-width:80px;justify-content:center}.heatmap-legend{justify-content:center}.heatmap-day-labels{width:18px;padding-top:calc(9px + var(--spacing-xs) + 2px)}.heatmap-day-label{height:10px;line-height:10px;font-size:9px}.heatmap-month-label{width:10px;font-size:9px}.heatmap-day{width:10px;height:10px}.heatmap-grid,.heatmap-week,.heatmap-grid-wrapper,.heatmap-month-labels{gap:2px}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.summary-card{--card-scale: 1;width:calc(1080px * var(--card-scale));height:calc(1920px * var(--card-scale));background:linear-gradient(165deg,#dcf8e8,#c8f0d8 40%,#b5e7c8);padding:calc(100px * var(--card-scale)) calc(70px * var(--card-scale));display:flex;flex-direction:column;justify-content:space-between;font-family:var(--font-family-base);box-sizing:border-box;position:relative;overflow:hidden;contain:layout style paint}.summary-card:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.03) 2px,rgba(255,255,255,.03) 4px);pointer-events:none;opacity:.5}.summary-card__header{text-align:center;color:#2d1810;margin-bottom:calc(30px * var(--card-scale));position:relative}.summary-card__title{font-family:Georgia,Playfair Display,serif;font-size:calc(76px * var(--card-scale));font-weight:700;margin-bottom:calc(18px * var(--card-scale));line-height:1;letter-spacing:calc(-.5px * var(--card-scale));font-style:italic;color:#2d1810}.summary-card__subtitle{font-size:calc(22px * var(--card-scale));font-weight:500;color:#5a3a28;letter-spacing:calc(2px * var(--card-scale));text-transform:uppercase}.summary-card__date-range{margin-top:calc(12px * var(--card-scale));font-size:calc(24px * var(--card-scale));font-weight:600;color:#2f6e43;letter-spacing:calc(.3px * var(--card-scale))}.summary-card__stats{display:flex;flex-direction:column;gap:calc(32px * var(--card-scale));flex:1;justify-content:center;padding:0;position:relative;z-index:1}.stat-card{background:#fffcf8f2;border-radius:calc(20px * var(--card-scale));padding:calc(42px * var(--card-scale)) calc(45px * var(--card-scale));box-shadow:0 calc(8px * var(--card-scale)) calc(32px * var(--card-scale)) #2d18101f,0 calc(2px * var(--card-scale)) calc(8px * var(--card-scale)) #2d181014;text-align:center;border:calc(2px * var(--card-scale)) solid rgba(255,255,255,.8);position:relative}.stat-card:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent calc(10px * var(--card-scale)),rgba(37,211,102,.02) calc(10px * var(--card-scale)),rgba(37,211,102,.02) calc(20px * var(--card-scale)));border-radius:calc(20px * var(--card-scale));pointer-events:none}.stat-card--featured{background:linear-gradient(135deg,#30d158,#25d366,#1da851);color:#fff;padding:calc(55px * var(--card-scale)) calc(50px * var(--card-scale));transform:scale(1.05) rotate(-.5deg);box-shadow:0 calc(16px * var(--card-scale)) calc(48px * var(--card-scale)) #25d3664d,0 calc(4px * var(--card-scale)) calc(12px * var(--card-scale)) #00000026;border:calc(3px * var(--card-scale)) solid rgba(255,255,255,.4)}.stat-card--featured:after{display:none}.stat-card--featured:before{content:"★";position:absolute;top:calc(20px * var(--card-scale));right:calc(25px * var(--card-scale));font-size:calc(42px * var(--card-scale));opacity:.25;color:#fff}.stat-card__value{font-family:Georgia,serif;font-size:calc(82px * var(--card-scale));font-weight:700;line-height:1;margin-bottom:calc(16px * var(--card-scale));color:#1a5f3e;letter-spacing:calc(-1px * var(--card-scale))}.stat-card--featured .stat-card__value{font-size:calc(96px * var(--card-scale));color:#fff;text-shadow:0 calc(4px * var(--card-scale)) calc(12px * var(--card-scale)) rgba(0,0,0,.2)}.stat-card__label{font-size:calc(18px * var(--card-scale));font-weight:600;color:#2d6b4b;text-transform:uppercase;letter-spacing:calc(3px * var(--card-scale))}.stat-card--featured .stat-card__label{font-size:calc(21px * var(--card-scale));color:#fffffff2;letter-spacing:calc(3px * var(--card-scale))}.summary-card__footer{text-align:center;color:#1a5f3e;font-size:calc(18px * var(--card-scale));font-weight:600;letter-spacing:calc(4px * var(--card-scale));text-transform:uppercase;opacity:.7;margin-top:calc(30px * var(--card-scale))}.wrapped-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{to{opacity:0}}.wrapped-modal__container{background:transparent;border-radius:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;position:relative}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.wrapped-modal__card-wrapper{width:540px;height:960px;margin:0 auto 24px;box-shadow:0 20px 60px #0006;border-radius:24px;overflow:hidden}.wrapped-modal__card-wrapper .summary-card{width:540px;height:960px}.wrapped-modal__actions{display:flex;gap:16px;justify-content:center;padding-bottom:20px}.wrapped-modal__btn{padding:16px 32px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;border:none;transition:all .2s ease;display:flex;align-items:center;gap:8px}.wrapped-modal__btn--primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-on-accent);box-shadow:0 4px 16px #25d3664d}.wrapped-modal__btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #25d36666}.wrapped-modal__btn--secondary{background:#ffffff26;color:var(--color-on-accent);border:2px solid rgba(255,255,255,.3)}.wrapped-modal__btn--secondary:hover{background:#ffffff40;border-color:#ffffff80}.wrapped-modal__btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.wrapped-modal__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 40px;color:var(--color-on-accent);gap:20px}.wrapped-modal__loading p{font-size:18px;font-weight:500;opacity:.9}.wrapped-modal__spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--color-on-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.wrapped-modal__card-wrapper,.wrapped-modal__card-wrapper .summary-card{width:270px;height:480px}.wrapped-modal__actions{flex-direction:column}.wrapped-modal__btn{width:100%}}.wrapped-hero{margin-bottom:var(--spacing-xl)}.wrapped-hero--header-only{margin-bottom:0}.wrapped-hero__header{text-align:center;margin-bottom:var(--spacing-lg);padding:var(--spacing-md) 0}.wrapped-hero__header h2{font-size:1.75rem;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-weight:var(--font-weight-semibold)}.wrapped-hero__header p{color:var(--color-text-secondary);font-size:1rem;font-weight:var(--font-weight-medium)}.wrapped-section{background:var(--wrapped-section-surface);border:1px solid var(--wrapped-section-border);border-radius:var(--border-radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);box-shadow:var(--shadow-sm)}.wrapped-section:last-child{margin-bottom:0}.wrapped-insights{margin-bottom:var(--spacing-lg)}.wrapped-section h3{margin-bottom:var(--spacing-md);font-size:1.25rem;color:var(--color-text-primary)}.badge-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:1024px){.badge-grid{grid-template-columns:repeat(2,1fr)}}.badge-card{background:var(--wrapped-result-surface);border:1px solid var(--wrapped-result-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.badge-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.badge-card__icon{font-size:2.5rem;margin-bottom:var(--spacing-sm)}.badge-card__title{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.badge-card__winner{font-size:1.3rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-xs)}.badge-card__description{font-size:.9rem;color:var(--color-text-secondary)}.year-review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-md)}@media(max-width:1024px){.year-review-grid{grid-template-columns:repeat(2,1fr)}}.year-review-card{background:var(--wrapped-result-surface);border:1px solid var(--wrapped-result-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);text-align:center;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.year-review-card:hover{transform:translateY(-2px)}.year-review-card__value{font-size:2rem;font-weight:700;color:var(--color-primary);margin-bottom:var(--spacing-sm);word-break:break-word}.year-review-card__label{font-size:.9rem;color:var(--color-text-secondary);margin-bottom:var(--spacing-xs);font-weight:600}.year-review-card__detail{font-size:.85rem;color:var(--color-text-tertiary)}.fun-facts-list{display:grid;gap:var(--spacing-md)}.fun-fact-item{background:var(--wrapped-result-surface);border:1px solid var(--wrapped-result-border);border-radius:var(--border-radius-md);padding:var(--spacing-md);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-fast)}.fun-fact-item:hover{transform:translate(4px)}.fun-fact-item__icon{font-size:1.75rem;flex-shrink:0}.fun-fact-item__content{flex:1}.fun-fact-item__title{font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1rem}.fun-fact-item__description{font-size:.9rem;color:var(--color-text-secondary);line-height:1.5}@media(max-width:768px){.wrapped-hero__header h2{font-size:1.5rem}.wrapped-hero__header p{font-size:.875rem}.badge-grid{grid-template-columns:1fr}.year-review-grid{grid-template-columns:repeat(2,1fr)}.year-review-card__value{font-size:1.5rem}.fun-fact-item{flex-direction:column;text-align:center}.fun-fact-item__icon{font-size:2rem}}.group-dynamics-section{margin-top:2rem}.group-dynamics-section h2{margin-bottom:0}.group-dynamics-section h3{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:1rem}.dynamics-summary-stats{display:flex;justify-content:space-around;background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.dynamics-stat{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:80px}.dynamics-stat-value{font-size:1.75rem;font-weight:700;line-height:1.2}.dynamics-stat-positive{color:var(--color-success-strong)}.dynamics-stat-negative{color:var(--color-danger-strong)}.dynamics-stat-label{font-size:.8rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.stability-meter-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.stability-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.stability-header h3{margin-bottom:0}.stability-label{font-size:.85rem;font-weight:600;padding:.25rem .75rem;border-radius:20px}.stability-label.stability-high{background:#05966926;color:var(--color-success-strong)}.stability-label.stability-good{background:#34c75926;color:var(--color-success)}.stability-label.stability-medium{background:#ff950026;color:var(--color-warning)}.stability-label.stability-low{background:#ff3b3026;color:var(--color-error)}.stability-meter{position:relative;height:12px;background:var(--color-bg-tertiary);border-radius:6px;overflow:hidden;margin-bottom:.5rem}.stability-meter-fill{height:100%;border-radius:6px;transition:width .5s ease-out}.stability-meter-fill.stability-high{background:linear-gradient(90deg,var(--color-success-strong),var(--color-success))}.stability-meter-fill.stability-good{background:linear-gradient(90deg,var(--color-success),#7cd992)}.stability-meter-fill.stability-medium{background:linear-gradient(90deg,var(--color-warning),#ffb84d)}.stability-meter-fill.stability-low{background:linear-gradient(90deg,var(--color-error),#ff6b63)}.stability-meter-markers{display:flex;justify-content:space-between;font-size:.7rem;color:var(--color-text-muted)}.stability-description{font-size:.9rem;color:var(--color-text-secondary);margin-top:.75rem}.membership-timeline-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.timeline-subtitle{font-size:.8rem;color:var(--color-text-secondary);margin-bottom:.75rem}.timeline-legend{display:flex;gap:1.5rem;margin-bottom:1rem;font-size:.8rem}.legend-item{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary)}.legend-color{width:12px;height:12px;border-radius:3px}.legend-join{background:var(--color-success-strong)}.legend-exit{background:var(--color-danger-strong)}.membership-timeline{display:flex;align-items:flex-end;gap:4px;height:120px;overflow-x:auto;padding-bottom:1.5rem;padding-top:1.25rem}.timeline-bar-group{position:relative;display:flex;flex-direction:column;align-items:center;flex:1;min-width:30px;max-width:50px;height:100%;cursor:pointer}.timeline-bars{display:flex;gap:2px;align-items:flex-end;height:calc(100% - 20px);width:100%}.timeline-bar{flex:1;min-height:2px;border-radius:2px 2px 0 0;transition:opacity .2s}.timeline-bar-join{background:var(--color-success-strong)}.timeline-bar-exit{background:var(--color-danger-strong)}.timeline-bar-group:hover .timeline-bar{opacity:.7}.timeline-label{font-size:.65rem;color:var(--color-text-muted);margin-top:4px;white-space:nowrap}.timeline-bar-group.year-start{margin-left:8px;padding-left:8px;border-left:2px solid var(--color-border)}.timeline-bar-group.year-start:first-child{margin-left:0;padding-left:0;border-left:none}.timeline-year-marker{position:absolute;top:-18px;left:50%;transform:translate(-50%);font-size:.7rem;font-weight:600;color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:0 4px;white-space:nowrap}.dynamics-badges-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.dynamics-badges-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.dynamics-badge-card{display:flex;gap:1rem;padding:1rem;background:var(--color-surface);border-radius:10px;border:1px solid var(--color-border);transition:transform .2s,box-shadow .2s}.dynamics-badge-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.badge-emoji{font-size:2rem;line-height:1}.badge-info{flex:1}.badge-title{font-weight:700;font-size:1rem;color:var(--color-text-primary);margin-bottom:.25rem}.badge-recipient{font-weight:600;color:var(--color-primary-dark);font-size:.9rem}.badge-description{font-size:.8rem;color:var(--color-text-secondary);margin-top:.25rem}.badge-stat{font-size:.75rem;color:var(--color-text-muted);margin-top:.25rem;font-style:italic}.revolving-door-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.revolving-door-subtitle{font-size:.85rem;color:var(--color-text-secondary);margin-top:-.5rem;margin-bottom:1rem}.revolving-door-list{display:flex;flex-direction:column;gap:.75rem}.revolving-door-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.revolving-door-rank{font-weight:700;font-size:.9rem;color:var(--color-text-muted);min-width:30px}.revolving-door-name{flex:1;font-weight:600;color:var(--color-text-primary)}.revolving-door-stats{display:flex;gap:1rem;font-size:.8rem}.revolving-door-count{color:var(--color-primary-dark);font-weight:600}.revolving-door-time{color:var(--color-text-secondary)}.retention-insights-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;border:1px solid var(--color-border)}.retention-insights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.retention-insight{text-align:center;padding:1rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px}.retention-insight-value{font-size:1.75rem;font-weight:700;color:var(--color-primary-dark);margin-bottom:.25rem}.retention-insight-label{font-size:.9rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.5rem}.retention-insight-detail{font-size:.75rem;color:var(--color-text-secondary);line-height:1.4}.result-card h4{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.75rem}.dynamics-breakdown{margin-bottom:1rem}.social-graph-container{background:var(--color-bg-secondary);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.social-graph-container h4{margin-bottom:1rem}.social-graph-subsection{margin-bottom:1.5rem}.social-graph-subsection:last-child{margin-bottom:0}.social-graph-subsection h5{font-size:.9rem;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.social-graph-subtitle{font-size:.75rem;color:var(--color-text-secondary);margin-bottom:.75rem}.social-graph-list{display:flex;flex-direction:column;gap:.5rem}.social-graph-item{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.75rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;font-size:.85rem}.exodus-event{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;flex:1}.exodus-leader{font-weight:600;color:var(--color-text-primary)}.exodus-action{color:var(--color-text-secondary)}.exodus-followers{font-weight:600;color:var(--color-danger-strong)}.exodus-window{color:var(--color-text-muted);font-size:.8rem}.exodus-date{font-size:.75rem;color:var(--color-text-muted)}.influence-name{font-weight:600;color:var(--color-text-primary)}.influence-stat{color:var(--color-text-secondary)}.influence-detail{font-size:.75rem;color:var(--color-text-muted);width:100%}.recruiter-item{justify-content:space-between}.recruiter-name{font-weight:600;color:var(--color-text-primary)}.recruiter-stats{display:flex;gap:.75rem;font-size:.8rem}.recruiter-added{color:var(--color-text-secondary)}.recruiter-retention{font-weight:600}.recruiter-retention.retention-high{color:var(--color-success-strong)}.recruiter-retention.retention-medium{color:var(--color-warning)}.recruiter-retention.retention-low{color:var(--color-danger-strong)}@media(max-width:600px){.dynamics-summary-stats{padding:1rem}.dynamics-stat-value{font-size:1.4rem}.dynamics-badges-grid{grid-template-columns:1fr}.revolving-door-item{flex-wrap:wrap}.revolving-door-stats{width:100%;justify-content:flex-start;margin-top:.25rem;margin-left:40px}.retention-insights-grid{grid-template-columns:1fr}.membership-timeline{height:100px}.social-graph-item{flex-direction:column;align-items:flex-start}.recruiter-item{flex-direction:row;flex-wrap:wrap}.recruiter-stats{width:100%;margin-top:.25rem}}.table-toggle-btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.table-toggle-btn:hover{background-color:var(--color-bg-tertiary);color:var(--color-text-primary);border-color:var(--color-primary)}.table-toggle-btn:active{transform:scale(.98)}.table-toggle-icon{width:16px;height:16px;transition:transform var(--transition-fast)}.table-toggle-btn[data-expanded=true] .table-toggle-icon{transform:rotate(180deg)}.analysis-loader{margin:var(--spacing-xl) 0;padding:var(--spacing-xl);background:#1e1e1e73;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg),inset 0 1px #ffffff0d;text-align:left;animation:scaleUpIn var(--transition-base) forwards}[data-theme=light] .analysis-loader{background:#ffffffa6;border-color:#0000000f;box-shadow:var(--shadow-lg),inset 0 1px #fffc}.analysis-loader__content{max-width:480px;margin:0 auto}.analysis-loader__header{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:var(--spacing-xl)}.analysis-loader__spinner{position:relative;width:64px;height:64px;margin-bottom:var(--spacing-md)}.analysis-loader__spinner-svg{width:100%;height:100%;transform:rotate(-90deg)}.analysis-loader__spinner-track{stroke:#ffffff0d}[data-theme=light] .analysis-loader__spinner-track{stroke:#0000000d}.analysis-loader__spinner-thumb{stroke:var(--color-primary);stroke-linecap:round;stroke-dasharray:125;stroke-dashoffset:125;animation:spinCircle 2s linear infinite}.analysis-loader__icon-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;animation:pulseScale 2s ease-in-out infinite}.analysis-loader__title{font-size:var(--font-size-xl);margin:0 0 var(--spacing-xs);font-weight:var(--font-weight-semibold)}.analysis-loader__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.analysis-loader__progress-container{width:100%;height:6px;background-color:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-xl);border:1px solid rgba(255,255,255,.03)}.analysis-loader__progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-full);box-shadow:0 0 8px var(--color-primary-bright);transition:width .3s cubic-bezier(.4,0,.2,1)}.analysis-loader__steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.analysis-loader__step{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:color var(--transition-base)}.analysis-loader__step-indicator{width:18px;height:18px;border-radius:50%;border:2px solid var(--color-border);position:relative;flex-shrink:0;transition:all var(--transition-base)}.analysis-loader__step-text{font-weight:var(--font-weight-medium)}.analysis-loader__step--active{color:var(--color-text-primary)}.analysis-loader__step--active .analysis-loader__step-indicator{border-color:var(--color-secondary);background-color:transparent}.analysis-loader__step--active .analysis-loader__step-indicator:after{content:"";position:absolute;top:50%;left:50%;width:6px;height:6px;border-radius:50%;background-color:var(--color-secondary);transform:translate(-50%,-50%);animation:stepPulse 1.2s ease-in-out infinite}.analysis-loader__step--completed{color:var(--color-success)}.analysis-loader__step--completed .analysis-loader__step-indicator{border-color:var(--color-success);background-color:var(--color-success)}.analysis-loader__step--completed .analysis-loader__step-indicator:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:10px;color:#fff;font-weight:700}@keyframes scaleUpIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes spinCircle{0%{stroke-dashoffset:125;transform:rotate(0)}50%{stroke-dashoffset:25;transform:rotate(180deg)}to{stroke-dashoffset:125;transform:rotate(360deg)}}@keyframes pulseScale{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.15)}}@keyframes stepPulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.3);opacity:1}to{transform:translate(-50%,-50%) scale(.8);opacity:.5}}
