:root{--color-primary:#1e3a5f;--color-primary-dark:#142540;--color-primary-light:#2c5282;--color-accent:#c9a961;--color-accent-dark:#a8893f;--color-success:#2d7a4f;--color-error:#b3261e;--color-bg:#fafaf7;--color-bg-paper:#fff;--color-bg-subtle:#f3f1eb;--color-text:#1a1f2e;--color-text-muted:#5b6478;--color-text-light:#8b94a8;--color-border:#e3e1d8;--color-border-strong:#c7c4b8;--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2.5rem;--space-2xl:4rem;--font-sans:'Inter',-apple-system,system-ui,sans-serif;--font-serif:'Source Serif Pro',Georgia,serif;--shadow-sm:0 1px 2px rgba(20,37,64,.06);--shadow-md:0 4px 12px rgba(20,37,64,.08);--shadow-lg:0 12px 32px rgba(20,37,64,.12);--radius-sm:4px;--radius-md:8px;--radius-lg:12px}
*{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px}
body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased}
.app-shell{min-height:100vh;display:flex;flex-direction:column}
.app-header{background:var(--color-primary);color:#fff;padding:var(--space-md) 0;box-shadow:var(--shadow-md);position:sticky;top:0;z-index:10}
.app-header-inner{max-width:1200px;margin:0 auto;padding:0 var(--space-lg);display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg)}
.app-brand{display:flex;align-items:center;gap:var(--space-md)}
.app-brand-mark{width:40px;height:40px;background:var(--color-accent);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-weight:700;font-size:1.25rem;color:var(--color-primary-dark)}
.app-brand-text h1{font-size:1.05rem;font-weight:600;line-height:1.2}
.app-brand-text .subtitle{font-size:.8rem;opacity:.75}
.app-nav{display:flex;gap:var(--space-md);align-items:center}
.app-nav a{color:rgba(255,255,255,.85);text-decoration:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;transition:all .15s}
.app-nav a:hover{background:rgba(255,255,255,.1);color:#fff}
.app-nav a.logout{color:rgba(255,255,255,.6);font-size:.85rem}
.app-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--space-xl) var(--space-lg)}
.app-footer{padding:var(--space-lg);text-align:center;font-size:.85rem;color:var(--color-text-light);border-top:1px solid var(--color-border)}
.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-dark),var(--color-primary));padding:var(--space-lg)}
.login-card{background:var(--color-bg-paper);border-radius:var(--radius-lg);padding:var(--space-2xl) var(--space-xl);max-width:420px;width:100%;box-shadow:var(--shadow-lg);text-align:center}
.login-card .brand-mark{width:64px;height:64px;margin:0 auto var(--space-lg);background:var(--color-accent);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-weight:700;font-size:1.8rem;color:var(--color-primary-dark)}
.login-card h1{font-family:var(--font-serif);font-size:1.5rem;font-weight:600;margin-bottom:var(--space-sm);color:var(--color-primary-dark)}
.login-card .subtitle{color:var(--color-text-muted);font-size:.9rem;margin-bottom:var(--space-xl)}
.login-card .researcher{font-size:.85rem;color:var(--color-text-light);margin-top:var(--space-xl);padding-top:var(--space-md);border-top:1px solid var(--color-border)}
.card{background:var(--color-bg-paper);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-md);box-shadow:var(--shadow-sm)}
.card.elevated{box-shadow:var(--shadow-md)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md);padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border)}
.card-header h2{font-family:var(--font-serif);font-size:1.25rem;font-weight:600;color:var(--color-primary-dark)}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}
.stat-card{background:var(--color-bg-paper);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--color-accent)}
.stat-card.primary::before{background:var(--color-primary)}
.stat-card.success::before{background:var(--color-success)}
.stat-label{font-size:.85rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:500}
.stat-value{font-family:var(--font-serif);font-size:2.5rem;font-weight:700;color:var(--color-primary-dark);margin-top:var(--space-xs);line-height:1}
.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:.65rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .15s;background:transparent;color:var(--color-text)}
.btn-primary{background:var(--color-primary);color:#fff}
.btn-primary:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}
.btn-outline{background:transparent;border:1px solid var(--color-border-strong);color:var(--color-text)}
.btn-outline:hover{background:var(--color-bg-subtle);border-color:var(--color-primary)}
.btn-ghost{background:transparent;color:var(--color-text-muted);padding:var(--space-sm) var(--space-md)}
.btn-ghost:hover{background:var(--color-bg-subtle);color:var(--color-text)}
.btn-danger{color:var(--color-error);border:1px solid transparent}
.btn-danger:hover{background:#fef2f2;border-color:var(--color-error)}
.btn-sm{padding:.4rem .85rem;font-size:.85rem}
.btn-block{width:100%;justify-content:center}
.form-group{margin-bottom:var(--space-md)}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}
label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:var(--space-xs)}
input[type=text],input[type=date],input[type=number],input[type=password],input[type=email],select,textarea{width:100%;padding:.65rem .85rem;border:1px solid var(--color-border-strong);border-radius:var(--radius-sm);font-family:var(--font-sans);font-size:.95rem;color:var(--color-text);background:var(--color-bg-paper);transition:all .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(30,58,95,.1)}
textarea{min-height:100px;resize:vertical;font-family:var(--font-sans);line-height:1.5}
textarea.expanded{min-height:140px}
.interview-list{display:flex;flex-direction:column;gap:var(--space-sm)}
.interview-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--color-bg-paper);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all .15s;text-decoration:none;color:inherit}
.interview-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateX(2px)}
.interview-meta{display:flex;flex-direction:column;gap:var(--space-xs)}
.interview-code{font-family:var(--font-serif);font-size:1.1rem;font-weight:600;color:var(--color-primary-dark)}
.interview-info{font-size:.85rem;color:var(--color-text-muted)}
.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}
.status-badge.in_progress{background:#fef3c7;color:#92400e}
.status-badge.completed{background:#d1fae5;color:#065f46}
.interview-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-xl);gap:var(--space-lg)}
.interview-title h1{font-family:var(--font-serif);font-size:2rem;font-weight:700;color:var(--color-primary-dark);margin-bottom:var(--space-xs)}
.interview-title .meta{color:var(--color-text-muted);font-size:.9rem}
.section-block{background:var(--color-bg-paper);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:var(--space-lg);overflow:hidden}
.section-header{background:var(--color-bg-subtle);padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--space-md)}
.section-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-paper);border-radius:var(--radius-sm)}
.section-title h2{font-family:var(--font-serif);font-size:1.3rem;font-weight:600;color:var(--color-primary-dark);margin-bottom:2px}
.section-title .section-desc{font-size:.85rem;color:var(--color-text-muted)}
.section-content{padding:var(--space-lg)}
.question-block{padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border)}
.question-block:last-child{border-bottom:none;padding-bottom:0}
.question-block:first-child{padding-top:0}
.question-label{display:flex;gap:var(--space-md);margin-bottom:var(--space-md)}
.question-number{font-family:var(--font-serif);font-size:1.5rem;font-weight:700;color:var(--color-accent-dark);line-height:1.2;min-width:2.5rem}
.question-text{font-size:1.05rem;font-weight:500;line-height:1.5;color:var(--color-text);padding-top:.2rem}
.options-label{font-size:.85rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:var(--space-sm);display:block}
.options-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-sm);margin-bottom:var(--space-md)}
.option-chip{display:flex;align-items:flex-start;gap:var(--space-sm);padding:.6rem .85rem;background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-size:.9rem;line-height:1.4}
.option-chip:hover{border-color:var(--color-primary-light);background:#eef2f7}
.option-chip input[type=checkbox]{width:18px;height:18px;margin-top:1px;accent-color:var(--color-primary);cursor:pointer}
.option-chip.checked{background:#e7eef5;border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary)}
.option-chip span{flex:1}
.tags-row{display:flex;flex-wrap:wrap;gap:var(--space-xs);margin-top:var(--space-md)}
.tag-chip{display:inline-flex;align-items:center;gap:4px;padding:.3rem .7rem;background:var(--color-bg-paper);border:1px solid var(--color-border-strong);border-radius:16px;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;user-select:none}
.tag-chip:hover{border-color:var(--color-accent)}
.tag-chip input[type=checkbox]{display:none}
.tag-chip.checked{background:var(--color-accent);border-color:var(--color-accent-dark);color:var(--color-primary-dark)}
.tag-chip.suggested{border-style:dashed}
.save-status{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px dashed var(--color-border);min-height:28px;font-size:.85rem}
.save-ok{color:var(--color-success);font-weight:500}
.save-pending{color:var(--color-text-light);font-style:italic}
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);gap:var(--space-md);flex-wrap:wrap}
.toolbar-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}
.empty-state{text-align:center;padding:var(--space-2xl) var(--space-lg);background:var(--color-bg-paper);border:1px dashed var(--color-border-strong);border-radius:var(--radius-md)}
.empty-state h3{font-family:var(--font-serif);font-size:1.3rem;color:var(--color-text-muted);margin-bottom:var(--space-sm)}
.empty-state p{color:var(--color-text-light);margin-bottom:var(--space-lg)}
.summary-question{background:var(--color-bg-paper);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-md)}
.summary-question h3{font-family:var(--font-serif);font-size:1.05rem;color:var(--color-primary-dark);margin-bottom:var(--space-md)}
.option-bar{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) 0;font-size:.9rem}
.option-bar-label{flex:0 0 280px;color:var(--color-text)}
.option-bar-track{flex:1;height:16px;background:var(--color-bg-subtle);border-radius:8px;overflow:hidden}
.option-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary-light),var(--color-accent));border-radius:8px}
.option-bar-value{flex:0 0 80px;text-align:right;font-variant-numeric:tabular-nums;color:var(--color-text-muted);font-size:.85rem}
.free-text-quote{padding:var(--space-sm) var(--space-md);background:var(--color-bg-subtle);border-left:3px solid var(--color-accent);margin:var(--space-sm) 0;font-style:italic;font-size:.9rem}
.free-text-quote .source{display:block;font-style:normal;font-size:.75rem;color:var(--color-text-muted);margin-top:var(--space-xs)}
.alert{padding:var(--space-md);border-radius:var(--radius-sm);margin-bottom:var(--space-md);font-size:.9rem}
.alert-error{background:#fef2f2;border:1px solid #fecaca;color:var(--color-error)}
.alert-info{background:#eff6ff;border:1px solid #bfdbfe;color:var(--color-primary)}
@media (max-width:768px){.app-header-inner{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.interview-header{flex-direction:column}.options-grid{grid-template-columns:1fr}.option-bar{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.option-bar-label{flex:1}}
@media print{.app-header,.app-footer,.toolbar,.btn{display:none}body{background:#fff}}
