*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#161210;--color-surface:#1e1a16;--color-text:#d4c5a9;--color-text-muted:#8c7d6a;--color-accent:#b8960c;--color-accent-hover:#c9a96e;--color-border:#b8960c1f;--color-danger:#e74c3c;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 16px #0006;--shadow-lg:0 12px 40px #00000080;--radius:12px;--radius-lg:16px}body{background:var(--color-bg);color:var(--color-text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Noto Serif SC,Source Han Serif SC,Songti SC,STSong,Georgia,serif;line-height:1.7}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.app-container{flex-direction:column;min-height:100vh;display:flex}.header{border-bottom:1px solid var(--color-border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:100;background:#161210f2;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.logo{color:#d4c5a9;letter-spacing:1px;font-size:20px;font-weight:700}.btn-add-header{background:var(--color-accent);color:#1a1510;border-radius:8px;padding:8px 20px;font-family:inherit;font-size:14px;font-weight:600;transition:background .2s}.btn-add-header:hover{background:var(--color-accent-hover)}.main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:32px 24px}.main-full{flex:1;justify-content:center;align-items:center;max-width:none;padding:0;display:flex}.category-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:20px;display:grid}.category-card{background:var(--color-surface);border-radius:var(--radius-lg);text-align:center;border:1px solid var(--color-border);box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:column;align-items:center;gap:12px;padding:32px 20px;transition:all .3s;display:flex}.category-card:hover{box-shadow:var(--shadow-lg);border-color:var(--color-accent);transform:translateY(-4px)}.category-emoji{font-size:40px;line-height:1}.category-name{color:var(--color-text);font-size:18px;font-weight:600}.category-count{color:var(--color-text-muted);font-size:13px}.add-page{max-width:640px;margin:0 auto}.btn-back{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;margin-bottom:24px;padding:0;font-family:inherit;font-size:14px;transition:color .2s}.btn-back:hover{color:var(--color-accent-hover)}.page-title{letter-spacing:2px;color:var(--color-text);margin-bottom:32px;font-size:28px;font-weight:700}.add-form{flex-direction:column;gap:24px;display:flex}.form-label{color:var(--color-text);flex-direction:column;gap:8px;font-size:14px;font-weight:600;display:flex}.form-select,.form-input,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text);outline:none;padding:12px 16px;font-family:inherit;font-size:16px;transition:border-color .2s}.form-select:focus,.form-input:focus,.form-textarea:focus{border-color:var(--color-accent)}.form-select option{color:#d4c5a9;background:#1e1a16}.form-textarea{resize:vertical;min-height:80px}.form-textarea::placeholder{color:var(--color-text-muted)}.btn-submit{background:var(--color-accent);color:#1a1510;cursor:pointer;letter-spacing:1px;border:none;border-radius:10px;align-self:flex-start;padding:14px 32px;font-family:inherit;font-size:16px;font-weight:600;transition:all .2s}.btn-submit:hover:not(:disabled){background:var(--color-accent-hover)}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.photo-uploader{flex-direction:column;gap:16px;display:flex}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius);text-align:center;cursor:pointer;padding:40px;transition:border-color .2s,background .2s}.drop-zone:hover{border-color:var(--color-accent);background:#b8960c0f}.drop-icon{margin-bottom:8px;font-size:36px;display:block}.drop-zone p{color:var(--color-text);margin-bottom:4px;font-size:15px}.drop-hint{color:var(--color-text-muted);font-size:12px}.preview-list{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px;display:grid}.preview-item{aspect-ratio:1;border-radius:var(--radius);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.preview-img{object-fit:cover;width:100%;height:100%}.preview-remove{color:#fff;cursor:pointer;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:16px;line-height:1;display:flex;position:absolute;top:4px;right:4px}.category-page{max-width:720px;margin:0 auto}.category-header{background:var(--color-surface);border-left:4px solid var(--color-accent);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);align-items:center;gap:12px;margin-bottom:32px;padding:20px 24px;display:flex}.category-header-emoji{font-size:32px}.category-header-title{letter-spacing:2px;color:var(--color-text);font-size:24px;font-weight:700}.category-header-count{color:var(--color-text-muted);margin-left:auto;font-size:14px}.item-list{flex-direction:column;gap:24px;display:flex}.item-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);transition:box-shadow .3s,border-color .3s;overflow:hidden}.item-card:hover{box-shadow:var(--shadow-md);border-color:#b8960c40}.item-photos{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:4px;display:grid}.item-photo{aspect-ratio:4/3;object-fit:cover;cursor:pointer;width:100%;transition:opacity .2s}.item-photo:hover{opacity:.85}.item-body{padding:20px 24px}.item-description{color:var(--color-text);margin-bottom:16px;font-size:15px;line-height:1.7}.item-footer{justify-content:space-between;align-items:center;display:flex}.item-date{color:var(--color-text-muted);font-size:13px}.btn-delete{border:1px solid var(--color-danger);color:var(--color-danger);cursor:pointer;background:0 0;border-radius:6px;padding:4px 14px;font-family:inherit;font-size:13px;transition:all .2s}.btn-delete:hover{background:var(--color-danger);color:#fff}.loading,.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:16px;padding:64px 24px;display:flex}.btn-add-empty{background:var(--color-accent);color:#1a1510;cursor:pointer;border:none;border-radius:8px;padding:10px 28px;font-family:inherit;font-size:15px;transition:background .2s}.btn-add-empty:hover{background:var(--color-accent-hover)}@media (width<=640px){.category-grid{grid-template-columns:repeat(2,1fr);gap:12px}.category-card{padding:24px 16px}.category-emoji{font-size:32px}.item-photos{grid-template-columns:1fr}.main{padding:20px 16px}}.photo-modal-overlay{z-index:1000;cursor:pointer;background:#000000eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.photo-modal-img{object-fit:contain;max-width:90vw;max-height:90vh}.splash{cursor:pointer;z-index:1000;background:url(/bg.jpg) 50%/cover no-repeat;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash:before{content:"";background:#00000059;transition:background .8s;position:absolute;inset:0}.splash.entering:before{background:#000000b3}.splash-overlay{pointer-events:none;background:0 0;transition:background .4s .5s;position:absolute;inset:0}.splash.entering .splash-overlay{background:#ffffffeb}.splash-content{z-index:1;text-align:center;transition:opacity .3s,transform .6s;position:relative}.splash.entering .splash-content{opacity:0;transform:scale(.92)}.splash-title{color:#fff;letter-spacing:8px;text-shadow:0 2px 20px #0000004d;margin-bottom:24px;font-family:Noto Serif SC,Songti SC,Georgia,serif;font-size:clamp(40px,8vw,80px);font-weight:700}.splash-hint{color:#ffffffa6;letter-spacing:4px;font-size:clamp(14px,2vw,18px);animation:2.5s ease-in-out infinite splash-pulse}@keyframes splash-pulse{0%,to{opacity:.5}50%{opacity:.9}}.splash-flash{opacity:0;pointer-events:none;z-index:2;background:#fff;transition:opacity .15s;position:absolute;inset:0}.splash.entering .splash-flash{opacity:1;transition:opacity .25s .7s}.app-container{animation:.6s page-in}@keyframes page-in{0%{opacity:0}to{opacity:1}}.museum-page{background:radial-gradient(at 50% 0,#c9a96e0f 0%,#0000 60%),radial-gradient(at 50% 100%,#0006 0%,#0000 50%),#161210;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 57px);padding:40px 24px;display:flex}.museum-halls{flex-wrap:nowrap;justify-content:center;align-items:flex-end;gap:24px;display:flex}.hall-entrance{cursor:pointer;flex-direction:column;align-items:center;gap:14px;text-decoration:none;transition:transform .5s cubic-bezier(.34,1.56,.64,1);display:flex}.hall-entrance:hover{z-index:2;transform:scale(1.1)}.hall-door{filter:drop-shadow(0 0 6px #b8960c33);width:100%;max-width:160px;height:auto;transition:filter .5s}.hall-entrance:hover .hall-door{filter:drop-shadow(0 0 28px #b8960c8c)}.hall-name{color:#d4c5a9;letter-spacing:4px;font-size:18px;font-weight:600;transition:color .4s,letter-spacing .4s}.hall-entrance:hover .hall-name{color:#eadbbc;letter-spacing:6px}.hall-count{color:#b4a58c8c;margin-top:-8px;font-size:13px;transition:color .4s}.hall-entrance:hover .hall-count{color:#c8b99bbf}.loading-dark{text-align:center;color:#b4a58c80;padding:64px 24px;font-size:16px}@media (width<=1100px){.museum-halls{gap:14px}.hall-door{max-width:120px}}@media (width<=750px){.museum-halls{gap:8px}.hall-door{max-width:80px}.hall-name{letter-spacing:2px;font-size:13px}.hall-count{font-size:11px}.hall-entrance:hover{transform:scale(1.06)}}
