*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #141210;--bg-secondary: #1C1917;--bg-card: #24201D;--primary-accent: #C7A27C;--accent-hover: #A67B5B;--text-primary: #F5F1EC;--text-secondary: #B8AEA4;--text-muted: #8E8276;--success: #8FB996;--success-bg: rgba(143, 185, 150, .05);--success-border: rgba(143, 185, 150, .15);--error: #D68C8C;--error-bg: rgba(214, 140, 140, .05);--error-border: rgba(214, 140, 140, .15);--border-light: rgba(255, 255, 255, .06);--border-focus: rgba(199, 162, 124, .35);--radius-lg: 16px;--radius-md: 12px;--radius-sm: 8px;--shadow-soft: 0 12px 30px rgba(0, 0, 0, .4), 0 2px 10px rgba(0, 0, 0, .2);--shadow-hover: 0 24px 50px rgba(0, 0, 0, .6), 0 2px 15px rgba(0, 0, 0, .3);--shadow-active: 0 4px 10px rgba(0, 0, 0, .25);--glow-accent: 0 0 25px rgba(199, 162, 124, .12)}body{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-base);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-wrapper{min-height:100vh;display:flex;align-items:flex-start;justify-content:center;padding:80px 24px 120px;background-image:radial-gradient(circle at 10% 20%,rgba(199,162,124,.02) 0%,transparent 40%),radial-gradient(circle at 90% 80%,rgba(166,123,91,.02) 0%,transparent 40%)}.container{width:100%;max-width:1100px;display:flex;flex-direction:column;gap:32px;animation:fade-in .8s cubic-bezier(.16,1,.3,1) both}@keyframes fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.header{text-align:center;margin-bottom:8px}.hero-tag{display:inline-flex;align-items:center;font-size:.725rem;font-weight:600;text-transform:uppercase;letter-spacing:.15em;color:var(--primary-accent);background-color:#c7a27c14;border:1px solid rgba(199,162,124,.15);padding:6px 16px;border-radius:100px;margin-bottom:18px}.title{font-size:2.75rem;font-weight:800;letter-spacing:-.035em;color:var(--text-primary);margin-bottom:12px;line-height:1.15}.subtitle{font-size:1.05rem;color:var(--text-secondary);font-weight:400;line-height:1.6;max-width:520px;margin:0 auto}.card{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:40px;box-shadow:var(--shadow-soft);transition:transform .4s cubic-bezier(.16,1,.3,1),box-shadow .4s cubic-bezier(.16,1,.3,1),border-color .4s cubic-bezier(.16,1,.3,1)}.card:hover{box-shadow:var(--shadow-hover);border-color:#ffffff1a}.drop-zone{border:1px dashed rgba(255,255,255,.15);border-radius:var(--radius-md);min-height:240px;display:flex;align-items:center;justify-content:center;cursor:pointer;background-color:#14121066;transition:all .35s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;margin-bottom:24px}.drop-zone:hover:not(.has-file){border-color:var(--primary-accent);background-color:#1c191799;box-shadow:var(--glow-accent);transform:translateY(-2px)}.drop-zone.dragging{border-color:var(--primary-accent);background-color:#c7a27c0d;box-shadow:var(--glow-accent);transform:scale(1.015)}.drop-zone.has-file{cursor:default;border-style:solid;border-color:var(--border-light)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:16px;padding:40px;text-align:center}.upload-icon-wrapper{width:56px;height:56px;border-radius:12px;background-color:#ffffff08;border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1)}.drop-zone:hover:not(.has-file) .upload-icon-wrapper{background-color:#c7a27c1a;border-color:#c7a27c4d;transform:scale(1.05)}.upload-icon{width:24px;height:24px;color:var(--text-secondary)}.drop-label{font-size:1rem;font-weight:500;color:var(--text-primary)}.drop-sublabel{font-size:.875rem;color:var(--text-secondary);margin-top:-6px}.file-types{font-size:.75rem;color:var(--text-muted);background-color:#ffffff05;padding:4px 14px;border-radius:100px;border:1px solid var(--border-light);margin-top:4px}.preview-container{width:100%;height:100%;position:relative;border-radius:calc(var(--radius-md) - 2px);overflow:hidden;box-shadow:var(--shadow-soft)}.preview-image{width:100%;height:100%;min-height:240px;max-height:400px;object-fit:cover;display:block}.preview-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,#141210f2,#14121000);padding:24px 20px 16px;display:flex;justify-content:space-between;align-items:flex-end}.preview-filename{font-size:.875rem;font-weight:500;color:var(--text-primary);max-width:70%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.preview-size{font-size:.75rem;color:var(--text-primary);opacity:.9;background:#ffffff14;border:1px solid var(--border-light);padding:3px 10px;border-radius:100px}.hidden-input{display:none}.button-row{display:flex;gap:12px;width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;border-radius:var(--radius-sm);font-family:inherit;font-size:.925rem;font-weight:500;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);border:none;outline:none}.btn-primary{flex:2;background-color:var(--primary-accent);color:#141210;font-weight:600;box-shadow:0 4px 14px #c7a27c26}.btn-primary:hover:not(:disabled){background-color:#dbc4a9;transform:translateY(-1px);box-shadow:0 6px 20px #c7a27c40}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{flex:1;background-color:#ffffff0a;color:var(--text-secondary);border:1px solid var(--border-light)}.btn-secondary:hover{background-color:#ffffff14;color:var(--text-primary);border-color:#ffffff26}.btn-outline{background-color:transparent;color:var(--text-secondary);border:1px solid var(--border-light);width:100%;margin-top:16px;font-size:.875rem;border-radius:var(--radius-sm);padding:12px 20px}.btn-outline:hover{background-color:#ffffff0a;border-color:var(--primary-accent);color:var(--text-primary)}.spinner{width:16px;height:16px;border:2px solid rgba(20,18,16,.3);border-top-color:var(--text-primary);border-radius:50%;animation:spin .6s linear infinite}.status-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:20px;padding:40px}.loading-card{background-color:var(--bg-card);border-color:var(--border-light)}.status-icon-wrapper{width:52px;height:52px;border-radius:50%;background-color:#ffffff08;border:1px solid var(--border-light);display:flex;align-items:center;justify-content:center;font-size:24px}.status-icon-wrapper.pulse{animation:pulse-ring 1.8s ease-in-out infinite}@keyframes pulse-ring{0%{transform:scale(.96);box-shadow:0 0 #c7a27c26}70%{transform:scale(1.04);box-shadow:0 0 0 10px #c7a27c00}to{transform:scale(.96);box-shadow:0 0 #c7a27c00}}.status-title{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.status-description{font-size:.9rem;color:var(--text-secondary);line-height:1.5}.progress-bar{width:100%;max-width:240px;height:3px;background-color:#ffffff0a;border-radius:100px;overflow:hidden}.progress-fill{height:100%;width:40%;background-color:var(--primary-accent);border-radius:100px;animation:progress-slide 1.5s ease-in-out infinite}@keyframes progress-slide{0%{transform:translate(-150%);width:40%}50%{width:50%}to{transform:translate(250%);width:40%}}.result-card{border-left:4px solid var(--primary-accent)}.result-card.success{border-left-color:var(--success);background-color:var(--success-bg)}.result-card.neutral{border-left-color:var(--primary-accent);background-color:var(--bg-card)}.result-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:16px}.result-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;border-radius:100px;font-size:.775rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.badge-success{background-color:#8fb9961f;color:var(--success);border:1px solid rgba(143,185,150,.18)}.badge-neutral{background-color:#ffffff08;color:var(--text-secondary);border:1px solid var(--border-light)}.confidence-score{font-size:.85rem;color:var(--text-muted);font-weight:500}.confidence-highlight{color:var(--primary-accent);font-weight:600}.result-message{font-size:.95rem;color:var(--text-secondary);line-height:1.6;text-align:left;width:100%;margin-bottom:24px}.s3-url-box{width:100%;background-color:#0003;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px;text-align:left;margin-bottom:20px}.s3-label{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.s3-link-container{display:flex;align-items:center;justify-content:space-between;gap:12px}.s3-link{font-size:.85rem;color:var(--primary-accent);text-decoration:none;word-break:break-all;line-height:1.5;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.s3-link:hover{color:#f5f1ec;text-decoration:underline}.btn-copy{background:none;border:none;padding:6px;cursor:pointer;color:var(--text-muted);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-copy:hover{color:var(--text-primary);background-color:#ffffff0a}.error-card{background-color:var(--error-bg);border-color:var(--border-light);border-left:4px solid var(--error)}.error-badge{background-color:#d68c8c1f;color:var(--error);display:inline-flex;padding:6px 14px;border-radius:100px;font-size:.775rem;font-weight:600;text-transform:uppercase;border:1px solid rgba(214,140,140,.18)}.error-message{font-size:.925rem;color:var(--text-secondary);line-height:1.6;margin-top:12px;margin-bottom:20px}.history-section{display:flex;flex-direction:column;gap:20px;margin-top:12px}.history-header{display:flex;justify-content:space-between;align-items:center}.history-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.btn-clear-history{background:none;border:none;color:var(--text-muted);font-size:.8rem;cursor:pointer;font-weight:500;transition:color .2s}.btn-clear-history:hover{color:var(--error)}.history-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.history-item{background-color:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-soft);display:flex;flex-direction:column;transition:all .35s cubic-bezier(.16,1,.3,1);position:relative}.history-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-hover);border-color:#ffffff1a}.history-img-wrapper{position:relative;aspect-ratio:16 / 10;background-color:#00000026;overflow:hidden}.history-img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.history-item:hover .history-img{transform:scale(1.04)}.history-item-badge{position:absolute;top:10px;right:10px;font-size:.65rem;font-weight:600;padding:4px 8px;border-radius:100px;text-transform:uppercase;background-color:#8fb99633;color:var(--success);border:1px solid rgba(143,185,150,.3)}.history-info{padding:16px;display:flex;flex-direction:column;gap:8px;flex-grow:1}.history-meta-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.history-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.history-confidence{font-size:.775rem;font-weight:600;color:var(--primary-accent)}.history-date{font-size:.75rem;color:var(--text-muted)}.history-actions{display:flex;align-items:center;justify-content:space-between;margin-top:auto;border-top:1px solid var(--border-light);padding-top:12px}.history-link{font-size:.8rem;font-weight:500;color:var(--primary-accent);text-decoration:none;display:inline-flex;align-items:center;gap:4px}.history-link:hover{color:#fffdf9}.btn-delete-item{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-delete-item:hover{color:var(--error);background-color:var(--error-bg)}.history-empty{grid-column:span 2;padding:48px;text-align:center;color:var(--text-muted);border:1px dashed var(--border-light);border-radius:var(--radius-md);background-color:#ffffff03;font-size:.9rem;display:flex;flex-direction:column;align-items:center;gap:12px}.history-empty-icon{font-size:24px;color:var(--text-muted);opacity:.5}.footer{text-align:center;margin-top:24px}.footer p{font-size:.8rem;color:var(--text-muted);display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px}.tech-badge{background-color:var(--bg-card);border:1px solid var(--border-light);padding:4px 12px;border-radius:100px;color:var(--text-secondary);font-size:.75rem;font-weight:500;transition:all .2s ease}.tech-badge:hover{background-color:#ffffff0a;border-color:var(--primary-accent);color:var(--text-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--bg-card);border-radius:10px;border:2px solid var(--bg-base)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}@media (max-width: 600px){.app-wrapper{padding:40px 16px 80px}.card{padding:28px 24px}.button-row{flex-direction:column}.btn{width:100%}.btn-secondary{order:2}.title{font-size:2.25rem}.history-grid{grid-template-columns:1fr}.history-empty{grid-column:span 1}.video-summary-grid{grid-template-columns:repeat(2,1fr)}}.mode-tabs{display:flex;gap:6px;padding:6px;background:var(--bg-secondary);border-radius:14px;border:1px solid var(--border);width:fit-content;margin:0 auto 24px}.mode-tab{display:flex;align-items:center;gap:7px;padding:9px 20px;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease;letter-spacing:.01em}.mode-tab:hover{color:var(--text-primary);background:#c7a27c14}.mode-tab.active{background:var(--card-bg);color:var(--primary-accent);border:1px solid var(--border);box-shadow:0 2px 8px #0000004d}.video-selected-state{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 0}.video-icon-wrapper{width:72px;height:72px;border-radius:50%;background:#c7a27c1a;display:flex;align-items:center;justify-content:center;border:1px solid rgba(199,162,124,.2)}.video-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}.video-stat-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:16px 12px;text-align:center;transition:border-color .2s ease}.video-stat-card:hover{border-color:#c7a27c4d}.video-stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:6px;letter-spacing:-.02em}.video-stat-label{font-size:.725rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.history-item-badge.badge-video{background:#b0c4de1f;color:#b0c4de;border-color:#b0c4de40}.face-list{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;width:100%}.face-item{background-color:#0000002e;border:1px solid var(--border-light);border-radius:var(--radius-md);padding:14px 18px;display:flex;flex-direction:column;gap:10px;transition:border-color .25s ease}.face-item:hover{border-color:#c7a27c33}.face-item-header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.face-item-number{font-size:.9rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.face-item .s3-url-box{background-color:#0000001f;padding:12px 14px}.dashboard-layout{display:flex;flex-direction:column;gap:28px;animation:fade-in .6s cubic-bezier(.16,1,.3,1) both}.dashboard-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media (min-width: 550px){.dashboard-stats{grid-template-columns:repeat(4,1fr)}}.dashboard-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px 16px;text-align:center;box-shadow:var(--shadow-soft);transition:all .3s ease}.dashboard-card:hover{transform:translateY(-2px);border-color:#c7a27c33;box-shadow:var(--shadow-hover)}.dashboard-card-val{font-size:1.85rem;font-weight:800;color:var(--primary-accent);margin-bottom:6px;letter-spacing:-.02em}.dashboard-card-label{font-size:.725rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.dashboard-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 650px){.dashboard-grid{grid-template-columns:1.2fr .8fr}}.dashboard-panel{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-soft)}.dashboard-panel-title{font-size:1rem;font-weight:700;color:var(--text-primary);margin-bottom:20px;letter-spacing:-.01em;display:flex;align-items:center;gap:8px}.chart-container{height:180px;display:flex;align-items:flex-end;justify-content:space-between;padding:10px 0 20px;border-bottom:1px solid rgba(255,255,255,.06);position:relative}.chart-bar-wrapper{display:flex;flex-direction:column;align-items:center;flex:1;height:100%;justify-content:flex-end;gap:8px}.chart-bar{width:24px;background:linear-gradient(180deg,var(--primary-accent) 0%,rgba(199,162,124,.2) 100%);border-radius:4px 4px 0 0;transition:height .6s ease;min-height:4px;position:relative}.chart-bar:hover{background:var(--primary-accent);box-shadow:0 0 12px #c7a27c66}.chart-bar-tooltip{position:absolute;top:-28px;left:50%;transform:translate(-50%);background:var(--bg-base);color:var(--text-primary);font-size:.675rem;padding:3px 6px;border-radius:4px;border:1px solid var(--primary-accent);pointer-events:none;opacity:0;transition:opacity .2s ease;white-space:nowrap}.chart-bar:hover .chart-bar-tooltip{opacity:1}.chart-x-label{font-size:.65rem;color:var(--text-muted);text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.identities-list{display:flex;flex-direction:column;gap:14px;max-height:280px;overflow-y:auto}.identity-item{display:flex;align-items:center;gap:12px;padding:8px 12px;background:#00000026;border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:all .2s ease}.identity-item:hover{border-color:#c7a27c26;background:#00000040}.identity-thumb{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(199,162,124,.25);background:var(--bg-secondary)}.identity-details{flex:1;display:flex;flex-direction:column}.identity-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}.identity-meta{font-size:.675rem;color:var(--text-muted)}.identity-count-badge{font-size:.725rem;font-weight:700;background:#c7a27c1f;color:var(--primary-accent);padding:2px 8px;border-radius:100px;border:1px solid rgba(199,162,124,.2)}.sessions-log-panel{width:100%}.sessions-table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-light);background:#0000001a}.sessions-table{width:100%;border-collapse:collapse;font-size:.8rem;text-align:left}.sessions-table th,.sessions-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.04)}.sessions-table th{background:#ffffff05;font-weight:600;color:var(--text-secondary);text-transform:uppercase;font-size:.675rem;letter-spacing:.05em}.sessions-table tbody tr:hover{background:#ffffff04}.sessions-table tbody tr:last-child td{border-bottom:none}.session-row-type{display:inline-flex;padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:600;text-transform:uppercase}.session-row-type.image{background:#8fb9961f;color:var(--success)}.session-row-type.video{background:#c7a27c1f;color:var(--primary-accent)}.session-people-mini-list{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}.session-people-mini-item{width:20px;height:20px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,.15)}.ftd-root{display:flex;flex-direction:column;gap:0;width:100%;animation:fade-in .6s cubic-bezier(.16,1,.3,1) both}.ftd-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:24px}.ftd-header-left{display:flex;align-items:center;gap:14px}.ftd-header-icon{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,#c7a27c26,#c7a27c0d);border:1px solid rgba(199,162,124,.2);display:flex;align-items:center;justify-content:center;color:var(--primary-accent);flex-shrink:0}.ftd-header-icon svg{width:22px;height:22px}.ftd-header-title{font-size:1.5rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;margin:0;background:linear-gradient(135deg,var(--text-primary) 60%,var(--primary-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ftd-header-sub{font-size:.8rem;color:var(--text-muted);margin:3px 0 0}.ftd-status-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;border-radius:100px;border:1px solid;font-size:.8rem;font-weight:500;transition:all .4s ease}.ftd-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ftd-status-text{font-weight:600}.ftd-spinner{width:12px;height:12px;border:2px solid rgba(255,255,255,.15);border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0}.ftd-tab-bar{display:flex;gap:4px;padding:5px;background:var(--bg-secondary);border-radius:14px;border:1px solid var(--border-light);margin-bottom:28px;overflow-x:auto}.ftd-tab{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border:none;border-radius:10px;background:transparent;color:var(--text-secondary);font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .22s cubic-bezier(.16,1,.3,1);white-space:nowrap;position:relative}.ftd-tab svg{width:15px;height:15px;flex-shrink:0}.ftd-tab:hover{color:var(--text-primary);background:#c7a27c12}.ftd-tab.active{background:var(--bg-card);color:var(--primary-accent);border:1px solid rgba(199,162,124,.18);box-shadow:0 2px 10px #0006}.ftd-tab-live-dot{position:absolute;top:6px;right:6px;width:6px;height:6px;background:#22c55e;border-radius:50%;animation:pulse-ring 1.8s ease-in-out infinite}.ftd-tab-count{background:#c7a27c26;color:var(--primary-accent);font-size:.65rem;font-weight:700;padding:2px 7px;border-radius:100px;border:1px solid rgba(199,162,124,.2);min-width:18px;text-align:center}.ftd-live-layout{display:grid;grid-template-columns:1fr 360px;gap:20px;align-items:start}@media (max-width: 900px){.ftd-live-layout{grid-template-columns:1fr}}.ftd-camera-panel{display:flex;flex-direction:column;gap:14px}.ftd-camera-wrapper{position:relative;width:100%;aspect-ratio:4/3;background:#000;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.07);box-shadow:0 16px 40px #00000080}.ftd-video-feed{width:100%;height:100%;object-fit:cover;display:block}.ftd-camera-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:linear-gradient(135deg,#0e0c0a,#1a1714)}.ftd-camera-placeholder-icon{width:72px;height:72px;border-radius:50%;background:#c7a27c12;border:1px solid rgba(199,162,124,.15);display:flex;align-items:center;justify-content:center;color:#c7a27c99;animation:pulse-ring 3s ease-in-out infinite}.ftd-camera-placeholder-icon svg{width:30px;height:30px}.ftd-camera-placeholder-text{font-size:.95rem;font-weight:500;color:var(--text-secondary)}.ftd-camera-placeholder-sub{font-size:.78rem;color:var(--text-muted)}.ftd-scan-line{position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,rgba(34,197,94,.7),transparent);animation:scan-sweep 3s ease-in-out infinite;pointer-events:none}@keyframes scan-sweep{0%{top:0%;opacity:.7}to{top:100%;opacity:0}}.ftd-live-badge{position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:6px;background:#000000b3;border:1px solid rgba(34,197,94,.4);border-radius:100px;padding:5px 12px;font-size:.68rem;font-weight:700;letter-spacing:.08em;color:#22c55e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.ftd-live-dot{width:7px;height:7px;background:#22c55e;border-radius:50%;animation:pulse-ring 1.5s ease-in-out infinite}.ftd-face-bounding-box{position:absolute;border:2px solid;border-radius:4px;transition:all .3s cubic-bezier(.16,1,.3,1);pointer-events:auto}.ftd-bbox-corner{position:absolute;width:10px;height:10px;border-style:solid;border-color:inherit}.ftd-bbox-tl{top:-2px;left:-2px;border-width:3px 0 0 3px}.ftd-bbox-tr{top:-2px;right:-2px;border-width:3px 3px 0 0}.ftd-bbox-bl{bottom:-2px;left:-2px;border-width:0 0 3px 3px}.ftd-bbox-br{bottom:-2px;right:-2px;border-width:0 3px 3px 0}.ftd-bbox-index{position:absolute;top:-1px;left:-1px;transform:translateY(-100%);font-size:.6rem;font-weight:800;padding:2px 7px;border-radius:4px 4px 0 0;letter-spacing:.05em}.ftd-bbox-label-panel{position:absolute;top:0;left:calc(100% + 6px);background:#0a0a12eb;border:1px solid;border-radius:8px;padding:6px 8px;min-width:160px;max-width:220px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 16px #00000080;z-index:10}.ftd-bbox-label-known{display:flex;align-items:center;gap:6px}.ftd-bbox-name-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.ftd-bbox-known-name{font-size:.8rem;font-weight:700;color:#f5f1ec;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ftd-bbox-edit-btn{background:none;border:none;cursor:pointer;color:#fff6;padding:2px;border-radius:4px;display:flex;align-items:center;transition:color .15s;flex-shrink:0}.ftd-bbox-edit-btn svg{width:13px;height:13px}.ftd-bbox-edit-btn:hover{color:var(--primary-accent)}.ftd-bbox-label-unknown{display:flex;gap:5px;align-items:center}.ftd-bbox-name-input{flex:1;background:#ffffff0f;border:1px solid;border-radius:5px;padding:5px 8px;font-size:.75rem;color:#f5f1ec;font-family:inherit;outline:none;min-width:0;transition:background .2s}.ftd-bbox-name-input::placeholder{color:#ffffff4d}.ftd-bbox-name-input:focus{background:#ffffff17}.ftd-bbox-save-btn{background:transparent;border:1px solid;border-radius:5px;padding:4px 8px;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .18s;display:flex;align-items:center;justify-content:center;min-width:40px;font-family:inherit}.ftd-bbox-save-btn svg{width:12px;height:12px}.ftd-bbox-save-btn:hover{opacity:.85}.ftd-session-controls{display:flex;flex-direction:column;gap:10px}.ftd-btn-start{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 28px;background:linear-gradient(135deg,var(--primary-accent),var(--accent-hover));color:#141210;font-size:.95rem;font-weight:700;font-family:inherit;border:none;border-radius:12px;cursor:pointer;transition:all .25s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 18px #c7a27c33;width:100%}.ftd-btn-start svg{width:18px;height:18px}.ftd-btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 28px #c7a27c59}.ftd-active-controls{display:flex;flex-direction:column;gap:10px}.ftd-session-timer{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:#22c55e;background:#22c55e14;border:1px solid rgba(34,197,94,.2);border-radius:100px;padding:5px 14px;width:fit-content}.ftd-timer-dot{width:7px;height:7px;background:#22c55e;border-radius:50%;animation:pulse-ring 1.5s ease-in-out infinite}.ftd-stats-bar{display:flex;gap:8px}.ftd-stat-chip{flex:1;background:#ffffff08;border:1px solid var(--border-light);border-radius:10px;padding:10px 8px;text-align:center}.ftd-stat-chip-val{display:block;font-size:1.4rem;font-weight:900;line-height:1;margin-bottom:3px}.ftd-stat-chip-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em}.ftd-btn-end{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:13px 28px;background:#d68c8c1a;color:var(--error);font-size:.9rem;font-weight:700;font-family:inherit;border:1px solid rgba(214,140,140,.25);border-radius:12px;cursor:pointer;transition:all .22s;width:100%}.ftd-btn-end svg{width:16px;height:16px}.ftd-btn-end:hover{background:#d68c8c2e;border-color:#d68c8c73;transform:translateY(-1px)}.ftd-live-log{background:var(--bg-card);border:1px solid var(--border-light);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-soft);min-height:300px;max-height:560px}.ftd-live-log-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-light);flex-shrink:0}.ftd-live-log-title{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:700;color:var(--text-primary)}.ftd-live-log-title svg{width:15px;height:15px;color:var(--primary-accent)}.ftd-live-log-count{font-size:.7rem;color:var(--text-muted);background:#ffffff0a;padding:3px 8px;border-radius:100px;border:1px solid var(--border-light)}.ftd-live-log-body{flex:1;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column;gap:2px}.ftd-live-log-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--text-muted);font-size:.82rem;text-align:center;flex:1}.ftd-live-log-empty svg{width:32px;height:32px;opacity:.4}.ftd-live-log-item{display:flex;align-items:center;gap:10px;padding:8px 16px;transition:background .15s;animation:log-slide-in .3s cubic-bezier(.16,1,.3,1)}@keyframes log-slide-in{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}.ftd-live-log-item:hover{background:#ffffff05}.ftd-log-avatar{width:30px;height:30px;border-radius:50%;border:1px solid;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:800;flex-shrink:0}.ftd-log-content{flex:1;min-width:0}.ftd-log-name{font-size:.8rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ftd-log-unknown{font-style:italic;color:var(--text-muted);font-weight:400}.ftd-log-event-type{font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.04em}.ftd-log-event-type.entry{background:#22c55e1f;color:#22c55e}.ftd-log-event-type.exit{background:#d68c8c1f;color:var(--error)}.ftd-log-event-type.detected{background:#60a5fa1a;color:#60a5fa}.ftd-log-meta{display:flex;align-items:center;gap:8px;margin-top:2px}.ftd-log-id{font-size:.62rem;color:var(--text-muted);font-family:monospace;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ftd-log-time{font-size:.62rem;color:var(--text-muted)}.ftd-log-confidence{font-size:.72rem;font-weight:700;color:var(--primary-accent);flex-shrink:0}.ftd-live-faces-strip{border-top:1px solid var(--border-light);padding:12px 16px;flex-shrink:0}.ftd-strip-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}.ftd-strip-faces{display:flex;flex-wrap:wrap;gap:6px}.ftd-strip-face-chip{display:inline-flex;align-items:center;gap:5px;border:1px solid;border-radius:100px;padding:4px 10px;font-size:.72rem;font-weight:600}.ftd-chip-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0}.ftd-chip-name{color:var(--text-primary)}.ftd-chip-conf{font-size:.62rem;color:var(--text-muted)}.ftd-post-session{background:var(--bg-card);border:1px solid rgba(143,185,150,.15);border-radius:18px;overflow:hidden;box-shadow:var(--shadow-soft);animation:fade-in .5s cubic-bezier(.16,1,.3,1)}.ftd-post-header{background:linear-gradient(135deg,#8fb9960f,#0000);border-bottom:1px solid var(--border-light);padding:28px 28px 20px}.ftd-post-title-row{display:flex;align-items:center;gap:16px;margin-bottom:20px}.ftd-post-icon{width:48px;height:48px;background:#8fb9961f;border:1px solid rgba(143,185,150,.25);border-radius:14px;display:flex;align-items:center;justify-content:center;color:var(--success);flex-shrink:0}.ftd-post-icon svg{width:22px;height:22px}.ftd-post-title{font-size:1.35rem;font-weight:800;color:var(--text-primary);letter-spacing:-.025em;margin:0}.ftd-post-subtitle{font-size:.78rem;color:var(--text-muted);margin:4px 0 0}.ftd-post-kpis{display:flex;align-items:center;background:#0000002e;border:1px solid var(--border-light);border-radius:12px;overflow:hidden}.ftd-post-kpi{flex:1;padding:14px 16px;text-align:center}.ftd-post-kpi-val{display:block;font-size:1.5rem;font-weight:900;color:var(--text-primary);letter-spacing:-.03em;line-height:1}.ftd-post-kpi-val.green{color:var(--success)}.ftd-post-kpi-val.red{color:var(--error)}.ftd-post-kpi-val.gold{color:var(--primary-accent)}.ftd-post-kpi-label{display:block;font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:4px}.ftd-post-kpi-divider{width:1px;height:36px;background:var(--border-light);flex-shrink:0}.ftd-post-body{padding:24px 28px;display:flex;flex-direction:column;gap:14px}.ftd-post-section-label{font-size:.68rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.ftd-post-faces{display:flex;flex-direction:column;gap:10px}.ftd-post-empty{padding:32px;text-align:center;color:var(--text-muted);font-size:.85rem;border:1px dashed var(--border-light);border-radius:10px}.ftd-post-face-card{display:flex;align-items:flex-start;gap:14px;background:#00000026;border:1px solid var(--border-light);border-left:3px solid;border-radius:12px;padding:14px 16px;transition:border-color .2s;animation:fade-in .4s cubic-bezier(.16,1,.3,1)}.ftd-post-face-avatar{width:40px;height:40px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:800;flex-shrink:0}.ftd-post-face-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:5px}.ftd-post-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ftd-post-face-name{font-size:.95rem;font-weight:700;color:var(--text-primary)}.ftd-post-unknown-label{font-style:italic;color:var(--text-muted);font-weight:400;font-size:.9rem}.ftd-post-rename-btn{background:none;border:1px solid rgba(255,255,255,.08);border-radius:5px;padding:3px 7px;cursor:pointer;color:var(--text-muted);display:flex;align-items:center;gap:4px;font-size:.7rem;font-family:inherit;font-weight:500;transition:all .15s}.ftd-post-rename-btn svg{width:11px;height:11px}.ftd-post-rename-btn:hover{color:var(--primary-accent);border-color:#c7a27c4d}.ftd-post-face-id{font-size:.63rem;color:var(--text-muted);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ftd-post-edit-row{display:flex;gap:6px;align-items:center}.ftd-post-edit-input{flex:1;background:#0000004d;border:1px solid rgba(199,162,124,.4);border-radius:6px;padding:6px 10px;font-size:.85rem;color:var(--text-primary);font-family:inherit;outline:none;font-weight:600}.ftd-post-edit-confirm,.ftd-post-edit-cancel{padding:5px 10px;border-radius:6px;font-size:.78rem;font-weight:700;cursor:pointer;border:none;font-family:inherit;transition:all .15s}.ftd-post-edit-confirm{background:#8fb99633;color:var(--success)}.ftd-post-edit-confirm:hover{background:#8fb99659}.ftd-post-edit-cancel{background:#ffffff0d;color:var(--text-muted)}.ftd-post-edit-cancel:hover{background:#ffffff1a}.ftd-unknown-name-row{display:flex;gap:6px;align-items:center;margin-top:6px}.ftd-unknown-name-input{flex:1;background:#ffffff0a;border:1px solid var(--border-light);border-radius:6px;padding:6px 10px;font-size:.78rem;color:var(--text-primary);font-family:inherit;outline:none}.ftd-unknown-name-input:focus{border-color:#c7a27c59}.ftd-unknown-name-input::placeholder{color:var(--text-muted)}.ftd-unknown-save-btn{padding:6px 12px;border-radius:6px;font-size:.75rem;font-weight:700;cursor:pointer;border:1px solid var(--border-light);background:#ffffff0a;color:var(--text-secondary);font-family:inherit;transition:all .2s}.ftd-unknown-save-btn:hover{border-color:var(--primary-accent);color:var(--primary-accent)}.ftd-unknown-save-btn.saved{background:#8fb9961f;color:var(--success);border-color:#8fb9964d}.ftd-unknown-save-btn.error{background:#d68c8c1f;color:var(--error);border-color:#d68c8c4d}.ftd-post-face-stats{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;min-width:80px}.ftd-post-stat-entry{font-size:.78rem;font-weight:700;color:var(--success)}.ftd-post-stat-exit{font-size:.78rem;font-weight:700;color:var(--error)}.ftd-post-stat-seen{font-size:.75rem;color:var(--text-muted)}.ftd-inline-saved{font-size:.65rem;font-weight:700;color:var(--success)}.ftd-inline-error{font-size:.65rem;font-weight:700;color:var(--error)}.ftd-post-actions{display:flex;gap:10px;padding:20px 28px;border-top:1px solid var(--border-light);background:#0000001a}.ftd-btn-primary{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;background:linear-gradient(135deg,var(--primary-accent),var(--accent-hover));color:#141210;font-size:.875rem;font-weight:700;font-family:inherit;border:none;border-radius:10px;cursor:pointer;transition:all .22s}.ftd-btn-primary svg{width:16px;height:16px}.ftd-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #c7a27c40}.ftd-btn-ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:13px 20px;background:#ffffff08;color:var(--text-secondary);font-size:.875rem;font-weight:600;font-family:inherit;border:1px solid var(--border-light);border-radius:10px;cursor:pointer;transition:all .2s;white-space:nowrap}.ftd-btn-ghost svg{width:14px;height:14px}.ftd-btn-ghost:hover{color:var(--text-primary);border-color:#ffffff1f;background:#ffffff0d}.ftd-history-view{display:flex;flex-direction:column;gap:20px;animation:fade-in .5s cubic-bezier(.16,1,.3,1)}.ftd-history-header{display:flex;align-items:center;justify-content:space-between}.ftd-history-title{display:flex;align-items:center;gap:10px;font-size:1.2rem;font-weight:800;color:var(--text-primary);letter-spacing:-.02em}.ftd-history-title svg{width:18px;height:18px;color:var(--primary-accent)}.ftd-history-count{font-size:.75rem;color:var(--text-muted);background:#ffffff0a;padding:4px 12px;border-radius:100px;border:1px solid var(--border-light)}.ftd-history-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:80px 40px;text-align:center;background:var(--bg-card);border:1px dashed var(--border-light);border-radius:16px}.ftd-history-empty-icon{width:64px;height:64px;background:#ffffff08;border:1px solid var(--border-light);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-muted)}.ftd-history-empty-icon svg{width:28px;height:28px;opacity:.5}.ftd-history-empty h3{font-size:1rem;font-weight:700;color:var(--text-secondary)}.ftd-history-empty p{font-size:.85rem;color:var(--text-muted)}.ftd-history-sessions{display:flex;flex-direction:column;gap:10px}.ftd-history-session-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:14px;overflow:hidden;transition:box-shadow .3s,border-color .3s}.ftd-history-session-card.expanded{border-color:#c7a27c33;box-shadow:var(--shadow-soft)}.ftd-history-session-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 20px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .18s}.ftd-history-session-header:hover{background:#ffffff05}.ftd-hist-session-left{display:flex;align-items:center;gap:14px}.ftd-hist-session-badge{width:38px;height:38px;background:#c7a27c14;border:1px solid rgba(199,162,124,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--primary-accent);flex-shrink:0}.ftd-hist-session-badge svg{width:16px;height:16px}.ftd-hist-session-date{font-size:.875rem;font-weight:700;color:var(--text-primary);margin:0}.ftd-hist-session-meta{font-size:.72rem;color:var(--text-muted);margin:3px 0 0}.ftd-hist-session-right{display:flex;align-items:center;gap:16px}.ftd-hist-stat{text-align:center}.ftd-hist-stat-val{display:block;font-size:1.15rem;font-weight:800;line-height:1}.ftd-hist-stat-val.green{color:var(--success)}.ftd-hist-stat-val.red{color:var(--error)}.ftd-hist-stat-label{font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ftd-hist-chevron{width:18px;height:18px;color:var(--text-muted);transition:transform .25s cubic-bezier(.16,1,.3,1);flex-shrink:0}.ftd-hist-chevron.open{transform:rotate(180deg)}.ftd-history-session-detail{padding:16px 20px 20px;display:flex;flex-direction:column;gap:16px;animation:fade-in .3s cubic-bezier(.16,1,.3,1);border-top:1px solid var(--border-light)}.ftd-hist-logs{display:flex;flex-direction:column;gap:4px}.ftd-hist-logs-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}.ftd-hist-log-row{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#0000001f;border-radius:7px;font-size:.78rem}.ftd-hist-log-event{font-weight:800;width:18px;text-align:center;flex-shrink:0}.ftd-hist-log-event.entered{color:var(--success)}.ftd-hist-log-event.exited{color:var(--error)}.ftd-hist-log-event.detected{color:#60a5fa}.ftd-hist-log-name{flex:1;color:var(--text-primary);font-weight:600}.ftd-hist-log-time{color:var(--text-muted);font-size:.68rem;flex-shrink:0}.ftd-hist-faces-label{font-size:.62rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}.ftd-hist-faces{display:flex;flex-direction:column;gap:8px}.ftd-hist-face-row{display:flex;align-items:center;gap:12px;background:#0000001f;border:1px solid var(--border-light);border-radius:10px;padding:10px 14px;transition:border-color .2s}.ftd-hist-face-row:hover{border-color:#c7a27c26}.ftd-hist-face-avatar{width:34px;height:34px;border-radius:50%;border:2px solid;display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800;flex-shrink:0}.ftd-hist-face-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.ftd-hist-name-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ftd-hist-face-name{font-size:.875rem;font-weight:700;color:var(--text-primary)}.ftd-hist-unknown{font-style:italic;color:var(--text-muted);font-weight:400;font-size:.85rem}.ftd-hist-edit-name-btn{display:inline-flex;align-items:center;gap:5px;background:#c7a27c14;border:1px solid rgba(199,162,124,.18);border-radius:6px;padding:3px 8px;font-size:.68rem;font-weight:700;color:var(--primary-accent);cursor:pointer;font-family:inherit;transition:all .18s;white-space:nowrap}.ftd-hist-edit-name-btn svg{width:10px;height:10px}.ftd-hist-edit-name-btn:hover{background:#c7a27c29;border-color:var(--primary-accent)}.ftd-hist-face-id{font-size:.62rem;color:var(--text-muted);font-family:monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ftd-hist-edit-row{display:flex;gap:5px;align-items:center}.ftd-hist-edit-input{flex:1;background:#0000004d;border:1px solid rgba(199,162,124,.35);border-radius:6px;padding:5px 9px;font-size:.82rem;color:var(--text-primary);font-family:inherit;outline:none;font-weight:600}.ftd-hist-edit-confirm,.ftd-hist-edit-cancel{padding:5px 9px;border-radius:6px;font-size:.72rem;font-weight:700;cursor:pointer;border:none;font-family:inherit;transition:all .15s}.ftd-hist-edit-confirm{background:#8fb9962e;color:var(--success)}.ftd-hist-edit-confirm:hover{background:#8fb9964d}.ftd-hist-edit-cancel{background:#ffffff0d;color:var(--text-muted)}.ftd-hist-edit-cancel:hover{background:#ffffff1a}.ftd-hist-face-stats{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;min-width:60px}.ftd-stat-entry{font-size:.72rem;font-weight:700;color:var(--success)}.ftd-stat-exit{font-size:.72rem;font-weight:700;color:var(--error)}.ftd-stat-conf{font-size:.68rem;color:var(--primary-accent)}@media (max-width: 600px){.ftd-header{flex-direction:column;align-items:flex-start}.ftd-tab{padding:8px 12px;font-size:.78rem}.ftd-post-kpis{flex-wrap:wrap}.ftd-post-kpi{min-width:40%}.ftd-post-kpi-divider{display:none}.ftd-post-actions{flex-direction:column}.ftd-bbox-label-panel{left:auto;top:calc(100% + 6px);min-width:140px}}.log-dashboard{max-width:1100px;margin:0 auto;padding:28px 0;display:flex;flex-direction:column;gap:24px;animation:fade-in .5s ease both}.log-dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.log-dashboard-title{display:flex;align-items:center;gap:10px;font-size:1.6rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em}.log-dashboard-title svg{color:var(--primary-accent)}.log-dashboard-subtitle{font-size:.875rem;color:var(--text-muted);margin-top:4px}.log-refresh-btn{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:#ffffff0a;border:1px solid var(--border-light);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:.82rem;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s}.log-refresh-btn:hover{background:#ffffff14;color:var(--text-primary)}.log-refresh-btn:disabled{opacity:.5;cursor:not-allowed}.log-date-filter{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:14px 18px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md)}.log-filter-btn{padding:7px 16px;border-radius:8px;border:1px solid transparent;font-size:.82rem;font-weight:600;color:var(--text-muted);background:transparent;cursor:pointer;font-family:inherit;transition:all .2s}.log-filter-btn:hover{color:var(--text-primary);background:#ffffff0a}.log-filter-btn.active{color:var(--primary-accent);background:#c7a27c1a;border-color:#c7a27c40}.log-date-input,.log-date-select{padding:7px 12px;background:#0003;border:1px solid var(--border-light);border-radius:8px;color:var(--text-secondary);font-size:.82rem;font-family:inherit;outline:none;transition:border-color .2s}.log-date-input:focus,.log-date-select:focus{border-color:var(--primary-accent)}.log-error-banner{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--error-bg);border:1px solid var(--error-border);border-radius:var(--radius-sm);color:var(--error);font-size:.875rem}.log-summary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}@media (max-width: 900px){.log-summary-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 560px){.log-summary-cards{grid-template-columns:1fr}}.log-summary-card{display:flex;align-items:center;gap:14px;padding:20px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);transition:all .25s}.log-summary-card:hover{border-color:#ffffff1a;transform:translateY(-2px)}.log-summary-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.log-summary-card-value{font-size:1.9rem;font-weight:900;letter-spacing:-.04em;line-height:1}.log-summary-card-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-top:3px}.log-summary-card-sub{font-size:.7rem;color:var(--text-muted);margin-top:2px}.log-view-toggle{display:flex;gap:8px;padding:4px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-sm);width:fit-content}.log-toggle-btn{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border-radius:6px;border:none;font-size:.8rem;font-weight:600;color:var(--text-muted);background:transparent;cursor:pointer;font-family:inherit;transition:all .2s}.log-toggle-btn.active{background:#c7a27c1f;color:var(--primary-accent)}.log-toggle-btn:hover:not(.active){color:var(--text-primary)}.log-loading{display:flex;align-items:center;gap:12px;justify-content:center;padding:40px;color:var(--text-muted);font-size:.9rem}.log-loading-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.08);border-top-color:var(--primary-accent);border-radius:50%;animation:spin .7s linear infinite}.log-empty-state{text-align:center;padding:60px 24px;background:var(--bg-card);border:1px dashed var(--border-light);border-radius:var(--radius-md)}.log-empty-icon{font-size:2.5rem;margin-bottom:16px}.log-empty-state h3{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:8px}.log-empty-state p{font-size:.9rem;color:var(--text-muted)}.log-person-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.log-person-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);overflow:hidden;transition:all .3s}.log-person-card:hover{border-color:#ffffff1f;transform:translateY(-3px);box-shadow:var(--shadow-hover)}.log-person-card.known{border-top:2px solid rgba(167,139,250,.5)}.log-person-card.unknown{border-top:2px solid rgba(75,85,99,.5)}.log-person-card-header{position:relative;height:100px;background:linear-gradient(135deg,#1a1510,#242020);display:flex;align-items:center;justify-content:center}.log-person-avatar-img{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid rgba(167,139,250,.4)}.log-person-avatar-fallback{width:72px;height:72px;border-radius:50%;background:#a78bfa1f;border:2px solid rgba(167,139,250,.3);display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:800;color:#a78bfacc}.log-person-badge{position:absolute;top:8px;right:8px;font-size:.65rem;font-weight:700;padding:3px 8px;border-radius:100px;background:#00000080;color:var(--text-muted);border:1px solid rgba(255,255,255,.08)}.log-person-card-body{padding:14px}.log-person-name{font-size:.95rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.log-person-id{font-size:.65rem;font-family:monospace;color:var(--text-muted);margin-bottom:12px}.log-person-stats-row{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.log-person-stat{flex:1;min-width:0;background:#ffffff08;border:1px solid var(--border-light);border-radius:8px;padding:6px 8px;text-align:center}.log-person-stat-val{display:block;font-size:.95rem;font-weight:800}.log-person-stat-label{display:block;font-size:.6rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.log-person-timeline-bar{height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden;margin-bottom:4px}.log-person-timeline-fill{height:100%;border-radius:2px;transition:width .6s ease}.log-person-timeline-label{font-size:.62rem;color:var(--text-muted)}.log-table-wrapper{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-light)}.log-table{width:100%;border-collapse:collapse;font-size:.875rem}.log-table th{text-align:left;padding:12px 16px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);background:#ffffff05;border-bottom:1px solid var(--border-light)}.log-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.log-table tbody tr:hover td{background:#ffffff05}.log-table tbody tr:last-child td{border-bottom:none}.log-table-face-cell{display:flex;align-items:center;justify-content:center}.log-table-face-img{width:38px;height:38px;border-radius:50%;object-fit:cover;border:2px solid rgba(167,139,250,.3)}.log-table-face-fallback{width:38px;height:38px;border-radius:50%;background:#a78bfa1a;border:1px solid rgba(167,139,250,.25);display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#a78bfacc}.log-table-name.known{color:var(--text-primary);font-weight:600}.log-table-name.unknown{color:var(--text-muted);font-style:italic}.log-table-id{font-size:.72rem;color:var(--text-muted);font-family:monospace}.log-table-count-cell{display:flex;align-items:center;gap:10px}.log-table-count{font-size:1rem;font-weight:800;color:#a78bfa;min-width:28px}.log-table-mini-bar{flex:1;height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.log-table-mini-fill{height:100%;background:linear-gradient(90deg,#a78bfa,#60a5fa);border-radius:2px}.log-table-time{font-size:.82rem;font-family:monospace;color:var(--text-secondary)}.log-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}@media (max-width: 740px){.log-charts-grid{grid-template-columns:1fr}}.log-chart-panel{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-md);padding:20px;overflow:hidden}.log-chart-panel-header{display:flex;align-items:center;gap:7px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text-muted);margin-bottom:16px}.log-chart-empty{text-align:center;padding:32px 0;color:var(--text-muted);font-size:.85rem}.log-hour-chart{display:flex;flex-direction:column;gap:8px}.log-chart-bars{display:flex;align-items:flex-end;gap:2px;height:90px;padding-bottom:18px;position:relative}.log-hour-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative;gap:3px}.log-hour-bar-wrapper:hover .log-hour-bar-tooltip{opacity:1;transform:translateY(-4px)}.log-hour-bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000000d9;color:var(--text-primary);font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;opacity:0;transition:all .15s;pointer-events:none;z-index:10}.log-hour-bar{width:100%;background:linear-gradient(180deg,#60a5fab3,#60a5fa4d);border-radius:2px 2px 0 0;transition:all .4s ease}.log-hour-bar.peak{background:linear-gradient(180deg,#a78bfa,#a78bfa80)}.log-hour-bar-label{position:absolute;bottom:-18px;font-size:.55rem;color:var(--text-muted);white-space:nowrap}.log-chart-peak{font-size:.75rem;color:var(--text-muted);padding-top:6px;border-top:1px solid var(--border-light)}.log-trend-chart{display:flex;align-items:flex-end;gap:8px;height:90px}.log-trend-bar-wrapper{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative;gap:4px}.log-trend-bar-wrapper:hover .log-trend-bar-tooltip{opacity:1}.log-trend-bar-tooltip{position:absolute;bottom:100%;left:50%;transform:translate(-50%);background:#000000d9;color:var(--text-primary);font-size:.65rem;font-weight:600;padding:3px 8px;border-radius:4px;white-space:nowrap;opacity:0;transition:opacity .15s;pointer-events:none;z-index:10}.log-trend-bar{width:100%;background:linear-gradient(180deg,#34d399,#34d3994d);border-radius:3px 3px 0 0;transition:height .4s ease}.log-trend-bar-label{font-size:.6rem;color:var(--text-muted);white-space:nowrap}.log-pie-wrapper{display:flex;align-items:center;gap:24px;padding:8px 0}.log-pie-chart{width:80px;height:80px;border-radius:50%;flex-shrink:0;box-shadow:0 4px 16px #0000004d}.log-pie-legend{display:flex;flex-direction:column;gap:10px}.log-pie-legend-item{display:flex;align-items:center;gap:8px;font-size:.82rem;color:var(--text-secondary)}.log-pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.log-top-people{display:flex;flex-direction:column;gap:10px}.log-top-person-row{display:flex;align-items:center;gap:10px}.log-top-rank{font-size:.7rem;font-weight:800;color:var(--text-muted);width:20px;text-align:right;flex-shrink:0}.log-top-avatar{width:32px;height:32px;flex-shrink:0;position:relative}.log-top-avatar-img{width:32px;height:32px;border-radius:50%;object-fit:cover;border:2px solid rgba(199,162,124,.3)}.log-top-avatar-fallback{width:32px;height:32px;border-radius:50%;background:#c7a27c1a;border:1px solid rgba(199,162,124,.2);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:800;color:var(--primary-accent)}.log-top-info{flex:1;min-width:0}.log-top-name{font-size:.82rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.log-top-bar-row{display:flex;align-items:center;gap:8px}.log-top-bar{flex:1;height:5px;background:#ffffff0f;border-radius:3px;overflow:hidden}.log-top-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-accent),#e0b894);border-radius:3px;transition:width .6s ease}.log-top-count{font-size:.72rem;font-weight:800;color:var(--primary-accent);white-space:nowrap}@keyframes spin{to{transform:rotate(360deg)}}.log-chart-svg{width:100%;height:110px;display:block;overflow:visible}.log-rebuild-banner{display:flex;align-items:center;gap:10px;padding:12px 18px;background:#34d39914;border:1px solid rgba(52,211,153,.2);border-radius:var(--radius-sm);color:#34d399;font-size:.875rem;font-weight:500;animation:fade-in .3s ease}.log-pie-chart{width:100px;height:100px;border-radius:50%;flex-shrink:0;box-shadow:0 4px 16px #00000059;position:relative;display:flex;align-items:center;justify-content:center}.log-pie-center{position:absolute;top:8px;right:8px;bottom:8px;left:8px;border-radius:50%;background:var(--bg-card);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}.log-pie-legend{display:flex;flex-direction:column;gap:12px}.log-pie-legend-item{display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:var(--text-secondary)}.log-pie-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0;margin-top:3px}.log-hour-chart{display:flex;flex-direction:column;gap:4px}.log-chart-peak{font-size:.75rem;color:var(--text-muted);padding-top:6px;border-top:1px solid var(--border-light);margin-top:4px}.log-chart-peak strong{color:var(--primary-accent)}
