*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg:#faf8f5;--color-surface:#fff;--color-text:#3d3226;--color-text-muted:#8c8072;--color-accent:#c9a96e;--color-accent-hover:#b8964a;--color-border:#e5ddd1;--color-danger:#c0392b;--shadow-sm:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 12px 40px #0000001a;--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{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;justify-content:space-between;align-items:center;padding:16px 24px;display:flex;position:sticky;top:0}.logo{color:var(--color-text);letter-spacing:1px;font-size:20px;font-weight:700}.btn-add-header{background:var(--color-accent);color:#fff;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}.home-hero{text-align:center;padding:48px 0 32px}.hero-title{color:var(--color-text);letter-spacing:4px;margin-bottom:12px;font-size:48px;font-weight:700}.hero-subtitle{color:var(--color-text-muted);letter-spacing:2px;font-size:16px}.home-toolbar{text-align:center;margin-bottom:40px}.btn-add-primary{background:var(--color-accent);color:#fff;letter-spacing:1px;box-shadow:var(--shadow-sm);border-radius:10px;padding:12px 36px;font-size:16px;font-weight:600;transition:all .2s;display:inline-block}.btn-add-primary:hover{background:var(--color-accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.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;box-shadow:var(--shadow-sm);cursor:pointer;border-top:4px solid;flex-direction:column;align-items:center;gap:12px;padding:32px 20px;transition:all .3s;display:flex}.category-card:hover{box-shadow:var(--shadow-lg);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}.add-header{text-align:center;margin-bottom:36px}.add-title{color:#d4c5a9;letter-spacing:6px;margin-bottom:8px;font-size:32px;font-weight:700}.add-subtitle{color:#b4a58c80;letter-spacing:3px;font-size:14px;font-style:italic}.btn-back-dark{color:#b4a58c99!important}.btn-back-dark:hover,.form-label-dark{color:#d4c5a9!important}.form-select-dark,.form-input-dark,.form-textarea-dark{color:#d4c5a9!important;background:#161210cc!important;border-color:#b8960c40!important}.form-select-dark:focus,.form-input-dark:focus,.form-textarea-dark:focus{border-color:#b8960c80!important}.form-select-dark option{color:#d4c5a9;background:#2a2118}.form-textarea-dark::placeholder,.form-input-dark::placeholder{color:#b4a58c59}.btn-submit-dark{letter-spacing:4px;font-weight:700;color:#161210!important;background:#b8960c!important}.btn-submit-dark:hover:not(:disabled){background:#d4a912!important}.museum-mode .drop-zone{background:#16121099!important;border-color:#b8960c40!important}.museum-mode .drop-zone:hover{background:#b8960c0f!important;border-color:#b8960c80!important}.museum-mode .drop-zone p{color:#d4c5a9!important}.museum-mode .drop-hint{color:#b4a58c66!important}.museum-mode .preview-remove{background:#b8960cb3!important}.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-text)}.page-title{letter-spacing:2px;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-textarea{resize:vertical;min-height:80px}.btn-submit{background:var(--color-accent);color:#fff;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:#c9a96e0d}.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-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border-left:4px solid;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;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);transition:box-shadow .3s;overflow:hidden}.item-card:hover{box-shadow:var(--shadow-md)}.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:#fff;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){.hero-title{letter-spacing:2px;font-size:32px}.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:#000000e6;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-mode{background:#161210;min-height:100vh}.museum-mode body{background:#161210}.header-dark{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#161210f2!important;border-bottom:1px solid #c9a96e26!important}.header-dark .logo{color:#d4c5a9}.main-full{flex:1;justify-content:center;align-items:center;display:flex;max-width:none!important;padding:0!important}.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)}}.collection-overlay{z-index:1000;cursor:pointer;background:#000000bf;flex-direction:column;justify-content:center;align-items:center;animation:.4s overlay-in;display:flex;position:fixed;inset:0}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.collection-card{cursor:default;animation:.6s cubic-bezier(.34,1.56,.64,1) .15s both card-in}@keyframes card-in{0%{opacity:0;transform:scale(.85)translateY(20px)}to{opacity:1;transform:scale(1)translateY(0)}}.collection-card-inner{text-align:center;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#8b775008 2px 4px),linear-gradient(135deg,#d4c5a0 0%,#c9b78a 15%,#daca9a 30%,#c4b082 50%,#d2bf8c 65%,#bfaa78 85%,#d4c5a0 100%);max-width:460px;padding:48px 52px;position:relative;box-shadow:0 2px 4px #0000004d,0 8px 24px #0006,0 20px 60px #00000080,inset 0 1px #ffffff26}.collection-card-inner:before{content:"";pointer-events:none;border:1px solid #8b77504d;position:absolute;inset:-3px}.collection-card-inner:after{content:"";pointer-events:none;position:absolute;inset:2px;box-shadow:inset 0 0 30px #8b775026}.collection-label{color:#6b5d42;letter-spacing:3px;margin-bottom:10px;font-family:Noto Serif SC,Songti SC,Georgia,serif;font-size:15px}.collection-museum{color:#4a3822;letter-spacing:6px;font-family:Noto Serif SC,Songti SC,Georgia,serif;font-size:30px;font-weight:700}.collection-divider{background:#8b775066;width:60px;height:1px;margin:20px auto}.collection-number-label{color:#8c7a5a;letter-spacing:3px;margin-bottom:8px;font-size:12px}.collection-number{color:#4a3822;letter-spacing:3px;font-family:Georgia,Noto Serif SC,serif;font-size:20px;font-weight:600}.collection-hint{color:#c8b99b66;letter-spacing:3px;cursor:pointer;margin-top:36px;font-size:13px;animation:2.5s ease-in-out infinite splash-pulse}@media (width<=500px){.collection-card-inner{max-width:320px;padding:36px 28px}.collection-museum{letter-spacing:4px;font-size:24px}.collection-number{letter-spacing:2px;font-size:17px}}.gallery-page{-webkit-user-select:none;user-select:none;background:repeating-linear-gradient(90deg,#0000 0,#0000000f 2px,#0000 4px 42px,#0000001a 44px,#0000 46px 88px,#0000000d 90px,#0000 92px),linear-gradient(#5c1515 0%,#4a1010 8%,#3d0d0d 20%,#350b0b 60%,#2d0909 100%);flex-direction:column;justify-content:center;align-items:center;width:100%;height:calc(100vh - 57px);display:flex;position:relative;overflow:hidden}.gallery-curtain-top{z-index:5;pointer-events:none;background:repeating-linear-gradient(90deg,#0000,#0000 18px,#00000026 18px 20px,#0000 20px 38px,#00000014 38px 40px,#0000 40px),linear-gradient(#6b1818 0%,#4a1010 70%,#0000 100%);height:60px;position:absolute;top:0;left:-10px;right:-10px;box-shadow:0 4px 20px #00000080}.gallery-tug{animation:.5s curtain-tug}@keyframes curtain-tug{0%{transform:scaleX(1)}30%{transform:scaleX(1.008)}to{transform:scaleX(1)}}.gallery-spotlights{pointer-events:none;z-index:1;position:absolute;inset:0}.gallery-spotlight{background:radial-gradient(140px 300px at 50% 25%,#fff0c814 0%,#ffe6b40a 30%,#0000 65%);width:180px;height:100%;position:absolute;top:0;transform:translate(-50%)}.gallery-viewport{z-index:2;scroll-behavior:smooth;width:100%;padding:0 60px;position:relative;overflow-x:hidden}.gallery-row{align-items:center;gap:40px;width:max-content;padding:20px 0;display:flex}.exhibit-item{flex-direction:column;align-items:center;transition:transform .5s cubic-bezier(.34,1.56,.64,1);display:flex;position:relative}.exhibit-item:hover{z-index:10}.exhibit-light{pointer-events:none;opacity:.6;background:radial-gradient(80% 100% at 50% 100%,#fff0c81f 0%,#ffe6b40d 40%,#0000 70%);width:160%;height:200px;transition:opacity .5s;position:absolute;top:-120px;left:50%;transform:translate(-50%)}.exhibit-item:hover .exhibit-light{opacity:1}.exhibit-frame{cursor:pointer;background:#222;transition:transform .5s cubic-bezier(.34,1.56,.64,1),box-shadow .5s;position:relative;overflow:hidden}.exhibit-item:hover .exhibit-frame{transform:scale(1.06)}.frame-gold{border:12px solid;border-image:linear-gradient(135deg,#c9a44b 0%,#e8d48b 15%,#b8902a 30%,#d4b85c 50%,#a67c20 70%,#e0c878 85%,#c9a44b 100%) 1;box-shadow:0 0 0 2px #6b4f18,0 0 0 5px #b8902a,0 0 0 6px #5c4210,0 8px 32px #0000008c,inset 0 0 0 1px #0003}.frame-darkwood{border:14px solid;border-image:linear-gradient(135deg,#4a2a14 0%,#6b3e20 20%,#5c3418 50%,#7a4828 80%,#4a2a14 100%) 1;box-shadow:0 0 0 1px #1a0a02,0 0 0 3px #4a2a14,0 8px 32px #0000008c,inset 0 0 0 1px #00000026}.frame-white{border:10px solid #f2ede6;box-shadow:0 0 0 1px #c5bfb5,0 0 0 3px #e8e2d8,0 8px 28px #00000059,inset 0 1px #fff6}.frame-silver{border:10px solid;border-image:linear-gradient(135deg,#9a9a9a 0%,#d0d0d0 20%,#a8a8a8 40%,#c8c8c8 60%,#888 80%,#b0b0b0 100%) 1;box-shadow:0 0 0 2px #666,0 0 0 4px #aaa,0 8px 32px #00000080,inset 0 0 0 1px #00000026}.frame-bronze{border:11px solid;border-image:linear-gradient(135deg,#7a5a1a 0%,#b8904c 20%,#8b6a28 50%,#c4a060 80%,#7a5a1a 100%) 1;box-shadow:0 0 0 2px #4a3510,0 0 0 5px #8b6a28,0 8px 32px #0000008c,inset 0 0 0 1px #0003}.frame-black{border:8px solid #1a1a1a;box-shadow:0 0 0 1px #3a3a3a,0 0 0 2px #1a1a1a,0 8px 28px #00000080,inset 0 1px #ffffff0d}.exhibit-size-sm .exhibit-frame{aspect-ratio:4/3;width:160px}.exhibit-size-md .exhibit-frame{aspect-ratio:3/4;width:220px}.exhibit-size-lg .exhibit-frame{aspect-ratio:3/4;width:280px}.exhibit-size-tall .exhibit-frame{aspect-ratio:2/3;width:180px}.exhibit-size-wide .exhibit-frame{aspect-ratio:16/10;width:300px}.exhibit-photo{object-fit:cover;width:100%;height:100%;display:block}.exhibit-no-photo{color:#666;justify-content:center;align-items:center;width:100%;height:100%;font-size:13px;display:flex}.exhibit-label{text-align:center;background:linear-gradient(#c9b078 0%,#b89858 30%,#a08040 100%);min-width:80px;max-width:200px;margin-top:12px;padding:8px 16px;position:relative;box-shadow:0 2px 6px #0006,inset 0 1px #ffffff26}.exhibit-label:before,.exhibit-label:after{content:"";background:radial-gradient(circle,#6b4f18,#3d2a08);border-radius:50%;width:5px;height:5px;position:absolute;top:4px}.exhibit-label:before{left:6px}.exhibit-label:after{right:6px}.exhibit-label-text{color:#3d2a10;letter-spacing:1px;text-overflow:ellipsis;white-space:nowrap;max-width:180px;font-size:12px;font-weight:600;line-height:1.4;overflow:hidden}.exhibit-label-date{color:#5c4218;letter-spacing:2px;margin-top:2px;font-size:10px}.exhibit-delete{color:#ffffffb3;cursor:pointer;opacity:0;z-index:5;background:#0006;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:14px;transition:opacity .3s;display:flex;position:absolute;top:8px;right:8px}.exhibit-item:hover .exhibit-delete{opacity:1}.exhibit-delete:hover{color:#fff;background:#b42828cc}.gallery-arrow{z-index:10;color:#c8aa6e99;cursor:pointer;background:#00000040;border:1px solid #c8aa6426;justify-content:center;align-items:center;width:54px;height:80px;font-family:Georgia,serif;font-size:48px;line-height:1;transition:all .3s;display:flex;position:absolute;top:50%;transform:translateY(-50%)}.gallery-arrow:hover{color:#dcbe82e6;background:#00000080;border-color:#c8aa6459}.gallery-arrow-left{border-radius:0 8px 8px 0;left:0}.gallery-arrow-right{border-radius:8px 0 0 8px;right:0}.gallery-arrow-hidden{opacity:0;pointer-events:none}.gallery-pager{z-index:10;color:#c8b49659;letter-spacing:3px;font-family:Georgia,serif;font-size:13px;position:absolute;bottom:20px}.gallery-empty{background:repeating-linear-gradient(90deg,#0000 0,#0000000f 2px,#0000 4px 42px,#0000001a 44px,#0000 46px 88px,#0000000d 90px,#0000 92px),linear-gradient(#5c1515 0%,#4a1010 8%,#3d0d0d 20%,#350b0b 60%,#2d0909 100%);flex-direction:column;justify-content:center;align-items:center;width:100%;height:calc(100vh - 57px);display:flex;position:relative;overflow:hidden}.gallery-empty-spotlight{pointer-events:none;background:radial-gradient(100% 100%,#fff0c80f 0%,#0000 70%);width:300px;height:300px;position:absolute;top:30%;left:50%;transform:translate(-50%,-50%)}.gallery-empty-title{color:#c8b49680;letter-spacing:3px;text-align:center;margin-bottom:12px;font-family:Georgia,Noto Serif SC,serif;font-size:20px;font-style:italic}.gallery-empty-sub{color:#c8b4964d;letter-spacing:2px;margin-bottom:36px;font-size:15px}@media (width<=1100px){.gallery-slide{gap:24px}.exhibit-size-sm .exhibit-frame{width:120px}.exhibit-size-md .exhibit-frame{width:170px}.exhibit-size-lg .exhibit-frame{width:210px}.exhibit-size-tall .exhibit-frame{width:140px}.exhibit-size-wide .exhibit-frame{width:230px}.gallery-stage{padding:0 44px}}@media (width<=750px){.gallery-slide{gap:14px}.exhibit-size-sm .exhibit-frame,.exhibit-size-md .exhibit-frame,.exhibit-size-tall .exhibit-frame{width:110px}.exhibit-size-lg .exhibit-frame{width:140px}.exhibit-size-wide .exhibit-frame{width:160px}.gallery-stage{padding:0 36px}.gallery-arrow{width:36px;height:56px;font-size:32px}.exhibit-label{min-width:60px;padding:6px 10px}.exhibit-label-text{max-width:100px;font-size:10px}.exhibit-label-date{font-size:9px}.gallery-empty-title{letter-spacing:2px;font-size:16px}}
