:root{color-scheme:dark;--bg:#0f0f10;--surface:#1a1a1a;--surface-2:#242424;--text:#f2f2f2;--muted:#9a9a9a;--accent:#e8e8e8;--error:#ff6b6b;--ok:#6bff9e;--border:#222}*{box-sizing:border-box}body,html{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,sans-serif}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.site-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap}.site-header h1{margin:0;font-size:1.1rem;font-weight:500;letter-spacing:.04em}.site-nav{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;align-items:center}.site-nav a{font-size:.9rem}.nav-dashboard{color:var(--muted)}.nav-dashboard:hover{color:var(--accent)}.gallery-grid{column-count:1;column-gap:.75rem;padding:.75rem 1rem 2rem}@media (min-width:640px){.gallery-grid{column-count:2}}@media (min-width:1024px){.gallery-grid{column-count:3}}@media (min-width:1400px){.gallery-grid{column-count:4}}.gallery-card{position:relative;display:block;width:100%;margin:0 0 .75rem;padding:0;border:none;border-radius:4px;overflow:hidden;cursor:pointer;background:var(--surface);page-break-inside:avoid;break-inside:avoid;transition:transform .2s ease,box-shadow .2s ease}.gallery-card:focus-visible,.gallery-card:hover{transform:scale(1.01);box-shadow:0 8px 24px rgb(0 0 0/35%);outline:2px solid #555;outline-offset:2px}.gallery-card-image{display:block;width:100%;height:auto;vertical-align:middle;background:var(--surface)}.gallery-card-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;padding:1rem;background:linear-gradient(0deg,rgb(0 0 0/55%),transparent 50%);opacity:0;transition:opacity .2s ease;pointer-events:none}.gallery-card:focus-visible .gallery-card-overlay,.gallery-card:hover .gallery-card-overlay{opacity:1}.gallery-card-label{font-size:.85rem;color:#f2f2f2;text-shadow:0 1px 2px rgb(0 0 0/50%)}.gallery-count{margin:.35rem 0 0;font-size:.9rem;color:var(--muted)}.gallery-skeleton{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:.75rem;gap:.75rem;padding:.75rem 1rem 2rem}.gallery-skeleton-item{background:linear-gradient(90deg,var(--surface) 0,var(--surface-2) 50%,var(--surface) 100%);background-size:200% 100%}.gallery-skeleton-item,.gallery-title-skeleton{border-radius:4px;animation:gallery-shimmer 1.4s ease infinite}.gallery-title-skeleton{width:12rem;height:1.5rem;background:var(--surface)}@keyframes gallery-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gallery-retry{margin-top:1rem}.lightbox{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;background:rgb(0 0 0/92%);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lightbox-toolbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;color:#ccc;flex-shrink:0}.lightbox-counter{font-size:.85rem;color:var(--muted)}.lightbox-close{width:2.5rem;height:2.5rem;border:none;border-radius:6px;background:rgb(255 255 255/8%);color:var(--text);font-size:1.5rem;line-height:1;cursor:pointer;transition:background .15s}.lightbox-close:hover{background:rgb(255 255 255/15%)}.lightbox-stage{position:relative;flex:1 1;display:flex;align-items:center;justify-content:center;min-height:0;padding:0 3rem 1.5rem}.lightbox-figure{margin:0;max-width:min(100%,1400px);max-height:100%;display:flex;flex-direction:column;align-items:center}.lightbox-image{max-width:100%;max-height:calc(100vh - 8rem);width:auto;height:auto;object-fit:contain}.lightbox-caption{margin-top:.75rem;font-size:.9rem;color:var(--muted);text-align:center}.lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:2.75rem;height:2.75rem;border:none;border-radius:50%;background:rgb(255 255 255/10%);color:var(--text);font-size:1.75rem;line-height:1;cursor:pointer;transition:background .15s}.lightbox-nav:hover{background:rgb(255 255 255/20%)}.lightbox-nav-prev{left:.75rem}.lightbox-nav-next{right:.75rem}@media (max-width:640px){.lightbox-stage{padding:0 .5rem 1rem}.lightbox-nav{width:2.25rem;height:2.25rem;font-size:1.5rem}.lightbox-nav-prev{left:.25rem}.lightbox-nav-next{right:.25rem}}.gallery-empty{padding:3rem 1.5rem;text-align:center;color:var(--muted)}.gallery-main{min-height:60vh}.gallery-title{padding:1.5rem 1.5rem .5rem}.gallery-title h2{margin:0;font-size:1.5rem;font-weight:500}.home-main{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.home-hero h2{margin:0 0 .35rem;font-size:1.75rem;font-weight:500}.home-subtitle{color:var(--muted);margin:0 0 2rem}.project-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));grid-gap:1rem;gap:1rem}.project-grid.compact{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));margin-top:1rem}.project-card{display:flex;flex-direction:column;gap:.35rem;padding:1.25rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);transition:border-color .15s}.project-card:hover{border-color:#444;text-decoration:none}.project-card-name{font-weight:500}.project-card-slug,.project-slug{font-size:.8rem;color:var(--muted)}.empty-state{padding:3rem 1.5rem;text-align:center;color:var(--muted)}.empty-state h2{color:var(--text);margin:0 0 .5rem}.dashboard-auth,.upload-main{max-width:28rem;margin:2rem auto;padding:0 1.5rem}.dashboard-auth h1,.upload-main h1{font-size:1.25rem;font-weight:500;margin:0 0 .5rem}.upload-hint{color:var(--muted);font-size:.9rem;margin:0 0 1.5rem}.project-form label,.upload-form label{display:block;font-size:.85rem;margin-bottom:.35rem;color:var(--muted)}.project-form input,.upload-form input[type=file],.upload-form input[type=password]{width:100%;margin-bottom:1rem;padding:.6rem .75rem;border:1px solid #333;border-radius:6px;background:var(--surface);color:var(--text)}.project-form button,.upload-form button{width:100%;padding:.75rem;border:none;border-radius:6px;background:var(--accent);color:#111;font-weight:600;cursor:pointer}.project-form button:disabled,.upload-form button:disabled{opacity:.5;cursor:not-allowed}.status{margin-top:1rem;font-size:.9rem;min-height:1.25rem}.status-error{color:var(--error)}.status-ok{color:var(--ok)}.back-link{display:inline-block;padding:1.25rem 1.5rem;color:var(--muted);font-size:.85rem}.back-link.inline{padding:0 0 .5rem}.back-link:hover{color:var(--accent)}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.5rem .75rem;border-bottom:1px solid var(--border)}.header-actions{display:flex;gap:.5rem}.draft-bar.global{margin:0;border-radius:0;border-left:none;border-right:none;border-top:none}.status.global-status{margin:0;padding:0 1.5rem 1rem}.project-list li.state-marked-delete{opacity:.55}.project-list li.state-marked-delete .project-name{text-decoration:line-through}.project-list li.state-created{border-color:#6b5a2e}.project-list li.dirty:not(.active){border-color:#444}.legend-added{color:#f2e8c0}.legend-delete{color:var(--error)}.legend-moved{color:#9ec5ff}.dashboard-header h1{margin:0;font-size:1.25rem;font-weight:500}.btn-ghost{padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--muted);cursor:pointer}.btn-ghost:hover{color:var(--text);border-color:#444}.dashboard-main{display:grid;grid-template-columns:minmax(260px,320px) 1fr;min-height:calc(100vh - 80px)}@media (max-width:768px){.dashboard-main{grid-template-columns:1fr}}.dashboard-sidebar{border-right:1px solid var(--border);padding:1rem}.sidebar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.sidebar-head h2{margin:0;font-size:1rem;font-weight:500}.sidebar-head button{padding:.35rem .65rem;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer;font-size:.85rem}.project-form{margin-bottom:1rem;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.project-form.inline input{margin-bottom:.5rem}.inline-actions{display:flex;gap:.5rem}.inline-actions button{flex:1 1;padding:.5rem;font-size:.85rem}.project-list{list-style:none;margin:0;padding:0}.project-list li{border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;overflow:hidden}.project-list li.active{border-color:#555;background:var(--surface)}.project-select{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;width:100%;padding:.75rem;border:none;background:transparent;color:var(--text);cursor:pointer;text-align:left}.project-name{font-weight:500}.project-row-actions{display:flex;gap:.75rem;padding:0 .75rem .75rem;font-size:.8rem}.project-row-actions button{padding:0;border:none;background:none;color:var(--muted);cursor:pointer;font-size:inherit}.project-row-actions button:hover{color:var(--accent)}.btn-danger{color:var(--error)!important}.sidebar-empty{color:var(--muted);font-size:.9rem}.dashboard-content{padding:1.5rem}.content-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.content-head h2{margin:0;font-size:1.25rem;font-weight:500}.project-name-field{display:flex;flex-direction:column;gap:.35rem;flex:1 1;max-width:20rem}.project-name-field span{font-size:.85rem;color:var(--muted)}.project-name-field input{padding:.6rem .75rem;border:1px solid #333;border-radius:6px;background:var(--surface);color:var(--text)}.draft-bar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;padding:1rem 1.25rem;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.draft-bar.dirty{border-color:#6b5a2e;background:#1a1810}.draft-bar p{margin:0;font-size:.9rem;color:var(--muted);max-width:36rem}.draft-bar.dirty p{color:#d4c48a}.draft-actions{display:flex;gap:.5rem}.btn-publish{padding:.55rem 1rem;border:none;border-radius:6px;background:var(--ok);color:#0a1a10;font-weight:600;cursor:pointer}.btn-publish:disabled{opacity:.5;cursor:not-allowed}.photos-manager-toolbar{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.photos-hint{font-size:.85rem;color:var(--muted)}.photos-empty{color:var(--muted);padding:2rem 0}.photo-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.75rem}.photo-item{display:flex;align-items:center;gap:1rem;padding:.75rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);cursor:-webkit-grab;cursor:grab}.photo-item.dragging{opacity:.6;border-color:#555}.photo-order{width:1.5rem;text-align:center;color:var(--muted);font-size:.85rem}.photo-order-original{color:#9ec5ff;font-weight:600}.photo-item.state-added{border-color:#6b5a2e}.photo-item.state-reordered{border-color:#4a6a9a}.photo-item.state-marked-delete{border-color:var(--error);opacity:.85}.photo-item.state-marked-delete img{opacity:.55}.photo-badge.state-added{background:#6b5a2e;color:#f2e8c0}.photo-badge.state-reordered{background:#1a2a4a;color:#9ec5ff}.photo-badge.state-marked-delete{background:#4a1515;color:#ffb4b4}.photo-badge{font-size:.75rem;padding:.15rem .45rem;border-radius:4px}.photo-item img{width:120px;height:90px;object-fit:cover;border-radius:4px;background:var(--surface-2)}.photo-actions{display:flex;gap:.5rem;margin-left:auto}.photo-actions button{padding:.4rem .65rem;border:1px solid var(--border);border-radius:6px;background:var(--surface-2);color:var(--text);cursor:pointer;font-size:.85rem}.photo-actions button:disabled{opacity:.4;cursor:not-allowed}