:root{--background:#f8f9fa;--foreground:#111827;--muted:#f1f3f5;--muted-foreground:#6b7280;--card:#ffffff;--border:#e5e7eb;--border-strong:#d1d5db;--input:#ffffff;--ring:rgba(37,99,235,0.16);--primary:#111827;--primary-foreground:#ffffff;--accent:#2563eb;--accent-soft:#eff6ff;--destructive:#b42318;--destructive-soft:#fef3f2;--warning:#9a6700;--warning-soft:#fffbeb;--success:#067647;--success-soft:#ecfdf3;--shadow-sm:0 1px 2px rgba(0,0,0,0.04);--shadow-card:0 1px 3px rgba(0,0,0,0.04),0 6px 20px rgba(0,0,0,0.05);--radius-lg:16px;--radius-md:12px;--radius-sm:8px;--shell:min(1200px,calc(100vw - 48px));--font-sans:"Geist","SF Pro Text","Segoe UI","Helvetica Neue",sans-serif}*{box-sizing:border-box}html{font-size:15px;overflow-y:scroll;scrollbar-gutter:stable}body,html{background:var(--background)}body{margin:0;min-height:100vh;color:var(--foreground);font-family:var(--font-sans);line-height:1.6;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}code,pre{font-family:SFMono-Regular,Menlo,Monaco,Consolas,monospace}button,input,select,textarea{font:inherit}.app-shell{width:var(--shell);margin:0 auto;min-height:100vh;display:flex;flex-direction:column;padding:0 0 32px}.app-footer{margin-top:auto;padding-top:24px;color:var(--muted-foreground);font-size:.8125rem;text-align:center}.home-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(300px,.85fr);grid-gap:20px;gap:20px;align-items:start}.home-grid-span{grid-column:1/-1}.review-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(300px,.75fr);grid-gap:20px;gap:20px;align-items:start}.site-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 0;border-bottom:1px solid var(--border);margin-bottom:32px}.site-logo{font-size:.875rem;font-weight:600;color:var(--foreground);letter-spacing:-.01em}.site-nav-actions{display:flex;align-items:center;gap:12px;margin-left:auto}.site-nav-links{display:flex;align-items:center;gap:8px}.icon-link{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid var(--border);border-radius:999px;color:var(--muted-foreground);background:var(--card);box-shadow:var(--shadow-sm);transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease}.icon-link:hover{background:var(--muted);border-color:var(--border-strong);color:var(--foreground)}.icon-link:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.icon-link svg{width:16px;height:16px}.page-hero{margin-bottom:32px}.page-title{margin:0 0 10px;font-size:clamp(1.75rem,3vw,2.5rem);line-height:1.1;letter-spacing:-.03em;font-weight:700}.page-subtitle{margin:0;color:var(--muted-foreground);font-size:1rem;line-height:1.6;max-width:42rem;white-space:normal;overflow-wrap:anywhere;text-wrap:pretty}.card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--card);box-shadow:var(--shadow-card)}.card-padded{padding:28px}.card-padded-sm{padding:20px}.section-kicker{margin:0;color:var(--muted-foreground);font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.section-title{margin:0;font-size:1.125rem;line-height:1.25;letter-spacing:-.02em;font-weight:600}.guide-footer,.helper-text,.section-copy,.small-text{margin:0;color:var(--muted-foreground);line-height:1.55}.helper-text{font-size:.875rem}.small-text{font-size:.8125rem}.stack{display:grid;grid-gap:16px;gap:16px}.stack-sm{display:grid;grid-gap:8px;gap:8px}.stack-xs{display:grid;grid-gap:4px;gap:4px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 18px;border:1px solid transparent;border-radius:999px;font-weight:600;font-size:.875rem;cursor:pointer;transition:background .14s ease,border-color .14s ease,color .14s ease,box-shadow .14s ease,opacity .14s ease;white-space:nowrap}.button:disabled{opacity:.5;cursor:not-allowed}.button-primary{background:var(--primary);color:var(--primary-foreground)}.button-primary:hover:not(:disabled){background:#1e293b}.button-secondary{background:var(--card);color:var(--foreground);border-color:var(--border);box-shadow:var(--shadow-sm)}.button-secondary:hover:not(:disabled){background:var(--muted);border-color:var(--border-strong)}.button-ghost{background:transparent;color:var(--muted-foreground);border-color:var(--border)}.button-ghost:hover:not(:disabled){background:var(--muted);color:var(--foreground)}.button-sm{min-height:34px;padding:0 14px;font-size:.8125rem}.button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}.button-row{display:flex;flex-wrap:wrap;gap:8px}.badge{display:inline-flex;align-items:center;justify-content:center;min-height:24px;padding:0 9px;border-radius:999px;border:1px solid transparent;font-size:.75rem;font-weight:500;background:var(--muted)}.badge,.badge-outline{color:var(--muted-foreground)}.badge-outline{background:transparent;border-color:var(--border)}.badge-secondary{background:var(--muted);border-color:var(--border);color:var(--foreground)}.badge-destructive{background:var(--destructive-soft);color:var(--destructive);border-color:rgba(180,35,24,.1)}.badge-row{display:flex;flex-wrap:wrap;gap:6px}.field{display:grid;grid-gap:6px;gap:6px}.field label{font-size:.8125rem;font-weight:600;color:var(--foreground)}.field input,.field select,.field textarea{width:100%;height:40px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--input);padding:0 12px;color:var(--foreground);transition:border-color .12s ease,box-shadow .12s ease;box-shadow:var(--shadow-sm)}.field textarea{height:auto;padding:10px 12px;resize:vertical}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:rgba(37,99,235,.5);box-shadow:0 0 0 3px var(--ring)}.upload-form{display:grid;grid-gap:20px;gap:20px}.upload-dropzone{border:2px dashed var(--border);border-radius:var(--radius-md);background:var(--muted);transition:border-color .15s ease,background .15s ease}.upload-dropzone:hover{border-color:var(--accent);background:var(--accent-soft)}.dropzone-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 24px;cursor:pointer;text-align:center;min-height:180px}.dropzone-label input{display:none}.dropzone-icon{width:44px;height:44px;color:var(--muted-foreground);opacity:.7}.dropzone-title{font-size:.9375rem;font-weight:600;color:var(--foreground)}.dropzone-copy{color:var(--muted-foreground);font-size:.8125rem;line-height:1.5}.thumb-strip{display:flex;gap:8px;overflow-x:auto;padding:14px 16px;border-top:1px solid var(--border);scrollbar-width:thin}.thumb-item{position:relative;flex:0 0 64px;height:48px;border-radius:var(--radius-sm);overflow:hidden;background:var(--border)}.thumb-item img{width:100%;height:100%;object-fit:cover}.thumb-item-more{display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:var(--muted-foreground);background:var(--muted);border:1px solid var(--border)}.control-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:14px;gap:14px}.advanced-settings{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;background:var(--card)}.advanced-settings summary{list-style:none;cursor:pointer;padding:13px 16px;font-weight:600;font-size:.875rem;display:flex;align-items:center;gap:8px;color:var(--foreground)}.advanced-settings summary::-webkit-details-marker{display:none}.advanced-settings summary:before{content:"›";display:inline-block;transition:transform .15s ease;color:var(--muted-foreground);font-size:1.1rem;line-height:1}.advanced-settings[open] summary:before{transform:rotate(90deg)}.advanced-settings[open] summary{border-bottom:1px solid var(--border)}.toggle-grid{display:grid;grid-gap:0;gap:0}.toggle-card{display:flex;gap:12px;align-items:flex-start;padding:13px 16px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s ease}.toggle-card:last-child{border-bottom:none}.toggle-card:hover{background:var(--muted)}.toggle-card input[type=checkbox]{margin-top:2px;flex-shrink:0;accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.toggle-card strong{display:block;font-size:.875rem;font-weight:600;color:var(--foreground);margin-bottom:2px}.toggle-card span{display:block;font-size:.8125rem;color:var(--muted-foreground);line-height:1.45}.toggle-inline{display:flex;gap:10px;align-items:center;cursor:pointer;font-size:.875rem;color:var(--foreground)}.toggle-inline input[type=checkbox]{accent-color:var(--accent);width:16px;height:16px;cursor:pointer}.submit-area{display:grid;grid-gap:8px;gap:8px}.status-rotator{display:inline-flex;align-items:center;gap:10px;min-height:20px;font-size:.8125rem;color:var(--muted-foreground)}.status-spinner{width:14px;height:14px;border:2px solid rgba(37,99,235,.18);border-top:2px solid var(--accent);border-radius:999px;flex-shrink:0;animation:status-spin .9s linear infinite}.status-rotating-copy{display:inline-block;animation:status-fade .22s ease}@keyframes status-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes status-fade{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.status-text{font-size:.8125rem;color:var(--muted-foreground)}.status-text.success{color:var(--success)}.error,.status-text.error{color:var(--destructive)}.divider{border:none;border-top:1px solid var(--border);margin:0}.guide-panel{display:grid;grid-gap:20px;gap:20px;padding:24px}.guide-toggle-input{position:absolute;opacity:0;pointer-events:none}.guide-toggle{display:flex;gap:4px;width:100%;padding:4px;border:1px solid var(--border);background:var(--muted)}.guide-toggle,.guide-toggle-button{align-items:center;border-radius:999px}.guide-toggle-button{flex:1 1;display:inline-flex;justify-content:center;min-height:32px;padding:0 14px;background:transparent;color:var(--muted-foreground);font-size:.8125rem;font-weight:600;text-align:center;cursor:pointer;transition:background .14s ease,color .14s ease,box-shadow .14s ease}.guide-toggle-input+.guide-toggle-input:focus-visible+.guide-toggle .guide-toggle-button:last-child,.guide-toggle-input:focus-visible+.guide-toggle-input+.guide-toggle .guide-toggle-button:first-child{box-shadow:0 0 0 3px var(--ring)}.guide-toggle-input:first-of-type:checked~.guide-toggle .guide-toggle-button:first-child,.guide-toggle-input:nth-of-type(2):checked~.guide-toggle .guide-toggle-button:last-child{background:var(--card);color:var(--foreground);box-shadow:var(--shadow-sm)}.guide-card{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card);padding:16px;display:grid;grid-gap:12px;gap:12px}.guide-card.guide-card-api,.guide-card.guide-card-cli{display:none}.guide-toggle-input:first-of-type:checked~.guide-card.guide-card-api,.guide-toggle-input:nth-of-type(2):checked~.guide-card.guide-card-cli{display:grid}.guide-card-header{display:grid;grid-gap:6px;gap:6px}.step-list{margin:0;padding-left:18px;color:var(--muted-foreground);font-size:.875rem;line-height:1.65}.code-block{margin:0;padding:12px 14px;border-radius:var(--radius-sm);background:var(--muted);color:var(--foreground);border:1px solid var(--border);font-size:.775rem;overflow-x:auto;line-height:1.6}.code-block-secondary{background:#f3f4f6}.guide-cli-command{padding-top:14px;padding-bottom:14px}.status-card{display:flex;align-items:center;gap:14px;padding:20px 24px}.status-card-error{justify-content:space-between;flex-wrap:wrap;gap:16px}.status-dot{width:10px;height:10px;border-radius:999px;flex:0 0 auto}.status-dot-live{background:var(--accent);box-shadow:0 0 0 5px rgba(37,99,235,.12);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 0 0 5px rgba(37,99,235,.12)}50%{box-shadow:0 0 0 8px rgba(37,99,235,.06)}}.results-shell{display:grid;grid-gap:20px;gap:20px;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.results-summary{padding:24px 28px;display:grid;grid-gap:20px;gap:20px}.results-topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.results-meta{font-size:.8125rem;color:var(--muted-foreground);margin:0 0 6px}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));grid-gap:12px;gap:12px}.summary-grid-compact{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));grid-gap:12px;gap:12px}.summary-card{padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--muted)}.summary-label{display:block;margin-bottom:4px;color:var(--muted-foreground);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}.summary-card strong{display:block;font-size:1.5rem;font-weight:700;letter-spacing:-.03em;line-height:1.1;color:var(--foreground)}.alert-panel{display:flex;align-items:center;flex-wrap:wrap;gap:10px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--muted);font-size:.875rem;color:var(--muted-foreground)}.alert-panel-warning{background:var(--warning-soft);border-color:rgba(154,103,0,.15);color:var(--warning)}.action-plan-card{padding:18px 20px;background:linear-gradient(180deg,#fbfdff,#f8fafc)}.action-list{display:grid;grid-gap:10px;gap:10px}.action-list-compact{gap:8px}.action-item{display:grid;grid-gap:8px;gap:8px;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--card)}.action-item-topline{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.action-item-fix,.action-item-topline strong{font-size:.875rem;color:var(--foreground)}.action-item-fix{margin:0;line-height:1.5}.review-list{padding:0;overflow:hidden}.review-list-header{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--border)}.photo-list,.photo-row{display:grid}.photo-row{grid-template-columns:32px 112px minmax(0,1fr);grid-gap:14px;gap:14px;align-items:start;padding:14px 20px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .12s ease}.photo-row:last-child{border-bottom:none}.photo-row:hover{background:var(--muted)}.photo-row.is-active{background:var(--accent-soft)}.photo-row:focus-visible{outline:none;box-shadow:inset 0 0 0 2px var(--accent)}.photo-rank{display:flex;align-items:center;justify-content:center;padding-top:6px;color:var(--muted-foreground);font-size:.8125rem;font-weight:600}.photo-thumb{aspect-ratio:4/3;overflow:hidden;border-radius:var(--radius-sm);background:var(--muted)}.photo-thumb img{width:100%;height:100%;object-fit:cover}.photo-content{display:grid;grid-gap:8px;gap:8px;padding-top:2px}.photo-name{margin:0;font-size:.875rem;font-weight:600;line-height:1.35;color:var(--foreground)}.photo-summary{margin:0;font-size:.8125rem;color:var(--muted-foreground);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.editor-panel{padding:0;overflow:hidden}.editor-stack{display:grid}.editor-preview{aspect-ratio:4/3;overflow:hidden;background:var(--muted);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.editor-preview img{width:100%;height:100%;object-fit:cover}.editor-body{padding:20px;display:grid;grid-gap:20px;gap:20px}.editor-info{display:grid;grid-gap:4px;gap:4px;padding-bottom:16px;border-bottom:1px solid var(--border)}.editor-title{margin:0;font-size:.9375rem;font-weight:600;line-height:1.3;color:var(--foreground)}.editor-section{display:grid;grid-gap:12px;gap:12px}.editor-section-title{margin:0;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.editor-section-title,.score-strip{font-size:.8125rem;color:var(--muted-foreground)}.score-strip{display:flex;flex-wrap:wrap;gap:8px 16px}.score-strip strong{color:var(--foreground)}.criteria-grid{display:grid;grid-gap:8px;gap:8px}.criteria-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--muted);font-size:.8125rem;color:var(--muted-foreground)}.criteria-row strong{color:var(--foreground)}.empty-state{padding:32px 24px;text-align:center;display:grid;grid-gap:8px;gap:8px}.text-link{color:var(--muted-foreground);font-size:.875rem;cursor:pointer}.text-link:hover{color:var(--foreground)}@media (max-width:980px){.control-grid,.home-grid,.review-layout,.summary-grid,.summary-grid-compact{grid-template-columns:1fr}.page-title{font-size:clamp(1.6rem,5.5vw,2.25rem)}}@media (max-width:720px){:root{--shell:calc(100vw - 32px)}.field input,.field select,.field textarea{font-size:16px}.app-shell{padding:0 0 24px}.site-nav{padding:16px 0 24px;margin-bottom:28px}.site-nav-actions{width:100%;justify-content:space-between}.photo-row{grid-template-columns:28px 88px minmax(0,1fr);gap:10px;padding:12px 16px}.button-row,.results-topbar,.review-list-header,.status-card,.status-card-error{flex-direction:column;align-items:stretch}.button{width:100%;justify-content:center}.app-footer{padding-top:20px}}