#root{min-height:100vh}.home-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-lg);text-align:center}.home-hero h1{font-size:2.2rem;margin-top:var(--space-md)}.home-tagline{color:var(--ink-muted);font-style:italic}.home-mark-box{width:56px;height:56px;display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent}.home-mark-icon{width:26px;height:26px;color:var(--ink)}.home-card{width:min(520px,92vw);border:2px solid var(--ink);background:#f9f5ef;padding:var(--space-xl);box-shadow:var(--shadow-soft);display:flex;flex-direction:column;gap:var(--space-md);text-align:center;position:relative}.home-card-accent{display:none}.home-card h2{font-size:1.2rem}.home-card-sub{color:var(--ink-muted)}.home-actions{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-lg);align-items:stretch}.home-btn{display:inline-flex;align-items:center;justify-content:center;background:#2b2723;color:#f6f1ea;padding:12px 16px;border-radius:6px;border:1px solid #2b2723;text-transform:none;letter-spacing:.5px}.home-link{color:var(--ink-muted);font-size:.9rem;text-align:center;text-decoration:underline}.home-quote{color:var(--ink-muted);font-size:.85rem;font-style:italic;max-width:520px}.roll-card{display:block;padding:var(--space-md);border:1px solid var(--border);border-radius:0;background:var(--card);color:inherit;box-shadow:var(--shadow-card)}.roll-card:hover{border-color:var(--border-strong)}.roll-card-top{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.roll-title{font-size:1.1rem;margin-bottom:4px}.roll-sub{font-size:.85rem;color:var(--ink-muted)}.roll-notes{font-size:.8rem;color:var(--ink-faint);margin-top:6px}.status-pill{padding:4px 10px;border-radius:var(--radius-pill);font-size:.7rem;border:2px solid var(--border-strong);white-space:nowrap;font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px;background:transparent}.rolls-page{display:flex;flex-direction:column;gap:var(--space-lg)}.rolls-header{display:flex;align-items:center;justify-content:space-between}.rolls-title{display:flex;align-items:center;gap:var(--space-md)}.rolls-accent{width:2px;height:48px;background:#d7a3a0;border-radius:var(--radius-pill)}.rolls-sub{color:var(--ink-muted);font-size:.9rem;display:flex;align-items:center;gap:8px}.rolls-emoji{display:inline-flex;color:var(--ink-muted)}.rolls-emoji svg{width:18px;height:18px;display:block}.primary-btn{display:inline-flex;align-items:center;gap:6px;background:#1f1b18;border-color:#1f1b18;color:#f6f1ea;border-radius:8px;padding:10px 18px;font-size:.85rem;box-shadow:var(--shadow-card);width:auto;flex:0 0 auto}.rolls-page .primary-btn{background:#1f1b18;border-color:#1f1b18;color:#f6f1ea;border-radius:8px}.rolls-tabs{display:inline-flex;border:1px solid var(--border);border-radius:0;background:#f8f2ea;padding:4px;width:fit-content;gap:4px}.tab{background:transparent;border:none;padding:6px 12px;border-radius:0;font-size:.85rem;color:var(--ink-muted);box-shadow:none;transform:none}.tab:hover{transform:none;box-shadow:none}.tab.active{background:var(--accent-ink);color:#f6f1ea}.rolls-list{display:flex;flex-direction:column;gap:var(--space-md)}.rolls-empty{color:var(--ink-muted)}.create-roll-page{min-height:calc(100vh - 120px);display:flex;align-items:center;justify-content:center;padding:var(--space-xl) var(--space-lg)}.create-roll-card{position:relative;width:min(560px,92vw);background:var(--card);border:2px solid var(--border-strong);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-soft)}.create-roll-close{position:absolute;top:16px;right:16px;background:transparent;border:none;font-size:1.2rem;padding:0;border-radius:0;color:var(--ink);box-shadow:none;transform:none}.create-roll-close:hover{box-shadow:none;transform:none}.create-roll-sub{color:var(--ink-muted);margin-bottom:var(--space-lg)}.create-roll-fields{display:flex;flex-direction:column;gap:var(--space-md)}.create-roll-fields label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--ink)}.create-roll-error{color:#a0432c;margin-top:var(--space-sm)}.create-roll-submit{margin-top:var(--space-lg);width:100%;text-align:center;display:inline-flex;align-items:center;justify-content:center;background:#7f7770;border-color:#7f7770;color:#f6f1ea;border-radius:var(--radius-md);padding:10px 16px;font-size:.9rem}.frame-form{display:flex;align-items:center;gap:var(--space-md)}.modal-backdrop{position:fixed;inset:0;background:#25211e99;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);width:min(520px,92vw);box-shadow:var(--shadow-soft)}.modal-card h2{margin-bottom:var(--space-sm)}.modal-sub{color:var(--ink-muted);font-size:.9rem;margin-bottom:var(--space-lg)}.modal-close{position:absolute;top:12px;right:20px;background:transparent;border:none;font-size:1.2rem;width:auto;height:auto;border-radius:0;padding:0;display:inline-flex;align-items:center;justify-content:center;color:var(--ink);box-shadow:none;transform:none}.modal-close:hover{box-shadow:none;transform:none}.modal-form{display:flex;flex-direction:column;gap:var(--space-md)}.modal-form .primary-btn{width:100%;text-align:center;display:inline-flex;align-items:center;justify-content:center;background:#7f7770;border-color:#7f7770;color:#f6f1ea;padding:10px 16px;border-radius:var(--radius-md)}.modal-form label{display:flex;flex-direction:column;gap:6px;font-size:.85rem;color:var(--ink);font-weight:400}.frame-list{display:grid;gap:var(--space-md)}.frame-card{border:2px solid var(--border-strong);background:var(--card);border-radius:0;padding:var(--space-md);box-shadow:none}.frame-card-row{display:flex;align-items:center;gap:var(--space-md)}.frame-card-number{width:48px;height:48px;border:2px solid var(--border-strong);display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1rem}.frame-card-divider{width:2px;height:36px;background:var(--accent-rose)}.frame-card-info{display:flex;flex-wrap:wrap;gap:var(--space-sm);align-items:center}.frame-pill{border:1px solid var(--border);padding:4px 10px;font-size:.8rem;background:#f7f2ec}.frame-card-note{margin-top:var(--space-sm);color:var(--ink-muted);font-size:.85rem;font-style:italic}.frame-grid{display:flex;flex-wrap:wrap;gap:10px;align-items:stretch}.frame-tile{border:2px solid var(--border-strong);background:var(--card);border-radius:0;padding:8px 10px;text-align:center;box-shadow:none;display:flex;flex-direction:column;flex:0 0 auto;box-sizing:border-box}.frame-tile.is-selectable{cursor:pointer}.frame-tile.is-selected{border-color:var(--ink)}.frame-tile.review-underexposed{border-color:#8aa1d8;background:#f2f5ff}.frame-tile.review-overexposed{border-color:#d7a3a0;background:#fff3ee}.frame-tile.review-well-exposed{border-color:#7eb599;background:#f1f7f3}.frame-tile-number{font-family:var(--font-display);font-size:.95rem;margin-bottom:4px}.frame-tile-info{font-size:.75rem;color:var(--ink-muted);display:grid;gap:4px;text-align:left}.frame-row{display:flex;justify-content:space-between;gap:var(--space-sm)}.frame-label{color:var(--ink-faint);text-transform:none;font-size:.7rem;letter-spacing:0}.frame-label-iso{text-transform:uppercase;letter-spacing:.6px}.frame-row span:last-child{color:var(--ink)}.frame-note-row{align-items:flex-start}.frame-note-row span:last-child{text-align:right;margin-left:auto;max-width:60%;white-space:normal;word-break:break-word;flex:1}.frame-review{margin-top:auto;font-size:.8rem;color:var(--ink);font-family:var(--font-display);letter-spacing:.5px}.frame-review.underexposed{color:#2c5aa0}.frame-review.overexposed{color:#a0432c}.frame-review.well-exposed{color:#2f6b4a}.empty-state{border:1px dashed var(--border);border-radius:var(--radius-md);padding:var(--space-2xl);text-align:center;background:#f8f3ec}.empty-icon{width:42px;height:32px;margin:0 auto var(--space-sm);border:1px solid var(--border);border-radius:4px;position:relative}.empty-icon:after{content:"";width:10px;height:10px;border:1px solid var(--border);border-radius:50%;position:absolute;top:8px;left:15px}.empty-title{font-size:1rem;margin-bottom:6px}.empty-sub{color:var(--ink-muted);font-size:.85rem}.roll-detail{display:flex;flex-direction:column;gap:var(--space-xl)}.roll-detail-header{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:var(--space-md);border-bottom:1px solid var(--border);padding-bottom:var(--space-md)}.back-button{border:1px solid var(--border);border-radius:var(--radius-md);padding:8px 10px;background:#faf6f1;font-size:.9rem}.roll-detail-title h1{font-size:1.8rem;margin-bottom:4px}.roll-meta-line{color:var(--ink-muted);font-size:.85rem}.roll-detail-actions{display:flex;align-items:center;gap:var(--space-sm)}.status-pill{padding:4px 10px;border-radius:var(--radius-pill);font-size:.7rem;border:2px solid var(--border-strong);background:transparent;white-space:nowrap;font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px}.status-pill.in_progress{color:var(--ink);border-color:var(--ink-muted)}.status-pill.developed{color:var(--accent-green);border-color:var(--accent-green)}.ghost-btn{background:transparent;color:var(--ink);border:1px solid var(--border);padding:8px 12px;border-radius:var(--radius-pill);font-size:.8rem}.outline-btn{border:2px solid var(--ink-muted);border-radius:var(--radius-pill);font-family:var(--font-display);text-transform:uppercase;letter-spacing:1px}.outline-btn-success{border-color:var(--accent-green);color:var(--accent-green)}.section-title{font-family:var(--font-display);font-size:1rem;letter-spacing:1px;text-transform:uppercase;color:var(--ink-muted);margin-bottom:var(--space-md)}.roll-shooting,.roll-review{display:flex;flex-direction:column;gap:var(--space-lg)}.shooting-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}.review-header{display:flex;align-items:center;gap:var(--space-md)}.review-toggle{display:inline-flex;align-items:center;gap:8px;background:var(--accent-ink);color:#f6f1ea;border-radius:4px;padding:8px 14px;font-size:.85rem;letter-spacing:0;text-transform:none;box-shadow:var(--shadow-card)}.review-eye-icon{width:20px;height:20px;display:block}.review-panel{margin-top:var(--space-lg);border-top:1px solid var(--border);padding-top:var(--space-lg)}.review-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.review-panel-title{font-family:var(--font-display);font-size:1rem}.review-panel-close{background:transparent;border:none;color:var(--ink);font-size:.85rem;letter-spacing:.5px;text-transform:uppercase;box-shadow:none;transform:none}.review-panel-close:hover{box-shadow:none;transform:none}.review-panel-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-lg)}.review-panel-meta .frame-pill{border:1px solid var(--border);padding:4px 10px;font-size:.8rem;background:#f7f2ec}.review-panel-meta .frame-note{color:var(--ink-muted);font-style:italic;font-size:.85rem;margin-left:auto}.review-panel-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-md)}.review-action{border:2px solid var(--border-strong);background:#f7f2ec;color:var(--ink);padding:10px 14px;font-size:.85rem;border-radius:4px;display:inline-flex;flex-direction:column;align-items:center;gap:6px}.review-action:hover{transform:none;box-shadow:none}.review-action.is-active{border-color:var(--ink);background:#efe8dd}.review-action.is-active.is-under{border-color:#8aa1d8;background:#f2f5ff}.review-action.is-active.is-good{border-color:#7eb599;background:#f1f7f3}.review-action.is-active.is-over{border-color:#d7a3a0;background:#fff3ee}.review-action .review-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center}.top-nav{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border);background:#f7f2eccc;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.brand{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-display);font-size:1.1rem}.brand-mark{width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;position:relative;border:none;background:transparent}.brand-mark svg{width:20px;height:20px}.brand-title{letter-spacing:.5px}.nav-links{display:flex;gap:var(--space-md);align-items:center}.nav-links a{color:var(--ink);font-size:.95rem}.nav-button{background:var(--accent-ink);color:#f6f1ea;border-radius:var(--radius-pill);padding:8px 14px;font-size:.85rem}.nav-user{display:flex;align-items:center;gap:var(--space-md);font-size:.85rem;color:var(--ink-muted)}.user-chip{padding:0;border:none;border-radius:0;background:transparent;font-family:var(--font-body);text-transform:none;letter-spacing:.2px;color:var(--ink-muted);font-size:.72rem;font-style:italic}.icon-link{color:var(--ink);border:1px solid var(--border);padding:6px 10px;border-radius:var(--radius-pill);background:#faf6f1}.page-content{max-width:980px;margin:0 auto;padding:var(--space-2xl) var(--space-lg) var(--space-2xl)}:root{--font-display: "Special Elite", "Courier New", monospace;--font-body: "Courier Prime", "Courier New", monospace;--font-ui: "Courier Prime", "Courier New", monospace;--paper: #f7f2ec;--paper-2: #f3ede4;--paper-3: #efe7dd;--card: #f9f5ef;--ink: #2b2723;--ink-muted: #6b6157;--ink-faint: #9a9086;--accent-rose: #d7a3a0;--accent-green: #4a8f73;--accent-ink: #2b2723;--border: #c9c0b6;--border-strong: #b6ada3;--shadow-soft: 0 10px 30px rgba(43, 39, 35, .08);--shadow-card: 0 6px 18px rgba(43, 39, 35, .08);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-pill: 999px}@font-face{font-family:Special Elite;src:url(/fonts/SpecialElite-Regular.woff2) format("woff2"),url(/fonts/SpecialElite-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Courier Prime;src:url(/fonts/CourierPrime-Regular.woff2) format("woff2"),url(/fonts/CourierPrime-Regular.woff) format("woff");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Courier Prime;src:url(/fonts/CourierPrime-Bold.woff2) format("woff2"),url(/fonts/CourierPrime-Bold.woff) format("woff");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Courier Prime;src:url(/fonts/CourierPrime-Italic.woff2) format("woff2"),url(/fonts/CourierPrime-Italic.woff) format("woff");font-weight:400;font-style:italic;font-display:swap}:root{font-family:var(--font-body);line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--ink)}*{box-sizing:border-box}body{margin:0;background-color:var(--paper);color:var(--ink)}a{color:inherit;text-decoration:none}a:hover{text-decoration:none}button,input,select,textarea{font-family:var(--font-body);color:var(--ink)}button{background:var(--accent-ink);color:#f6f1ea;border:1px solid var(--accent-ink);padding:8px 16px;border-radius:var(--radius-pill);cursor:pointer;transition:transform .15s ease,box-shadow .15s ease}.primary-btn,.nav-button{color:#f6f1ea}button:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}button:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}input,select,textarea{width:100%;background:#f7f2ec;border:1px solid var(--border);padding:10px 12px;border-radius:var(--radius-md);font-size:.95rem}textarea{min-height:100px;resize:vertical}h1,h2,h3{font-family:var(--font-display);margin:0 0 var(--space-sm) 0}p{margin:0}
