*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-text-size-adjust:100%;text-size-adjust:100%;overflow-x:hidden}body{-webkit-font-smoothing:antialiased;min-height:100dvh;line-height:1.5}img,svg,video,canvas{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}a{color:inherit;text-decoration:none}fieldset{border:none}:root{--color-bg:#f5f5f4;--color-surface:#fff;--color-text:#18181b;--color-text-muted:#52525b;--color-border:#d4d4d8;--color-accent:#b91c1c;--color-accent-text:#fff;--color-success:#15803d;--color-danger:#b91c1c;--color-nav-bg:#fff;--color-nav-text:#71717a;--color-nav-active:var(--color-accent);--space-xs:.25rem;--space-sm:.5rem;--space-md:1rem;--space-lg:1.5rem;--space-xl:2rem;--space-2xl:3rem;--font-sans:system-ui, -apple-system, sans-serif;--font-mono:ui-monospace, "Cascadia Code", "Fira Code", monospace;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.5rem;--font-size-2xl:2rem;--font-size-3xl:2.5rem;--nav-height:3.5rem;--radius:.375rem;--radius-sm:.25rem;--transition-fast:.12s ease}@media (prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=darkroom]){--color-bg:#09090b;--color-surface:#18181b;--color-text:#e4e4e7;--color-text-muted:#a1a1aa;--color-border:#27272a;--color-accent:#ef4444;--color-success:#22c55e;--color-danger:#ef4444;--color-nav-bg:#18181b;--color-nav-text:#71717a}}[data-theme=dark]{--color-bg:#09090b;--color-surface:#18181b;--color-text:#e4e4e7;--color-text-muted:#a1a1aa;--color-border:#27272a;--color-accent:#ef4444;--color-success:#22c55e;--color-danger:#ef4444;--color-nav-bg:#18181b;--color-nav-text:#71717a}[data-theme=darkroom]{--color-bg:#0a0000;--color-surface:#1a0505;--color-text:#c33;--color-text-muted:#802020;--color-border:#331010;--color-accent:#c20;--color-accent-text:#0a0000;--color-success:#930;--color-danger:#c20;--color-nav-bg:#1a0505;--color-nav-text:#802020;--color-nav-active:#c33}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);line-height:1.6}#app{padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--space-lg));max-width:32rem;margin:0 auto;overflow-x:hidden}input,select,textarea{box-sizing:border-box;min-width:0}.page h1{font-size:var(--font-size-xl);letter-spacing:-.01em;margin-bottom:var(--space-md);font-weight:700}.page h2{font-size:var(--font-size-lg);letter-spacing:-.01em;font-weight:600}#bottom-nav{min-height:var(--nav-height);background:var(--color-nav-bg);border-top:1px solid var(--color-border);z-index:100;padding-top:var(--space-sm);padding-bottom:env(safe-area-inset-bottom,var(--space-xs));justify-content:space-around;align-items:stretch;display:flex;position:fixed;bottom:0;left:0;right:0}#bottom-nav a{padding:0 var(--space-sm);min-width:3rem;color:var(--color-nav-text);transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;justify-content:center;align-items:center;gap:.25rem;text-decoration:none;display:flex}#bottom-nav a.active{color:var(--color-nav-active)}.nav-icon{font-size:1.5rem;line-height:1}.nav-label{font-size:var(--font-size-xs);letter-spacing:.02em;font-weight:500;line-height:1}fieldset{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}fieldset legend{font-weight:600;font-size:var(--font-size-sm);letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-muted);padding:0 var(--space-xs)}.theme-options{gap:var(--space-md);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.page-settings fieldset p{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.page-settings fieldset>label,.s3-config-form label{gap:var(--space-xs);font-size:var(--font-size-sm);margin-bottom:var(--space-sm);flex-direction:column;font-weight:600;display:flex}.page-settings fieldset input[type=text],.page-settings fieldset input[type=url],.page-settings fieldset input[type=password]{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);color:var(--color-text);width:100%;font-weight:400}.settings-actions{gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap;display:flex}.settings-status{font-size:var(--font-size-sm);margin-top:var(--space-xs)}.backup-list{font-size:var(--font-size-sm);margin-top:var(--space-sm);padding:0;list-style:none}.backup-list li{padding:var(--space-xs) 0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.backup-list li:last-child{border-bottom:none}.backup-info{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.about-info{font-size:var(--font-size-sm)}.about-info dt{color:var(--color-text-muted);float:left;width:5rem;font-weight:600}.about-info dd{margin-left:5.5rem;margin-bottom:var(--space-xs)}.theme-options label{align-items:center;gap:var(--space-xs);cursor:pointer;display:flex}.update-banner{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-accent);color:#fff;font-size:var(--font-size-sm);z-index:200;display:flex;position:fixed;top:0;left:0;right:0}.update-banner button{color:#fff;border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm);cursor:pointer;font-size:var(--font-size-sm);background:#ffffff26;border:1px solid #ffffff4d}.material-symbols-outlined{font-size:inherit;vertical-align:middle;line-height:1}button .material-symbols-outlined,a .material-symbols-outlined{margin-right:.125em;font-size:1.25em}input[type=checkbox]{appearance:none;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;width:1.125rem;height:1.125rem;transition:background var(--transition-fast), border-color var(--transition-fast);flex-shrink:0;position:relative}input[type=checkbox]:checked{background:var(--color-accent);border-color:var(--color-accent)}input[type=checkbox]:checked:after{content:"";border:solid var(--color-accent-text);border-width:0 2px 2px 0;width:5px;height:9px;position:absolute;top:1px;left:4px;transform:rotate(45deg)}input[type=radio]{appearance:none;border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:1.125rem;height:1.125rem;transition:border-color var(--transition-fast);border-radius:50%;flex-shrink:0;position:relative}input[type=radio]:checked{border-color:var(--color-accent)}input[type=radio]:checked:after{content:"";background:var(--color-accent);border-radius:50%;width:8px;height:8px;position:absolute;top:3px;left:3px}select{appearance:none;padding:var(--space-xs) var(--space-md) var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font:inherit;font-size:var(--font-size-sm);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%2371717a' d='M5 6L0 0h10z'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;background-size:10px 6px;padding-right:1.5rem}select:focus{border-color:var(--color-accent)}[data-theme=darkroom] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23802020' d='M5 6L0 0h10z'/%3E%3C/svg%3E")}[data-theme=dark] select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23a1a1aa' d='M5 6L0 0h10z'/%3E%3C/svg%3E")}@media (prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=darkroom]) select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%23a1a1aa' d='M5 6L0 0h10z'/%3E%3C/svg%3E")}}:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.page-timer{gap:var(--space-md);flex-direction:column;display:flex}.recipe-selector{gap:var(--space-sm);flex-direction:column;display:flex}.recipe-selector select{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base)}.recipe-actions{gap:var(--space-sm);flex-wrap:wrap;display:flex}.recipe-link{color:var(--color-text-muted);text-decoration:none}.recipe-link:hover{color:var(--color-text)}.timer-display{align-items:center;gap:var(--space-sm);flex-direction:column;display:flex}.timer-ring{width:240px;height:240px;position:relative}.timer-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.timer-ring-bg{fill:none;stroke:var(--color-border);stroke-width:8px}.timer-ring-progress{fill:none;stroke:var(--color-accent);stroke-width:8px;stroke-linecap:round;transition:stroke-dashoffset .1s linear}.timer-ring-text{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.timer-time{font-family:var(--font-mono);font-size:var(--font-size-2xl);letter-spacing:.05em;font-weight:700;line-height:1}.timer-step-name{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-xs)}.timer-agitation{font-size:var(--font-size-sm);color:var(--color-accent);min-height:1.25em;font-weight:600}.timer-temp[hidden]{display:none}.timer-temp{padding:var(--space-xs) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text);letter-spacing:.02em;justify-content:center;align-items:center;gap:.375em;font-weight:600;display:flex}.timer-temp .material-symbols-outlined{color:var(--color-accent);font-size:1.25em}.timer-controls{justify-content:center;gap:var(--space-md);display:flex}.timer-controls button{min-width:4.5rem;min-height:2.75rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-weight:600;font-size:var(--font-size-sm);-webkit-tap-highlight-color:transparent;transition:transform 80ms ease, background var(--transition-fast), color var(--transition-fast)}.timer-controls button:active{transform:scale(.94)}.timer-controls .btn-primary{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.step-list{gap:var(--space-xs);flex-direction:column;list-style:none;display:flex}.step-list li{padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);font-size:var(--font-size-sm);justify-content:space-between;display:flex}.step-list li.active{border-color:var(--color-accent);font-weight:600}.step-list li.done{opacity:.5;text-decoration:line-through}.handsfree .timer-ring{width:320px;height:320px}.handsfree .timer-time{font-size:3.5rem}.handsfree .timer-controls button{min-width:5rem;min-height:3.5rem;font-size:var(--font-size-lg)}.timer-options{align-items:center;gap:var(--space-md);font-size:var(--font-size-sm);display:flex}.timer-options label{align-items:center;gap:var(--space-xs);cursor:pointer;display:flex}.btn-sm{min-height:2.25rem;padding:var(--space-xs) var(--space-md);border-radius:var(--radius);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:var(--font-size-sm);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;transition:transform 80ms ease, background var(--transition-fast), border-color var(--transition-fast);justify-content:center;align-items:center;gap:.25em;font-weight:500;line-height:1;display:inline-flex}.btn-sm:active{transform:scale(.94)}.btn-primary{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.btn-danger{color:var(--color-danger);border-color:var(--color-danger)}.recipe-editor{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-top:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.recipe-editor h2{font-size:var(--font-size-lg);margin-bottom:var(--space-xs)}.recipe-editor label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.recipe-editor input{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-sizing:border-box;width:100%;min-width:0;font-weight:400}.recipe-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.recipe-row{grid-template-columns:1fr}}.step-row{gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);grid-template-columns:2fr 1fr 1fr 1fr auto;align-items:end;display:grid}@media (max-width:480px){.step-row{grid-template-columns:1fr 1fr}}.btn-remove-step{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;width:2rem;height:2rem;font-size:var(--font-size-lg);justify-content:center;align-items:center;display:flex}.recipe-editor-actions{gap:var(--space-sm);margin-top:var(--space-sm);display:flex}.darkroom-toggle{margin:var(--space-sm) 0;justify-content:center;display:flex}.darkroom-switch{padding:var(--space-xs) var(--space-md);border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);min-height:2.25rem;color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);align-items:center;gap:.375em;font-weight:600;display:inline-flex}.darkroom-switch .material-symbols-outlined{font-size:1.25em}.darkroom-switch.active{color:#c33;background:#1a0505;border-color:#c33}.darkroom-switch.active .material-symbols-outlined{color:#c20}.darkroom-warning[hidden]{display:none}.darkroom-warning{z-index:150;padding:var(--space-md);background:#0a0000d9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.darkroom-warning-content{border-radius:var(--radius);padding:var(--space-lg);text-align:center;color:#c33;background:#1a0505;border:1px solid #331010;max-width:20rem}.darkroom-warning-icon{margin-bottom:var(--space-sm);color:#c20;font-size:2rem;display:block}.darkroom-warning-content p{font-size:var(--font-size-sm);margin-bottom:var(--space-md);color:#802020;line-height:1.5}.darkroom-warning-actions{gap:var(--space-sm);justify-content:center;display:flex}.darkroom-warning-actions .btn-sm{color:#c33;background:#1a0505;border-color:#331010}.darkroom-warning-actions .btn-danger{color:#c20;border-color:#c20}.dev-tools-panel{border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden}.dev-tools-toggle{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-surface);cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text);text-align:left;transition:background var(--transition-fast);border:none;border-radius:0;font-weight:600;display:flex}.dev-tools-toggle:hover{background:color-mix(in srgb, var(--color-border) 50%, var(--color-surface))}.dev-tools-toggle .material-symbols-outlined{color:var(--color-accent);font-size:1.1rem}.dev-tools-chevron{color:var(--color-text-muted);margin-left:auto;font-size:1.1rem}.dev-tools-body{padding:var(--space-md);gap:var(--space-lg);border-top:1px solid var(--color-border);flex-direction:column;display:flex}.dev-tools-section{gap:var(--space-sm);flex-direction:column;display:flex}.dev-tools-section-title{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0;font-weight:600}.dev-tools-recipe-temp{font-size:var(--font-size-sm);margin:0}.dev-tools-label{font-size:var(--font-size-sm);color:var(--color-text);flex-direction:column;gap:.25rem;display:flex}.dev-tools-input{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-sm);font-family:var(--font-sans)}.dev-tools-input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.dev-tools-result{font-size:var(--font-size-sm);min-height:1.25rem}.dev-tools-muted{color:var(--color-text-muted);font-size:var(--font-size-xs)}.dev-tools-ok{color:var(--color-success)}.dev-tools-error{color:var(--color-danger)}.dev-tools-suggestion{margin:var(--space-xs) 0 0}.dev-tools-compensation{gap:var(--space-xs);flex-direction:column;display:flex}.dev-tools-comp-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.dev-tools-comp-label{flex:1;min-width:6rem;font-weight:500}.dev-tools-comp-orig{color:var(--color-text-muted);font-family:var(--font-mono)}.dev-tools-comp-arrow{color:var(--color-text-muted)}.dev-tools-comp-adj{font-family:var(--font-mono);color:var(--color-accent);font-weight:700}.dev-tools-comp-pct{font-size:var(--font-size-xs);border-radius:var(--radius-sm);padding:.125rem .375rem;font-weight:600}.dev-tools-comp-pct.warmer{background:color-mix(in srgb, var(--color-accent) 15%, transparent);color:var(--color-accent)}.dev-tools-comp-pct.cooler{background:color-mix(in srgb, var(--color-success) 15%, transparent);color:var(--color-success)}.dev-tools-dilution-result{padding:var(--space-sm);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-direction:column;gap:.25rem;display:flex}.dev-tools-mix-row{font-size:var(--font-size-sm);justify-content:space-between;align-items:baseline;display:flex}.dev-tools-mix-row.dev-tools-mix-total{padding-top:var(--space-xs);border-top:1px solid var(--color-border);font-weight:600}.dev-tools-mix-value{font-family:var(--font-mono);color:var(--color-accent);font-weight:600}.expiry-badge{border-radius:var(--radius-sm);font-size:var(--font-size-xs);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-sm);padding:.25rem .625rem;font-weight:700;display:inline-block}.expiry-badge.expiry-expired{background:color-mix(in srgb, var(--color-danger) 15%, transparent);color:var(--color-danger);border:1px solid color-mix(in srgb, var(--color-danger) 40%, transparent)}.expiry-badge.expiry-soon{color:#d97706;background:#d9770626;border:1px solid #d9770666}.storage-info{margin-bottom:var(--space-sm)}.storage-info summary{cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-muted);padding:var(--space-xs) 0;-webkit-user-select:none;user-select:none}.storage-info-fields{gap:var(--space-sm);padding-top:var(--space-sm);flex-direction:column;display:flex}.push-pull-badge{border-radius:var(--radius-sm);font-size:var(--font-size-xs);letter-spacing:.06em;text-transform:uppercase;margin-bottom:var(--space-sm);padding:.25rem .625rem;font-weight:700;display:inline-block}.push-pull-badge.push{background:color-mix(in srgb, var(--color-accent) 15%, transparent);color:var(--color-accent);border:1px solid color-mix(in srgb, var(--color-accent) 40%, transparent)}.push-pull-badge.pull{background:color-mix(in srgb, var(--color-text-muted) 15%, transparent);color:var(--color-text-muted);border:1px solid color-mix(in srgb, var(--color-text-muted) 40%, transparent)}.pipeline-grid{gap:var(--space-xs);margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.pipeline-grid button{padding:var(--space-sm) var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:.125rem;display:flex}.pipeline-grid button .material-symbols-outlined{margin-right:0;font-size:1.5rem}.pipeline-grid .pipeline-label{text-transform:capitalize;font-size:.75rem;line-height:1}.pipeline-grid .pipeline-count{font-family:var(--font-mono);opacity:.6;font-size:.75rem;line-height:1}.pipeline-grid button.active{background:var(--color-accent);color:var(--color-accent-text);border-color:var(--color-accent)}.pipeline-grid button.active .pipeline-count{opacity:.9}.roll-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.roll-card{padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;display:flex}.roll-card:active{border-color:var(--color-accent)}.roll-card-info{flex-direction:column;gap:.125rem;display:flex}.roll-card-title{font-weight:600}.roll-card-meta{font-size:var(--font-size-sm);color:var(--color-text-muted)}.roll-card-status{font-size:var(--font-size-sm);padding:.125rem var(--space-sm);background:var(--color-border);white-space:nowrap;border-radius:1rem}.roll-detail-header{justify-content:space-between;align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.roll-detail-header h2{font-size:var(--font-size-lg);margin:0}.roll-detail-meta{gap:var(--space-xs) var(--space-md);font-size:var(--font-size-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border-radius:var(--radius);border:1px solid var(--color-border);grid-template-columns:auto 1fr;display:grid}.roll-detail-meta dt{color:var(--color-text-muted);text-transform:uppercase;font-weight:600;font-size:var(--font-size-xs);letter-spacing:.04em}.roll-detail-meta dd{font-family:var(--font-mono)}.pipeline-progress{margin-bottom:var(--space-md);gap:2px;display:flex}.pipeline-progress .stage{padding:var(--space-xs);text-align:center;background:var(--color-border);color:var(--color-text-muted);flex:1;font-size:.75rem}.pipeline-progress .stage:first-child{border-radius:var(--radius) 0 0 var(--radius)}.pipeline-progress .stage:last-child{border-radius:0 var(--radius) var(--radius) 0}.pipeline-progress .stage.reached{background:var(--color-accent);color:var(--color-accent-text)}.shot-list{gap:var(--space-xs);margin-bottom:var(--space-md);flex-direction:column;list-style:none;display:flex}.shot-item{gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);font-size:var(--font-size-sm);grid-template-columns:2.5rem 1fr auto;align-items:center;display:grid}.shot-frame{font-family:var(--font-mono);font-weight:700;font-size:var(--font-size-base)}.shot-details{flex-direction:column;gap:.125rem;display:flex}.shot-exposure{font-family:var(--font-mono)}.shot-meta{color:var(--color-text-muted);font-size:.75rem}.shot-actions{gap:var(--space-xs);display:flex}.roll-actions{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;display:flex}.btn-quick-record{min-height:2.25rem;padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm);background:var(--color-surface);color:var(--color-accent);border:1.5px solid var(--color-accent);border-radius:var(--radius);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;transition:transform 80ms ease, background var(--transition-fast);justify-content:center;align-items:center;gap:.375em;font-weight:600;display:inline-flex}.btn-quick-record:active{background:var(--color-accent);color:var(--color-accent-text);transform:scale(.94)}.shot-editor{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.shot-editor h3{font-size:var(--font-size-base);margin:0}.shot-editor label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.shot-editor input,.shot-editor textarea{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-sizing:border-box;min-width:0;font-weight:400}.shot-editor textarea{resize:vertical;min-height:3rem}.shot-editor-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.shot-editor-row{grid-template-columns:1fr}}.shot-editor-actions{gap:var(--space-sm);display:flex}.new-roll-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.new-roll-form label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.new-roll-form input,.new-roll-form select,.new-roll-form textarea{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-sizing:border-box;min-width:0;font-weight:400}.new-roll-form .form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.new-roll-form .form-row{grid-template-columns:1fr}}.new-roll-form-actions{gap:var(--space-sm);display:flex}.film-search-row{gap:var(--space-xs);align-items:center;display:flex}.film-search-row input{flex:1;min-width:0}.film-search-row .btn-icon{padding:var(--space-xs);flex-shrink:0;width:2.25rem;min-height:2.25rem}.rolls-actions{gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.film-browser-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.film-browser-header h1{margin-bottom:0}.film-search-label{gap:var(--space-xs);font-size:var(--font-size-sm);margin-bottom:var(--space-md);flex-direction:column;font-weight:600;display:flex}.film-search-label input{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);font-size:var(--font-size-base);color:var(--color-text)}.film-list{padding:0;list-style:none}.film-item{padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border);font-size:var(--font-size-sm);flex-direction:column;gap:.125rem;display:flex}.film-meta{font-family:var(--font-mono);color:var(--color-text-muted);font-size:.75rem}.film-notes{color:var(--color-text-muted);font-size:.75rem}.film-overflow{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-sm)}.scan-notes-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}.scan-notes-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.scan-notes-header h3{font-size:var(--font-size-base);align-items:center;gap:var(--space-xs);margin:0;display:flex}.scan-notes-header h3 .material-symbols-outlined{color:var(--color-text-muted);font-size:1.1rem}.scan-notes-meta{gap:var(--space-xs) var(--space-md);font-size:var(--font-size-sm);grid-template-columns:auto 1fr;margin:0;display:grid}.scan-notes-meta dt{color:var(--color-text-muted);text-transform:uppercase;font-weight:600;font-size:var(--font-size-xs);letter-spacing:.04em}.scan-notes-meta dd{font-family:var(--font-mono)}.scan-notes-meta .scan-notes-color{white-space:pre-wrap;font-family:inherit}.scan-notes-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0}.scan-notes-form{gap:var(--space-sm);flex-direction:column;display:flex}.scan-notes-form label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.scan-notes-form input,.scan-notes-form textarea{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-sizing:border-box;min-width:0;font-weight:400}.scan-notes-form textarea{resize:vertical;min-height:4rem}.scan-notes-actions{gap:var(--space-sm);display:flex}.batch-rename-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}.batch-rename-panel h3{font-size:var(--font-size-base);margin:0 0 var(--space-sm);align-items:center;gap:var(--space-xs);display:flex}.batch-rename-panel h3 .material-symbols-outlined{color:var(--color-text-muted);font-size:1.1rem}.batch-rename-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--space-sm)}.batch-rename-hint code{font-family:var(--font-mono);background:var(--color-border);border-radius:2px;padding:.1em .3em;font-size:.85em}.batch-rename-controls{gap:var(--space-sm);margin-bottom:var(--space-sm);flex-wrap:wrap;align-items:flex-end;display:flex}.batch-rename-controls label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;flex:1;min-width:12rem;font-weight:600;display:flex}.batch-rename-controls input{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);font-family:var(--font-mono);font-size:var(--font-size-sm);min-width:0}.batch-rename-actions{margin-top:var(--space-sm);gap:var(--space-sm);display:flex}.batch-rename-status{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:var(--font-mono)}.rename-preview-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);margin-top:var(--space-sm)}.rename-preview-table th{text-align:left;padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.rename-preview-table td{padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border);font-family:var(--font-mono);word-break:break-all}.rename-preview-table .rename-changed{color:var(--color-accent)}.lf-holders-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}.lf-section-heading{align-items:center;gap:var(--space-xs);font-size:var(--font-size-base);margin:0 0 var(--space-sm);display:flex}.lf-section-heading .material-symbols-outlined{color:var(--color-accent);font-size:1.2rem}.lf-holders-grid{gap:var(--space-sm);margin-bottom:var(--space-sm);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.lf-holders-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);grid-column:1/-1}.lf-holder-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-sm);gap:var(--space-xs);flex-direction:column;display:flex}.lf-holder-number{align-items:center;gap:var(--space-xs);font-weight:700;font-size:var(--font-size-sm);display:flex}.lf-holder-number .material-symbols-outlined{color:var(--color-text-muted);font-size:1rem}.lf-holder-delete{margin-left:auto}.lf-holder-sides{gap:var(--space-xs);grid-template-columns:1fr 1fr;display:grid}.lf-holder-side{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs);gap:var(--space-xs);transition:opacity var(--transition-fast);flex-direction:column;display:flex}.lf-holder-side.exposed{opacity:.55}.lf-side-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-weight:700}.lf-side-film{width:100%;padding:.2rem var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-size:var(--font-size-sm);box-sizing:border-box}.lf-expose-toggle{padding:.2rem var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:var(--font-size-xs);cursor:pointer;-webkit-tap-highlight-color:transparent;transition:background var(--transition-fast), border-color var(--transition-fast);align-items:center;gap:.25rem;display:flex}.lf-expose-toggle .material-symbols-outlined{font-size:.95rem}.lf-expose-toggle.is-exposed{background:color-mix(in srgb, var(--color-text-muted) 12%, transparent);border-color:var(--color-text-muted);text-decoration:line-through}.lf-holder-notes-label{gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);flex-direction:column;font-weight:600;display:flex}.lf-holder-notes{padding:.2rem var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-size:var(--font-size-sm);box-sizing:border-box;width:100%}.lf-add-holder{align-items:flex-end;gap:var(--space-sm);flex-wrap:wrap;display:flex}.lf-add-holder-label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.lf-shot-fields{border-top:1px solid var(--color-border);padding-top:var(--space-sm);gap:var(--space-sm);flex-direction:column;display:flex}.lf-shot-section-heading{align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-accent);text-transform:uppercase;letter-spacing:.06em;font-weight:700;display:flex}.lf-shot-section-heading .material-symbols-outlined{font-size:1rem}.lf-bellows-row{align-items:flex-end;gap:var(--space-sm);flex-wrap:wrap;display:flex}.lf-bellows-result{font-size:var(--font-size-sm);color:var(--color-accent);font-family:var(--font-mono);padding-bottom:.35rem}.lf-movements-details{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm)}.lf-movements-details summary{cursor:pointer;font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none;padding:var(--space-xs) 0;font-weight:600}.lf-movements-grid{gap:var(--space-sm);padding-top:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.lf-movements-grid,.lf-holders-grid{grid-template-columns:1fr}}.lf-movements-standard-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-xs);font-weight:700}.lf-movements-fields{gap:var(--space-xs);flex-direction:column;display:flex}.lf-movements-fields label{font-size:var(--font-size-xs)!important;font-weight:500!important}.shot-meta.lf-shot-meta{color:color-mix(in srgb, var(--color-accent) 80%, var(--color-text-muted));font-family:var(--font-mono);font-size:var(--font-size-xs)}.contact-sheet-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md)}.contact-sheet-panel h3{font-size:var(--font-size-base);margin:0 0 var(--space-xs);align-items:center;gap:var(--space-xs);display:flex}.contact-sheet-panel h3 .material-symbols-outlined{color:var(--color-text-muted);font-size:1.1rem}.contact-sheet-hint{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--space-sm)}.contact-sheet-controls{gap:var(--space-md);margin-bottom:var(--space-sm);flex-wrap:wrap;align-items:center;display:flex}.contact-sheet-controls label{align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);font-weight:600;display:flex}.contact-sheet-controls select{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);font-size:var(--font-size-sm);min-width:0}.contact-sheet-toggle{cursor:pointer;-webkit-user-select:none;user-select:none}.contact-sheet-toggle input{accent-color:var(--color-accent)}.contact-sheet-actions-top{gap:var(--space-sm);margin-bottom:var(--space-sm);display:flex}.contact-sheet-status{font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:var(--font-mono);min-height:1.25rem}.shoot-mode{z-index:200;background:var(--color-bg);padding:var(--space-md);padding-bottom:env(safe-area-inset-bottom,var(--space-md));flex-direction:column;display:flex;position:fixed;inset:0}.shoot-header{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;display:flex}.shoot-header h2{font-size:var(--font-size-lg);margin:0}.shoot-exit{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);min-width:3rem;min-height:3rem;font-size:var(--font-size-lg);cursor:pointer}.shoot-info{text-align:center;margin-bottom:var(--space-lg)}.shoot-frame-number{font-family:var(--font-mono);font-size:var(--font-size-3xl,2.5rem);letter-spacing:.05em;font-weight:700;line-height:1}.shoot-frame-label{font-size:var(--font-size-xs);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);font-weight:600}.shoot-light-info{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-sm);min-height:1.5em}.shoot-exposure{gap:var(--space-xs);margin-bottom:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.shoot-exposure-field{flex-direction:column;gap:.125rem;display:flex}.shoot-exposure-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);text-align:center;font-weight:600}.shoot-exposure-select{font-family:var(--font-mono);text-align:center}.shoot-lens-row{margin-bottom:var(--space-sm);flex-direction:column;gap:.125rem;display:flex}.shoot-lens-select{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);box-sizing:border-box;min-width:0}.shoot-btn{min-height:8rem;margin-bottom:var(--space-md);border-radius:var(--radius);background:var(--color-accent);color:var(--color-accent-text);cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;border:none;flex:1;justify-content:center;align-items:center;font-size:2rem;font-weight:700;transition:transform 80ms,opacity 80ms;display:flex}.shoot-btn:active{opacity:.9;transform:scale(.96)}.shoot-btn.recording{background:var(--color-success);animation:.3s pulse}@keyframes pulse{0%{transform:scale(.96)}50%{transform:scale(1.02)}to{transform:scale(1)}}.shoot-recent{gap:var(--space-sm);padding-bottom:var(--space-sm);-webkit-overflow-scrolling:touch;display:flex;overflow-x:auto}.shoot-recent-item{min-width:4rem;padding:var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);text-align:center;font-size:var(--font-size-sm);flex-shrink:0}.shoot-recent-frame{font-family:var(--font-mono);font-weight:700}.shoot-recent-time{color:var(--color-text-muted);font-size:.75rem}.shoot-lf-section{gap:var(--space-sm);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.shoot-lf-row{align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.shoot-bellows-result{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-accent)}.shoot-lf-movements{border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:var(--space-xs) var(--space-sm)}.shoot-lf-movements summary{cursor:pointer;-webkit-user-select:none;user-select:none;font-size:var(--font-size-sm);padding:var(--space-xs) 0;font-weight:600}.shoot-lf-mov-grid{gap:var(--space-sm);padding-top:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.shoot-lf-mov-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-xs);font-weight:700}.shoot-lf-mov-std{gap:var(--space-xs);flex-direction:column;display:flex}.shoot-lf-mov-std label{align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500;display:flex}.shoot-lf-mov-std input{width:5rem;padding:.2rem var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:var(--font-size-sm);box-sizing:border-box}.ev-calculator{gap:var(--space-sm);margin-bottom:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.ev-field{gap:var(--space-xs);flex-direction:column;display:flex}.ev-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:600}.ev-select{padding:var(--space-sm);font-family:var(--font-mono);text-align:center}.ev-result{padding:var(--space-lg) var(--space-md);margin-bottom:var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;align-items:center;display:flex}.ev-result-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);font-weight:600}.ev-result-value{font-family:var(--font-mono);font-size:var(--font-size-3xl,2.5rem);letter-spacing:.05em;font-weight:700;line-height:1.2}.ev-result-sub{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-xs);text-align:center}.ev-table-section h2{margin-bottom:var(--space-sm)}.ev-table{border-collapse:collapse;width:100%;font-family:var(--font-mono);font-size:var(--font-size-xs);display:block;overflow-x:auto}.ev-table thead{display:table-header-group}.ev-table tbody{display:table-row-group}.ev-table tr{display:table-row}.ev-table th,.ev-table td{text-align:center;border:1px solid var(--color-border);white-space:nowrap;padding:.25rem .375rem;display:table-cell}.ev-table thead th{background:var(--color-surface);font-weight:600;position:sticky;top:0}.ev-table tbody th{background:var(--color-surface);text-align:right;font-weight:600;position:sticky;left:0}.ev-table td{color:var(--color-text-muted)}.meter-details{margin-top:var(--space-lg);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);overflow:hidden}.meter-details-summary{align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:600;list-style:none;display:flex}.meter-details-summary::-webkit-details-marker{display:none}.meter-details-summary:before{content:"▶";transition:transform var(--transition-fast);flex-shrink:0;font-size:.6em}.meter-details[open] .meter-details-summary:before{transform:rotate(90deg)}.meter-details-body{padding:var(--space-md);border-top:1px solid var(--color-border)}.sunny16-controls{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.sunny16-iso-select{width:auto}.sunny16-table{border-collapse:collapse;width:100%;font-size:var(--font-size-xs);display:block;overflow-x:auto}.sunny16-table thead{display:table-header-group}.sunny16-table tbody{display:table-row-group}.sunny16-table tr{display:table-row}.sunny16-table th,.sunny16-table td{border:1px solid var(--color-border);vertical-align:top;padding:.3rem .5rem;display:table-cell}.sunny16-table thead th{background:var(--color-surface);text-align:left;white-space:nowrap;font-weight:600}.sunny16-condition{background:var(--color-surface);white-space:nowrap;color:var(--color-text-muted);text-align:left;font-weight:600}.sunny16-combos{color:var(--color-text-muted)}.sunny16-combo{font-family:var(--font-mono);font-size:var(--font-size-xs);white-space:nowrap;background:var(--color-bg);border-radius:var(--radius-sm);margin:.1rem .25rem .1rem 0;padding:.1rem .3rem;display:inline-block}.filter-controls{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.filter-controls .ev-select{flex:1}.filter-result{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}@media (max-width:480px){.filter-result{grid-template-columns:1fr}}.filter-result-row{gap:var(--space-xs);padding:var(--space-sm);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);flex-direction:column;display:flex}.filter-result-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);font-weight:600}.filter-result-value{font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:700}.more-grid{gap:var(--space-md);padding:var(--space-md) 0;grid-template-columns:repeat(2,1fr);display:grid}.more-grid-item{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);-webkit-tap-highlight-color:transparent;flex-direction:column;text-decoration:none;transition:background .15s,border-color .15s;display:flex}.more-grid-item:active,.more-grid-item:hover{background:var(--color-surface-raised);border-color:var(--color-accent)}.more-grid-icon{color:var(--color-accent);font-size:2rem}.more-grid-label{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.placeholder-message{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-xl) var(--space-md);color:var(--color-text-muted);text-align:center;flex-direction:column;min-height:40vh;display:flex}.placeholder-icon{opacity:.4;font-size:3rem}.gear-section{margin-bottom:var(--space-xl)}.gear-section-header{margin-bottom:var(--space-sm);justify-content:space-between;align-items:center;display:flex}.gear-section-header h2{align-items:center;gap:var(--space-xs);font-size:var(--font-size-base);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:0;font-weight:700;display:flex}.gear-section-header h2 .material-symbols-outlined{font-size:1.1em}.gear-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.gear-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:var(--space-md) 0;text-align:center}.gear-card{justify-content:space-between;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);display:flex}.gear-card-info{flex-direction:column;gap:.125rem;min-width:0;display:flex}.gear-card-name{font-weight:600;font-size:var(--font-size-sm)}.gear-card-meta{color:var(--color-text-muted);font-size:.75rem}.gear-card-actions{gap:var(--space-xs);flex-shrink:0;display:flex}.gear-form-slot{margin-bottom:var(--space-sm)}.gear-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);gap:var(--space-sm);margin-bottom:var(--space-sm);flex-direction:column;display:flex}.gear-form h3{font-size:var(--font-size-base);margin:0}.gear-form label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.gear-form input,.gear-form select,.gear-form textarea{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-bg);box-sizing:border-box;min-width:0;font-weight:400}.gear-form textarea{resize:vertical;min-height:3rem}.gear-form .form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.gear-form .form-row{grid-template-columns:1fr}}.gear-form-actions{gap:var(--space-sm);display:flex}.page-header{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-lg);display:flex}.page-header h1{margin:0}.back-btn{color:var(--color-accent);padding:var(--space-xs);border-radius:var(--radius-sm);-webkit-tap-highlight-color:transparent;align-items:center;text-decoration:none;display:flex}.back-btn:active{opacity:.7}.reference-guide{padding-bottom:var(--space-xl)}.reference-guide h2{align-items:center;gap:var(--space-sm);font-size:var(--font-size-lg);margin-bottom:var(--space-md);display:flex}.reference-guide h2 .material-symbols-outlined{color:var(--color-accent);font-size:1.4rem}.reference-section{border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--space-sm);background:var(--color-surface);overflow:hidden}.reference-section summary{padding:var(--space-sm) var(--space-md);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;justify-content:space-between;align-items:center;font-weight:600;list-style:none;display:flex}.reference-section summary:after{content:"expand_more";color:var(--color-text-muted);font-family:Material Symbols Outlined;font-size:1.1rem;transition:transform .2s}.reference-section[open] summary:after{transform:rotate(180deg)}.reference-section summary::-webkit-details-marker{display:none}.reference-body{padding:0 var(--space-md) var(--space-md);font-size:var(--font-size-sm);line-height:1.6}.reference-body h4{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin:var(--space-sm) 0 var(--space-xs);font-weight:700}.reference-body h4:first-child{margin-top:0}.reference-body ul,.reference-body ol{margin:0 0 var(--space-sm);flex-direction:column;gap:.25rem;padding-left:1.25rem;display:flex}.reference-body li{color:var(--color-text)}.reference-body strong{color:var(--color-text);font-weight:600}.reference-body em{color:var(--color-accent);font-style:normal;font-weight:500}.page-darkroom{gap:var(--space-md);flex-direction:column;display:flex}.darkroom-header{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.darkroom-header h1{font-size:var(--font-size-xl);margin:0}.darkroom-sub-header{justify-content:space-between;align-items:center;gap:var(--space-sm);flex-wrap:wrap;display:flex}.darkroom-sub-header h1{font-size:var(--font-size-xl);flex:1;margin:0}.darkroom-sub-header-actions{gap:var(--space-xs);flex-wrap:wrap;display:flex}.darkroom-quick-nav{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}.darkroom-nav-btn{align-items:center;gap:var(--space-xs);padding:var(--space-md) var(--space-sm);border:1.5px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);cursor:pointer;font-size:var(--font-size-sm);transition:background var(--transition-fast), border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;flex-direction:column;font-weight:600;display:flex}.darkroom-nav-btn:active{transform:scale(.95)}.darkroom-nav-btn .material-symbols-outlined{color:var(--color-accent);font-size:1.5rem}.darkroom-section-actions{gap:var(--space-sm);display:flex}.darkroom-filter-bar{gap:var(--space-md);flex-wrap:wrap;display:flex}.filter-label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;flex:1;min-width:8rem;font-weight:600;display:flex}.paper-search-label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;font-weight:600;display:flex}.paper-list{gap:var(--space-xs);flex-direction:column;list-style:none;display:flex}.paper-item{padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);gap:var(--space-xs);flex-direction:column;display:flex}.paper-item-header{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.paper-item-name{font-size:var(--font-size-base)}.paper-badge{font-size:var(--font-size-xs);border-radius:var(--radius-sm);letter-spacing:.05em;flex-shrink:0;padding:.125rem .5rem;font-weight:700}.paper-type-rc{background:color-mix(in srgb, var(--color-accent) 15%, transparent);color:var(--color-accent);border:1px solid color-mix(in srgb, var(--color-accent) 40%, transparent)}.paper-type-fb{background:color-mix(in srgb, var(--color-success) 15%, transparent);color:var(--color-success);border:1px solid color-mix(in srgb, var(--color-success) 40%, transparent)}.paper-item-meta{gap:var(--space-md);font-size:var(--font-size-sm);color:var(--color-text-muted);flex-wrap:wrap;display:flex}.paper-item-notes{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0;line-height:1.45}.paper-user-badge{font-size:var(--font-size-xs);color:var(--color-text-muted);font-style:italic}.paper-add-form{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);gap:var(--space-sm);flex-direction:column;display:flex}.paper-add-form h2{font-size:var(--font-size-lg);margin:0}.paper-form-actions{gap:var(--space-sm);display:flex}.print-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.print-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-sm) var(--space-md);cursor:pointer;align-items:center;gap:var(--space-sm);transition:border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;display:flex}.print-card:hover,.print-card:focus{border-color:var(--color-accent);outline:none}.print-card-body{flex-direction:column;flex:1;gap:.25rem;display:flex}.print-card-top{justify-content:space-between;align-items:baseline;gap:var(--space-sm);display:flex}.print-card-paper{font-weight:600;font-size:var(--font-size-base)}.print-card-rating{font-size:var(--font-size-sm);color:var(--color-accent);flex-shrink:0}.print-card-neg,.print-card-meta{font-size:var(--font-size-sm);color:var(--color-text-muted)}.print-card-date{font-size:var(--font-size-xs);color:var(--color-text-muted)}.print-card-chevron{color:var(--color-text-muted);flex-shrink:0;font-size:1.25rem}.print-detail-title{font-size:var(--font-size-xl);margin:0}.print-detail-rating{color:var(--color-accent);font-size:1.25rem}.print-detail-date{font-size:var(--font-size-sm);color:var(--color-text-muted)}.print-detail-grid{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.print-detail-grid{grid-template-columns:1fr}}.print-detail-field{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-sm) var(--space-md);flex-direction:column;gap:.125rem;display:flex}.field-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.field-value{font-size:var(--font-size-base);font-weight:600}.print-detail-exposure{font-family:var(--font-mono);font-size:var(--font-size-lg);color:var(--color-accent)}.print-neg-link{cursor:pointer;color:var(--color-accent);text-decoration:underline}.print-neg-link:hover{opacity:.8}.print-dodge-burn-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md)}.print-db-title{align-items:center;gap:var(--space-xs);font-size:var(--font-size-base);margin:0 0 var(--space-xs);color:var(--color-accent);font-weight:700;display:flex}.print-db-title .material-symbols-outlined{font-size:1.1rem}.print-db-notes{font-size:var(--font-size-sm);white-space:pre-wrap;margin:0;line-height:1.55}.print-section-title{font-size:var(--font-size-base);margin:0 0 var(--space-xs);font-weight:700}.print-detail-notes p{font-size:var(--font-size-sm);margin:0;line-height:1.55}.print-form{gap:var(--space-md);flex-direction:column;display:flex}.print-form-actions{gap:var(--space-sm);padding-bottom:var(--space-lg);display:flex}.rating-fieldset{border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-sm) var(--space-md)}.rating-fieldset legend{font-size:var(--font-size-sm);padding:0 var(--space-xs);color:var(--color-text-muted);font-weight:600}.rating-buttons{gap:var(--space-sm);padding-top:var(--space-xs);display:flex}.rating-label{cursor:pointer;align-items:center;display:flex}.rating-label input[type=radio]{opacity:0;width:0;height:0;position:absolute}.rating-star{color:var(--color-border);transition:color var(--transition-fast);font-size:1.75rem;line-height:1}.rating-label:hover .rating-star,.rating-label input:checked~.rating-star{color:var(--color-accent)}.card-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);gap:var(--space-md);flex-direction:column;display:flex}.mode-toggle-group{border:1px solid var(--color-border);border-radius:var(--radius);display:flex;overflow:hidden}.mode-toggle{padding:var(--space-xs) var(--space-sm);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;font-size:var(--font-size-sm);transition:background var(--transition-fast), color var(--transition-fast);border:none;flex:1;font-weight:600}.mode-toggle.active{background:var(--color-accent);color:var(--color-accent-text)}.teststrip-results-header{justify-content:space-between;align-items:center;display:flex}.teststrip-results-header h2{font-size:var(--font-size-lg);align-items:center;gap:var(--space-sm);margin:0;display:flex}.mode-badge{font-size:var(--font-size-xs);border-radius:var(--radius-sm);background:color-mix(in srgb, var(--color-accent) 15%, transparent);color:var(--color-accent);border:1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);letter-spacing:.04em;text-transform:uppercase;padding:.125rem .5rem;font-weight:700}.teststrip-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.teststrip-table th{text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border);font-weight:700}.teststrip-table td{padding:var(--space-xs) var(--space-sm);border-bottom:1px solid var(--color-border);font-family:var(--font-mono)}.teststrip-table tr:last-child td{border-bottom:none}.strip-num{color:var(--color-text-muted)}.strip-exp{color:var(--color-text);font-weight:600}.strip-cum{color:var(--color-accent);font-weight:700}.enlarger-timer-body{gap:var(--space-md);flex-direction:column;align-items:center;display:flex}.strip-mode-banner{align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));border:1px solid color-mix(in srgb, var(--color-accent) 40%, transparent);border-radius:var(--radius);font-size:var(--font-size-sm);color:var(--color-accent);font-weight:600;display:flex}.strip-mode-banner .material-symbols-outlined{font-size:1.1rem}.strip-mode-banner .btn-sm{margin-left:auto}.strip-progress-info{font-size:var(--font-size-sm);color:var(--color-text-muted);font-family:var(--font-mono);text-align:center}.exposure-input-row{align-items:flex-end;gap:var(--space-sm);width:100%;display:flex}.exposure-input-row label{gap:var(--space-xs);font-size:var(--font-size-sm);flex-direction:column;flex:1;font-weight:600;display:flex}.interval-status{padding:var(--space-sm) var(--space-md);background:color-mix(in srgb, var(--color-accent) 10%, var(--color-surface));border:1px solid var(--color-accent);border-radius:var(--radius);font-size:var(--font-size-sm);color:var(--color-accent);text-align:center;width:100%;font-weight:600}.empty-state{padding:var(--space-2xl) var(--space-md);align-items:center;gap:var(--space-sm);color:var(--color-text-muted);text-align:center;flex-direction:column;display:flex}.empty-icon{opacity:.4;font-size:3rem}.empty-state p{font-size:var(--font-size-sm);max-width:20rem;line-height:1.5}.empty-message{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--space-lg)}.form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}@media (max-width:400px){.form-row{grid-template-columns:1fr}}@media (max-width:390px){.darkroom-quick-nav{gap:var(--space-xs)}.darkroom-nav-btn{padding:var(--space-sm) var(--space-xs);font-size:var(--font-size-xs)}.darkroom-filter-bar{gap:var(--space-sm);flex-direction:column}.print-card-paper{font-size:var(--font-size-sm)}}.page-analytics{flex-direction:column;height:100%;display:flex;overflow:hidden}.analytics-content{padding:var(--space-md);padding-bottom:calc(var(--space-xl) + env(safe-area-inset-bottom));flex:1;overflow-y:auto}.analytics-tab-bar{border-bottom:1px solid var(--color-border);background:var(--color-surface);scrollbar-width:none;flex-shrink:0;display:flex;overflow-x:auto}.analytics-tab-bar::-webkit-scrollbar{display:none}.analytics-tab{padding:var(--space-sm) var(--space-md);color:var(--color-text-muted);white-space:nowrap;border-bottom:2px solid #0000;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:64px;font-size:.72rem;font-weight:500;text-decoration:none;transition:color .15s,border-color .15s;display:flex}.analytics-tab .material-symbols-outlined{font-size:1.25rem}.analytics-tab--active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.analytics-stats{gap:var(--space-lg);flex-direction:column;display:flex}.analytics-empty{color:var(--color-text-muted);text-align:center;padding:var(--space-xl) var(--space-md);font-size:.9rem}.analytics-chart-block{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-md)}.analytics-chart-title{text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-sm);font-size:.8rem;font-weight:600}.analytics-no-data{color:var(--color-text-muted);font-size:.85rem;font-style:italic}.analytics-bar-chart{flex-direction:column;gap:6px;display:flex}.analytics-bar-row{align-items:center;gap:var(--space-sm);grid-template-columns:6rem 1fr 2.5rem;display:grid}.analytics-bar-label{color:var(--color-text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;overflow:hidden}.analytics-bar-track{background:var(--color-border);border-radius:6px;height:12px;overflow:hidden}.analytics-bar-fill{background:var(--color-accent);border-radius:6px;min-width:2px;height:100%;transition:width .4s}.analytics-bar-value{color:var(--color-text);text-align:right;font-size:.75rem;font-weight:600}.analytics-ranked-list{counter-reset:ranked;flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.analytics-ranked-item{counter-increment:ranked;align-items:center;gap:var(--space-sm);border-radius:var(--radius-sm);background:var(--color-bg);padding:6px 8px;display:flex}.analytics-ranked-item:before{content:counter(ranked);color:var(--color-text-muted);text-align:center;min-width:1.2rem;font-size:.7rem;font-weight:700}.analytics-ranked-name{text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.85rem;overflow:hidden}.analytics-ranked-badge{background:var(--color-accent);color:#fff;text-align:center;border-radius:999px;min-width:1.6rem;padding:2px 7px;font-size:.7rem;font-weight:700}.analytics-cost{gap:var(--space-lg);flex-direction:column;display:flex}.cost-summary-cards{gap:var(--space-sm);grid-template-columns:repeat(3,1fr);display:grid}.cost-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);flex-direction:column;align-items:center;gap:2px;display:flex}.cost-card-total{border-color:var(--color-accent)}.cost-card-label{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:.7rem;font-weight:600}.cost-card-value{color:var(--color-text);font-size:1.1rem;font-weight:700}.cost-card-total .cost-card-value{color:var(--color-accent)}.cost-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-md);overflow-x:auto}.cost-table{border-collapse:collapse;width:100%;font-size:.82rem}.cost-table th,.cost-table td{text-align:left;border-bottom:1px solid var(--color-border);padding:8px 10px}.cost-table thead{background:var(--color-surface)}.cost-table tbody tr:last-child td{border-bottom:none}.cost-table tbody tr:nth-child(2n){background:var(--color-bg)}.cost-sort-btn{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:.82rem;font-weight:600;-webkit-text-decoration:underline dashed;text-decoration:underline dashed}.cost-sort-btn.active{color:var(--color-accent);text-decoration:underline}.cost-roll-link{color:var(--color-accent);text-decoration:none}.cost-roll-link:hover{text-decoration:underline}.analytics-map{gap:var(--space-md);flex-direction:column;display:flex}.map-filter-bar{gap:var(--space-sm);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);flex-wrap:wrap;align-items:flex-end;display:flex}.map-filter-item{color:var(--color-text-muted);flex-direction:column;gap:2px;font-size:.75rem;font-weight:600;display:flex}.map-filter-select,.map-filter-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);appearance:none;padding:4px 8px;font-size:.82rem}.map-container{border-radius:var(--radius-md);border:1px solid var(--color-border);height:60vh;min-height:300px;position:relative;overflow:hidden}.map-shot-count{color:var(--color-text-muted);text-align:center;font-size:.82rem}.map-offline-msg{justify-content:center;align-items:center;gap:var(--space-sm);height:100%;color:var(--color-text-muted);flex-direction:column;display:flex}.map-offline-msg .material-symbols-outlined{font-size:3rem}.map-popup{font-size:.82rem;line-height:1.5}.map-popup a{color:var(--color-accent);font-weight:600;text-decoration:none}.analytics-timeline{gap:var(--space-lg);flex-direction:column;display:flex}.timeline-month{gap:var(--space-sm);flex-direction:column;display:flex}.timeline-month-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);padding-bottom:4px;font-size:.75rem;font-weight:700}.timeline-list{flex-direction:column;gap:0;margin:0;padding:0;list-style:none;display:flex}.timeline-event{gap:var(--space-md);display:flex;position:relative}.timeline-icon-wrap{flex-direction:column;flex-shrink:0;align-items:center;width:28px;display:flex}.timeline-icon{font-variation-settings:"FILL" 1;z-index:1;background:var(--color-bg);border-radius:50%;font-size:1.25rem}.timeline-event--created .timeline-icon{color:var(--color-text-muted)}.timeline-event--loaded .timeline-icon{color:#4a90e2}.timeline-event--first_shot .timeline-icon{color:#27ae60}.timeline-event--last_shot .timeline-icon{color:var(--color-accent)}.timeline-event--archived .timeline-icon{color:#8e44ad}.timeline-line{background:var(--color-border);flex:1;width:2px;margin-top:4px}.timeline-list li:last-child .timeline-line{display:none}.timeline-content{padding-bottom:var(--space-md);flex:1;min-width:0}.timeline-header{justify-content:space-between;align-items:baseline;gap:var(--space-sm);margin-bottom:2px;display:flex}.timeline-type{text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);font-size:.72rem;font-weight:700}.timeline-date{color:var(--color-text-muted);white-space:nowrap;font-size:.72rem}.timeline-roll-link{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;text-decoration:none;display:block;overflow:hidden}.timeline-roll-link:hover{color:var(--color-accent)}.timeline-detail{color:var(--color-text-muted);margin:0;font-size:.78rem}@media (max-width:420px){.cost-summary-cards{grid-template-columns:repeat(2,1fr)}.analytics-bar-row{grid-template-columns:5rem 1fr 2rem}.map-filter-bar{flex-direction:column;align-items:stretch}.map-filter-apply{width:100%}}.reference-index-list{gap:var(--space-sm);flex-direction:column;display:flex}.reference-index-item{align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);color:var(--color-text);-webkit-tap-highlight-color:transparent;text-decoration:none;transition:background .15s,border-color .15s;display:flex}.reference-index-item:active,.reference-index-item:hover{background:var(--color-surface-raised,var(--color-surface));border-color:var(--color-accent)}.reference-index-icon{color:var(--color-accent);flex-shrink:0;font-size:1.6rem}.reference-index-info{flex-direction:column;flex:1;gap:.125rem;min-width:0;display:flex}.reference-index-title{font-weight:600;font-size:var(--font-size-base)}.reference-index-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.reference-index-arrow{color:var(--color-text-muted);flex-shrink:0;font-size:1.2rem}.reference-intro{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-md);line-height:1.6}.reference-category-heading{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin:var(--space-md) 0 var(--space-xs);font-weight:700}.reference-category-heading:first-child{margin-top:0}.reference-search-wrap{margin-bottom:var(--space-md);position:relative}.reference-search-icon{left:var(--space-sm);color:var(--color-text-muted);pointer-events:none;font-size:1.1rem;position:absolute;top:50%;transform:translateY(-50%)}.reference-search{box-sizing:border-box;width:100%;padding:var(--space-sm) var(--space-sm) var(--space-sm) 2.25rem;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-base)}.reference-search::placeholder{color:var(--color-text-muted)}.reference-search:focus{outline:2px solid var(--color-accent);outline-offset:1px;border-color:var(--color-accent)}.reference-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;padding:var(--space-xl) 0}.reference-body p{margin:0 0 var(--space-sm);color:var(--color-text);font-size:var(--font-size-sm);line-height:1.6}.reference-body p:last-child{margin-bottom:0}.reference-table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm);margin:var(--space-sm) 0}.reference-table th,.reference-table td{padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);text-align:left}.reference-table th{background:var(--color-bg);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.reference-table td{color:var(--color-text)}.zone-gradient-strip{border-radius:var(--radius);margin-bottom:var(--space-md);grid-template-columns:repeat(11,1fr);gap:2px;display:grid;overflow:hidden}.zone-strip-btn{all:unset;padding-bottom:var(--space-xs);aspect-ratio:1/2;cursor:pointer;-webkit-tap-highlight-color:transparent;justify-content:center;align-items:flex-end;transition:transform .1s,box-shadow .1s;display:flex;position:relative}.zone-strip-btn:active{transform:scaleY(.95)}.zone-strip-btn--active{box-shadow:0 0 0 2px var(--color-accent) inset}.zone-strip-num{letter-spacing:.02em;font-variant-numeric:tabular-nums;font-size:.6rem;font-weight:700;line-height:1}.zone-detail-panel{gap:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:3rem 1fr;animation:.15s fadeIn;display:grid}.zone-detail-panel[hidden]{display:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.zone-detail-swatch{border-radius:var(--radius-sm);border:1px solid var(--color-border);flex-shrink:0;width:3rem;height:3rem}.zone-detail-body{min-width:0}.zone-detail-title{font-size:var(--font-size-base);margin:0 0 var(--space-xs);color:var(--color-text);font-weight:700}.zone-detail-desc{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:0 0 var(--space-sm);line-height:1.5}.zone-detail-body h4{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin:var(--space-sm) 0 var(--space-xs);font-size:.7rem;font-weight:700}.zone-detail-subjects{margin:0 0 var(--space-sm);flex-direction:column;gap:.2rem;padding-left:1.1rem;display:flex}.zone-detail-subjects li,.zone-detail-metering{font-size:var(--font-size-sm);color:var(--color-text);line-height:1.5}.zone-detail-metering{margin:0}.beginner-progress{align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);display:flex}.beginner-step-count{font-size:var(--font-size-sm);color:var(--color-text-muted);white-space:nowrap;font-variant-numeric:tabular-nums}.beginner-progress-bar{background:var(--color-border);border-radius:2px;flex:1;height:4px;overflow:hidden}.beginner-progress-fill{background:var(--color-accent);border-radius:2px;height:100%;transition:width .3s}.beginner-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);margin-bottom:var(--space-md);overflow:hidden}.beginner-card-header{align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-bg);display:flex}.beginner-card-icon{color:var(--color-accent);flex-shrink:0;font-size:1.4rem}.beginner-card-heading{font-size:var(--font-size-base);color:var(--color-text);margin:0;font-weight:700}.beginner-card-body{padding:var(--space-md)}.beginner-tip{gap:var(--space-sm);background:color-mix(in srgb, var(--color-accent) 8%, transparent);border-left:3px solid var(--color-accent);padding:var(--space-sm) var(--space-md);align-items:flex-start;display:flex}.beginner-tip-icon{color:var(--color-accent);flex-shrink:0;margin-top:.1rem;font-size:1.1rem}.beginner-tip p{font-size:var(--font-size-sm);color:var(--color-text);margin:0;line-height:1.5}.beginner-nav{justify-content:space-between;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xl);display:flex}.beginner-dots{align-items:center;gap:.4rem;display:flex}.beginner-dot{background:var(--color-border);border-radius:50%;width:6px;height:6px;transition:background .2s}.beginner-dot--active{background:var(--color-accent)}.btn{align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius);font-size:var(--font-size-sm);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;font-weight:600;transition:opacity .15s;display:inline-flex}.btn:disabled{opacity:.35;cursor:not-allowed}.btn .material-symbols-outlined{font-size:1rem}.btn-primary{background:var(--color-accent);color:var(--color-accent-text)}.btn-primary:not(:disabled):active,.btn-primary:not(:disabled):hover{opacity:.85}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:not(:disabled):active,.btn-secondary:not(:disabled):hover{border-color:var(--color-accent);color:var(--color-accent)}@media (max-width:390px){.zone-gradient-strip{gap:1px}.zone-strip-num{font-size:.5rem}.zone-detail-panel{grid-template-columns:2.5rem 1fr}.zone-detail-swatch{width:2.5rem;height:2.5rem}.beginner-nav{gap:var(--space-xs)}.btn{padding:var(--space-xs) var(--space-sm)}}
