:root{color:#24292f;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f6f7f9;font:16px/1.5 Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}body{margin:0}:root{--dia-orange:#ef7d00;--dia-orange-dark:#c96500;--ink:#24292f;--muted:#667085;--line:#e4e7ec;--panel:#fff;--page:#f6f7f9;--soft-orange:#fff3e7;--shadow:0 18px 45px #10182814}*{box-sizing:border-box}body{background:linear-gradient(180deg, #ef7d0014, #ef7d0000 260px), var(--page);min-height:100vh;color:var(--ink);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input{font:inherit}#root{width:100%;min-height:100vh}.app{width:min(100%,760px);min-height:100vh;margin:0 auto;padding:28px 18px 40px}.header{text-align:center;padding:22px 0 24px}.school-logo{width:min(100%,360px);height:auto;margin:0 auto 18px;display:block}.hero-kicker{color:var(--dia-orange);letter-spacing:.08em;text-transform:uppercase;margin:0 0 8px;font-size:.82rem;font-weight:800}.header h1{color:var(--ink);letter-spacing:0;margin:0;font-size:2.35rem;font-weight:800;line-height:1.08}.intro-text{width:min(100%,560px);color:var(--muted);margin:14px auto 0;font-size:1rem;line-height:1.55}.intro-text p{margin:0}.intro-text p+p{margin-top:10px}.guest-name-panel,.upload-box{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px}.guest-name-panel{margin-bottom:18px;padding:18px}.guest-name-label{color:var(--ink);margin-bottom:8px;font-size:.92rem;font-weight:800;display:block}.guest-name-input{width:100%;min-height:48px;color:var(--ink);background:#fff;border:1px solid #cfd4dc;border-radius:8px;outline:none;padding:12px 14px;transition:border-color .18s,box-shadow .18s}.guest-name-input:focus{border-color:var(--dia-orange);box-shadow:0 0 0 4px #ef7d0024}.content{width:100%}.upload-media{gap:18px;display:grid}.upload-box{padding:22px}.upload-box h2{color:var(--ink);letter-spacing:0;margin:0 0 8px;font-size:1.28rem;font-weight:800;line-height:1.2}.upload-hint{color:var(--muted);margin:0 0 18px;font-size:.96rem;line-height:1.45}.file-actions{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-bottom:16px;display:grid}.file-label,.upload-btn{text-align:center;cursor:pointer;border-radius:8px;justify-content:center;align-items:center;min-height:48px;font-weight:800;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s;display:inline-flex}.file-label{color:var(--dia-orange-dark);background:var(--soft-orange);border:1px solid #ef7d0042}.file-label:hover{border-color:var(--dia-orange);transform:translateY(-1px)}.file-label[disabled]{color:#98a2b3;border-color:var(--line);cursor:not-allowed;background:#f2f4f7;transform:none}.file-list{border:1px solid var(--line);background:#f9fafb;border-radius:8px;margin:0 0 16px;padding:14px}.file-list h3{color:var(--ink);margin:0 0 8px;font-size:.95rem;font-weight:800}.file-list ul{gap:6px;margin:0;padding:0;list-style:none;display:grid}.file-list li{overflow-wrap:anywhere;color:var(--muted);justify-content:space-between;align-items:center;gap:10px;font-size:.92rem;display:flex}.file-list li span{overflow-wrap:anywhere;min-width:0}.remove-selected-btn{color:#b42318;cursor:pointer;background:#fff5f5;border:1px solid #fecdca;border-radius:8px;flex:none;min-height:32px;padding:0 10px;font-size:.82rem;font-weight:800}.remove-selected-btn:disabled{opacity:.55;cursor:not-allowed}.upload-btn{color:#fff;background:var(--dia-orange);border:1px solid var(--dia-orange);width:100%;margin-top:4px;box-shadow:0 12px 24px #ef7d0033}.upload-btn:hover:not(:disabled){background:var(--dia-orange-dark);border-color:var(--dia-orange-dark);transform:translateY(-1px)}.upload-btn:disabled{box-shadow:none;cursor:not-allowed;background:#d0d5dd;border-color:#d0d5dd}.message{color:var(--ink);border:1px solid var(--line);border-left:4px solid var(--dia-orange);background:#f9fafb;border-radius:8px;margin:14px 0 0;padding:12px 14px;font-weight:700;line-height:1.4}.own-photos-box{box-shadow:none}.own-photo-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px;display:grid}.own-photo-item{aspect-ratio:1;border:1px solid var(--line);background:#f2f4f7;border-radius:8px;position:relative;overflow:hidden}.own-photo-item img{object-fit:cover;width:100%;height:100%;display:block}.own-photo-change-btn{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#24292fd1;border:1px solid #ffffff3d;border-radius:8px;min-height:38px;padding:0 10px;font-size:.84rem;font-weight:800;position:absolute;bottom:8px;left:8px;right:8px}.own-photo-change-btn:hover:not(:disabled){background:var(--dia-orange)}.own-photo-change-btn:disabled{opacity:.65;cursor:not-allowed}.own-photo-empty{color:var(--muted);text-align:center;background:#f9fafb;border:1px dashed #cfd4dc;border-radius:8px;margin:0;padding:16px}.app-footer{text-align:center;margin-top:24px}.admin-toggle,.logout-btn,.filter-btn,.export-zip-btn,.delete-upload-btn,.admin-login button,.secondary-btn,.slideshow-actions button{cursor:pointer;border-radius:8px;justify-content:center;align-items:center;min-height:42px;font-weight:800;transition:transform .18s,border-color .18s,background .18s,box-shadow .18s;display:inline-flex}.admin-toggle{color:var(--muted);border:1px solid var(--line);background:0 0;padding:8px 14px}.admin-toggle:hover,.secondary-btn:hover,.filter-btn:hover,.slideshow-actions button:hover{border-color:var(--dia-orange);color:var(--dia-orange-dark)}.admin-login{text-align:left;background:var(--panel);border:1px solid var(--line);width:min(100%,420px);box-shadow:var(--shadow);border-radius:8px;margin:14px auto 0;padding:18px}.admin-login h2{color:var(--ink);margin:0 0 12px;font-size:1.1rem;font-weight:800}.admin-login input{border:1px solid #cfd4dc;border-radius:8px;outline:none;width:100%;min-height:46px;padding:12px 14px}.admin-login input:focus{border-color:var(--dia-orange);box-shadow:0 0 0 4px #ef7d0024}.admin-login-actions,.admin-view-switch,.export-zip-actions,.slideshow-actions{flex-wrap:wrap;gap:10px;display:flex}.admin-login-actions{margin-top:12px}.admin-login button,.export-zip-btn{color:#fff;background:var(--dia-orange);border:1px solid var(--dia-orange);padding:0 16px}.secondary-btn,.filter-btn,.slideshow-actions button{color:var(--ink);border:1px solid var(--line);background:#fff;padding:0 14px}.filter-btn.active{color:#fff;background:var(--dia-orange);border-color:var(--dia-orange)}.admin-view-switch{border:1px solid var(--line);background:#fff;border-radius:8px;margin-bottom:18px;padding:8px;box-shadow:0 10px 24px #1018280f}.admin-view-switch .filter-btn{flex:130px}.logout-btn{width:100%;color:var(--muted);border:1px solid var(--line);background:#fff;margin-top:18px}.admin-gallery{gap:18px;display:grid}.gallery-header-row{background:var(--panel);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:8px;justify-content:space-between;align-items:flex-start;gap:16px;padding:22px;display:flex}.gallery-header-row h2{color:var(--ink);margin:0 0 6px;font-size:1.35rem;font-weight:800}.gallery-subtitle{color:var(--muted);margin:0}.gallery-message,.admin-empty-state{color:var(--ink);border:1px solid var(--line);border-left:4px solid var(--dia-orange);background:#fff;border-radius:8px;margin:0;padding:14px 16px}.admin-empty-state{color:var(--muted);border-left-color:var(--line);text-align:center}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;display:grid}.gallery-item{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden;box-shadow:0 12px 28px #10182812}.gallery-link{color:inherit;text-decoration:none;display:block}.gallery-media{aspect-ratio:4/3;background:#f2f4f7}.gallery-media img{object-fit:cover;width:100%;height:100%;display:block}.gallery-info{gap:7px;padding:13px;display:grid}.gallery-filename,.gallery-guest,.gallery-date{margin:0}.gallery-filename{overflow-wrap:anywhere;color:var(--ink);font-size:.92rem;font-weight:800}.gallery-guest,.gallery-date{color:var(--muted);font-size:.88rem}.delete-upload-btn{color:#b42318;background:#fff5f5;border:1px solid #fecdca;width:100%;margin-top:4px}.delete-upload-btn:hover:not(:disabled){background:#fee4e2;border-color:#f97066}.export-zip-btn:hover:not(:disabled),.admin-login button:hover:not(:disabled){background:var(--dia-orange-dark);border-color:var(--dia-orange-dark);transform:translateY(-1px)}.export-zip-btn:disabled,.delete-upload-btn:disabled,.admin-login button:disabled{opacity:.55;cursor:not-allowed;transform:none}.slideshow-page{color:#fff;background:#101418;grid-template-rows:auto 1fr;min-height:100vh;display:grid}.slideshow-topbar{color:var(--ink);border-bottom:4px solid var(--dia-orange);background:#fffffff5;justify-content:space-between;align-items:center;gap:18px;padding:18px 24px;display:flex}.slideshow-brand{align-items:center;gap:14px;min-width:0;display:flex}.slideshow-brand img{width:120px;height:auto;display:block}.slideshow-brand h1{color:var(--ink);margin:0;font-size:1.5rem;font-weight:900;line-height:1}.slideshow-actions{justify-content:flex-end}.slideshow-actions button{background:#fff;min-height:38px}.slideshow-frame{place-items:center;min-height:0;padding:24px;display:grid;position:relative}.slideshow-frame img{object-fit:contain;border-radius:8px;max-width:100%;max-height:calc(100vh - 132px);display:block;box-shadow:0 24px 70px #00000059}.slideshow-caption{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#101418bd;border:1px solid #ffffff2e;border-radius:8px;justify-content:space-between;gap:12px;padding:12px 16px;display:flex;position:absolute;bottom:24px;left:24px;right:24px}.slideshow-empty{color:#fff;margin:0;font-size:1.2rem;font-weight:800}@media (width<=560px){.app{padding:20px 14px 30px}.header{padding-top:12px}.school-logo{width:min(100%,300px)}.header h1{font-size:1.85rem}.guest-name-panel,.upload-box{padding:16px}.file-actions{grid-template-columns:1fr}.gallery-header-row,.slideshow-topbar{flex-direction:column;align-items:stretch}.export-zip-btn,.slideshow-actions button{width:100%}.slideshow-brand{text-align:center;justify-content:center}.slideshow-brand img{width:96px}.slideshow-actions{grid-template-columns:1fr 1fr;display:grid}.slideshow-frame{padding:12px}.slideshow-frame img{max-height:calc(100vh - 230px)}.slideshow-caption{bottom:12px;left:12px;right:12px}}
