:root{--background:#f7f9fc;--surface:#fff;--surface-muted:#f2f6fb;--surface-tint:#fff4f8;--text:#182033;--muted:#607086;--border:#d9e2ee;--accent:#2aa79b;--accent-strong:#0f766e;--accent-soft:#e7f8f5;--rose:#f472a5;--rose-soft:#fff1f6;--danger:#c9354d;--danger-soft:#fff1f3;--shadow:0 12px 28px #17203314}*{box-sizing:border-box}html,body{background:linear-gradient(180deg, #fbfcff 0%, var(--background) 42%, #f4f7fb 100%);min-height:100%;color:var(--text);margin:0;font-family:Arial,Hiragino Kaku Gothic ProN,Yu Gothic,Meiryo,sans-serif}button,input,textarea{font:inherit}button{border:0}a{color:inherit}.app-shell{background:0 0;min-height:100vh}.login-screen{place-items:center;min-height:100vh;padding:24px;display:grid}.login-panel{border:1px solid var(--border);background:var(--surface);width:min(100%,420px);box-shadow:var(--shadow);border-radius:8px;padding:28px}.login-title,.page-title{letter-spacing:0;margin:0}.login-title{font-size:1.6rem}.login-form{gap:14px;margin-top:24px;display:grid}.field-label{color:var(--muted);gap:8px;font-size:.92rem;font-weight:700;display:grid}.text-input{border:1px solid var(--border);background:var(--surface);width:100%;min-height:46px;color:var(--text);border-radius:8px;padding:10px 12px;box-shadow:inset 0 1px #fffc}.text-input:focus,.file-picker:focus-visible,.button:focus-visible,.icon-button:focus-visible,.album-chip:focus-visible,.album-sort-button:focus-visible,.photo-preview-button:focus-visible,.sort-button:focus-visible,.album-edit-toggle:focus-visible{outline-offset:2px;outline:3px solid #2aa79b38}.button,.icon-button{cursor:pointer;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:42px;font-weight:700;text-decoration:none;transition:background-color .14s,border-color .14s,color .14s,transform .14s;display:inline-flex}.button:disabled,.icon-button:disabled{cursor:not-allowed;opacity:.62}.button-primary{background:var(--accent);color:#fff;padding:0 16px;box-shadow:0 8px 18px #2aa79b33}.button-primary:hover:not(:disabled){background:var(--accent-strong)}.button-danger{background:var(--danger-soft);color:var(--danger);border:1px solid #c2415a3d;padding:0 12px}.button-danger:hover:not(:disabled){background:#ffe1e8}.button-secondary,.icon-button{border:1px solid var(--border);background:var(--surface);color:var(--text);box-shadow:0 5px 14px #1720330f}.button-secondary{padding:0 12px}.button-secondary:hover:not(:disabled),.icon-button:hover:not(:disabled){background:var(--surface-muted)}.icon-button{width:42px;height:42px;padding:0}.status{border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.92rem}.status-error{background:var(--danger-soft);color:var(--danger)}.status-muted{background:var(--accent-soft);color:var(--accent-strong)}.gallery-shell{gap:18px;width:min(1220px,100%);margin:0 auto;padding:30px 20px 48px;display:grid}.toolbar{justify-content:space-between;align-items:center;gap:18px;display:flex}.page-title{color:#141c2f;font-size:clamp(1.8rem,4vw,2.7rem);line-height:1}.title-group{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.role-badge{background:var(--accent-soft);color:var(--accent-strong);border:1px solid #2aa79b42;border-radius:999px;padding:5px 10px;font-size:.8rem;font-weight:700}.toolbar-actions,.upload-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.card-actions{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px;display:grid}.album-section{border:1px solid var(--border);background:#ffffffc7;border-radius:8px;gap:10px;padding:12px;display:grid;box-shadow:0 8px 20px #1720330d}.album-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.section-label{color:var(--muted);font-size:.84rem;font-weight:800}.album-sort-actions{flex-wrap:wrap;gap:6px;display:flex}.album-sort-button{border:1px solid var(--border);background:var(--surface);min-height:32px;color:var(--muted);cursor:pointer;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;padding:0 10px;font-size:.82rem;font-weight:800;display:inline-flex}.album-sort-button:hover,.album-sort-button-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#2aa79b5c}.album-strip{scrollbar-width:thin;gap:10px;padding:2px 0 4px;display:flex;overflow-x:auto}.album-chip{border:1px solid var(--border);background:var(--surface);min-width:max-content;min-height:40px;color:var(--text);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:0 12px;font-weight:700;display:inline-flex;box-shadow:0 7px 16px #1720330d}.album-chip:hover,.album-chip-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#2aa79b6b}.album-count{background:var(--rose-soft);min-width:24px;height:24px;color:var(--muted);border-radius:999px;justify-content:center;align-items:center;font-size:.78rem;display:inline-flex}.album-chip-active .album-count{background:var(--accent);color:#fff}.sort-bar{border:1px solid var(--border);background:#ffffffb8;border-radius:8px;flex-wrap:wrap;align-items:center;gap:10px;padding:10px;display:flex;box-shadow:0 8px 20px #1720330d}.sort-label{color:var(--muted);font-size:.86rem;font-weight:700}.sort-actions{flex-wrap:wrap;gap:8px;display:flex}.sort-button{border:1px solid var(--border);background:var(--surface);min-height:36px;color:var(--text);cursor:pointer;white-space:nowrap;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:0 10px;font-size:.9rem;font-weight:700;display:inline-flex}.sort-button:hover,.sort-button-active{background:var(--accent-soft);color:var(--accent-strong);border-color:#2aa79b6b}.upload-panel{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:16px;padding:16px;display:grid}.upload-fields{gap:12px;display:grid}.compact-field{max-width:360px}.file-picker{border:1px dashed var(--border);background:var(--surface-muted);border-radius:8px;width:100%;min-height:42px;padding:10px}.file-picker::file-selector-button{background:var(--accent-soft);min-height:32px;color:var(--accent-strong);cursor:pointer;border:1px solid #2aa79b47;border-radius:8px;margin-right:10px;padding:0 12px;font-weight:700}.file-summary{color:var(--muted);margin:8px 0 0;font-size:.9rem}.upload-queue{gap:6px;max-height:180px;display:grid;overflow:auto}.upload-queue-item{border:1px solid var(--border);background:var(--surface);border-radius:8px;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;padding:8px 10px;font-size:.84rem;display:grid}.upload-queue-name{text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.upload-queue-state{color:var(--muted);white-space:nowrap;font-weight:800}.upload-queue-item-uploading{background:var(--accent-soft);border-color:#2aa79b47}.upload-queue-item-done .upload-queue-state{color:var(--accent-strong)}.upload-queue-item-error{background:var(--danger-soft);border-color:#c9354d47}.upload-queue-item-error .upload-queue-state{max-width:220px;color:var(--danger);text-overflow:ellipsis;overflow:hidden}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.photo-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;transition:border-color .14s,box-shadow .14s,transform .14s;overflow:hidden}.photo-card:hover{border-color:#2aa79b61;transform:translateY(-2px);box-shadow:0 18px 36px #1720331f}.photo-preview-button{cursor:zoom-in;background:0 0;border:0;width:100%;padding:0;display:block;overflow:hidden}.photo-preview{aspect-ratio:4/3;background:linear-gradient(135deg, var(--surface-muted), var(--accent-soft));object-fit:cover;width:100%;transition:transform .18s;display:block}.photo-preview-button:hover .photo-preview{transform:scale(1.015)}.photo-body{gap:12px;padding:13px;display:grid}.photo-title-row{gap:8px;display:grid}.photo-name{color:#182033;text-overflow:ellipsis;white-space:nowrap;margin:0;font-weight:700;overflow:hidden}.photo-albums{flex-wrap:wrap;gap:6px;display:flex}.photo-album{background:var(--accent-soft);width:fit-content;max-width:100%;color:var(--accent-strong);text-overflow:ellipsis;white-space:nowrap;border:1px solid #2aa79b47;border-radius:999px;padding:3px 8px;font-size:.76rem;font-weight:700;overflow:hidden}.album-editor{border-top:1px dashed var(--border);padding-top:10px}.album-edit-label{color:var(--muted);gap:7px;font-size:.88rem;font-weight:700;display:grid}.album-edit-hint{color:#9a8fa7;font-size:.76rem;font-weight:700}.album-input-row{grid-template-columns:repeat(2,minmax(0,1fr));align-items:center;gap:8px;display:grid}.album-edit-toggle{background:var(--accent-soft);width:fit-content;max-width:100%;min-height:34px;color:var(--accent-strong);cursor:pointer;white-space:nowrap;border:1px solid #2aa79b47;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:0 10px;font-size:.84rem;font-weight:700;display:inline-flex}.album-edit-toggle:hover{background:#dcf7f1;border-color:#2aa79b6b}.album-edit-textarea{resize:vertical;min-height:76px;padding:9px 10px}.album-save-button{min-height:38px;padding:0 10px}.photo-meta{color:var(--muted);justify-content:space-between;gap:10px;font-size:.84rem;display:flex}.empty-state{border:1px dashed var(--border);background:var(--surface);color:var(--muted);text-align:center;border-radius:8px;padding:28px;box-shadow:0 8px 20px #1720330d}.preview-modal-backdrop{z-index:50;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f172a85;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.preview-modal{background:var(--surface);border:1px solid #d9e2eec7;border-radius:8px;grid-template-rows:auto minmax(0,1fr) auto;width:min(980px,100%);max-height:min(92vh,900px);display:grid;overflow:hidden;box-shadow:0 24px 60px #0f172a47}.preview-modal-header,.preview-modal-footer{justify-content:space-between;align-items:center;gap:14px;padding:14px 16px;display:flex}.preview-modal-header{border-bottom:1px solid var(--border)}.preview-modal-footer{border-top:1px solid var(--border)}.preview-modal-heading,.preview-modal-meta{gap:8px;min-width:0;display:grid}.preview-modal-title{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin:0;font-size:1rem;line-height:1.3;overflow:hidden}.preview-modal-image-wrap{background:#111827;place-items:center;min-height:0;padding:12px;display:grid;overflow:auto}.preview-modal-image{object-fit:contain;border-radius:6px;max-width:100%;max-height:68vh;display:block}.preview-close{flex:none}@media (max-width:720px){.gallery-shell{padding:18px 14px 32px}.toolbar,.upload-panel{flex-direction:column;grid-template-columns:1fr;align-items:stretch}.toolbar-actions,.upload-actions{justify-content:space-between}.upload-toggle{flex:160px}.card-actions{grid-template-columns:1fr}.album-toolbar{align-items:flex-start}.album-input-row{grid-template-columns:1fr}.upload-queue-item{grid-template-columns:1fr;gap:4px}.upload-queue-state{white-space:normal}.upload-queue-item-error .upload-queue-state,.compact-field{max-width:none}.button-primary,.button-secondary{flex:auto}.photo-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.photo-body{padding:10px}.photo-meta{flex-direction:column;gap:4px}.preview-modal-backdrop{padding:10px}.preview-modal{max-height:calc(100vh - 20px)}.preview-modal-header,.preview-modal-footer{align-items:stretch}.preview-modal-footer{flex-direction:column}.preview-modal-image{max-height:56vh}}@media (max-width:420px){.photo-grid{grid-template-columns:1fr}}
