:root{--primary:#1c2659;--primary-dark:#121a3d;--body:#1c2659;--hero-gradient:linear-gradient(180deg, #1835ab 0%, #122870 100%);--light-blue:#d3d9fa;--subtitle-blue:#cbccfa;--accent:#ffb800;--accent-dark:#cc9400;--white:#fff;--bg-color:#f6f6fa;--font-primary:"Inter", sans-serif;--radius:16px;--radius-btn:32px}*{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-primary);background-color:var(--bg-color);color:var(--body);-webkit-font-smoothing:antialiased;line-height:1.5}#app{flex-direction:column;min-height:100vh;display:flex;overflow-x:hidden}.hidden{display:none!important}.top-bar{text-align:center;color:var(--body);z-index:10;background:#fff;padding:23px 0;font-size:24px;font-weight:700;position:relative;box-shadow:0 2px 8px #0000000d}.hero{background:var(--hero-gradient);justify-content:center;align-items:center;max-height:517px;padding:40px;display:flex;position:relative;overflow:hidden}.hero-bg-elements{pointer-events:none;z-index:1;width:100%;height:100%;position:absolute;top:0;left:0}.confetti{opacity:1;width:600px;position:absolute;top:-50px;left:-50px}.hero-container{z-index:2;flex-direction:row;justify-content:center;align-items:center;gap:40px;width:100%;max-width:1240px;display:flex;position:relative}.dragon-mascot-container{flex:1;justify-content:flex-end;display:flex}.dragon-mascot{filter:drop-shadow(0 20px 40px #0000004d);width:510px;height:auto;margin-bottom:-100px}.hero-text-content{text-align:center;flex-direction:column;flex:1.2;align-items:center;display:flex}.school-shield{height:90px;margin-bottom:20px}.headline{color:var(--light-blue);max-width:680px;margin-bottom:20px;font-size:48px;font-weight:700;line-height:1.2}.subtitle{color:var(--subtitle-blue);max-width:700px;margin-bottom:20px;font-size:24px;font-weight:400;line-height:1.2}.upload-container{margin-bottom:20px}.btn-upload{background:var(--accent);color:var(--primary);border:4px solid var(--primary);width:320px;height:80px;box-shadow:0 8px 0 var(--primary);cursor:pointer;text-transform:uppercase;border-radius:40px;justify-content:center;align-items:center;gap:12px;padding:24px 40px;font-size:20px;font-weight:700;transition:all .1s;display:inline-flex}.btn-upload:hover{box-shadow:0 10px 0 var(--primary);transform:translateY(-2px)}.btn-upload:active{box-shadow:0 4px 0 var(--primary);transform:translateY(4px)}.subtitle.emphasis{color:var(--subtitle-blue);font-size:28px;font-weight:700}.modal-overlay{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:1000;visibility:visible;opacity:1;background:#121a3dcc;justify-content:center;align-items:center;width:100%;height:100%;padding:20px;transition:opacity .3s;display:flex;position:fixed;top:0;left:0}.modal-overlay.hidden{display:none!important}.modal-content{background:#fff;border-radius:40px;flex-direction:column;width:95%;max-width:700px;max-height:90vh;animation:.4s cubic-bezier(.16,1,.3,1) modalSlideIn;display:flex;position:relative;overflow:hidden;box-shadow:0 40px 100px #0006}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.btn-close{cursor:pointer;z-index:100;color:#374151;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:all .2s;display:flex;position:absolute;top:24px;right:24px}.btn-close:hover{background:#e5e7eb;transform:rotate(90deg)}.photobooth-interface{flex-direction:column;justify-content:center;align-items:center;height:100%;padding:20px 40px;display:flex}.preview-header{text-align:center;margin-bottom:20px}.preview-header h3{color:var(--primary);font-size:24px;font-weight:800}.viewfinder{background:#000;border-radius:20px;width:100%;max-width:620px;height:300px;margin-bottom:20px;position:relative;overflow:hidden}.image-wrapper{width:100%;height:100%}.processing-state{text-align:center;z-index:5;background:#fffffff2;flex-direction:column;justify-content:center;align-items:center;gap:15px;display:flex;position:absolute;inset:0}.modal-actions{justify-content:center;width:100%;padding-top:10px;display:flex}.action-group-row{flex-direction:row;justify-content:center;gap:12px;width:100%;max-width:620px;display:flex}.hero-icon{width:20px;height:20px}.btn-filter,.btn-secondary,.btn-share{padding:10px var(--radius);border-radius:var(--radius);cursor:pointer;white-space:nowrap;color:#1a1a1a;background:#fff;border:1.5px solid #e6e6e6;flex:1;justify-content:center;align-items:center;gap:8px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.btn-filter,.btn-secondary{color:#1a1a1a;background:#dde2ff}.btn-share{color:#1a1a1a;background:#ffb800}.btn-filter:hover,.btn-secondary:hover{background:#ccd4ff}.btn-share:hover{background:#e6a600;transform:translateY(-2px)}.preview-header p{color:#666;font-size:var(--radius)}.image-wrapper{background:#1a1a1a;justify-content:center;align-items:center;width:100%;height:350px;display:flex;overflow:hidden}.image-wrapper img{object-fit:contain;width:100%;height:100%}.processing-state{text-align:center;padding:40px}.loader-container{justify-content:center;align-items:center;margin-bottom:24px;display:flex;position:relative}.countdown-container{border:10px solid var(--accent);background:#fff;border-radius:50%;justify-content:center;align-items:center;width:120px;height:120px;margin-bottom:24px;display:flex;position:relative;box-shadow:0 0 40px #ffb8004d}.countdown-number{color:var(--primary);font-variant-numeric:tabular-nums;font-size:64px;font-weight:800;animation:1s ease-in-out infinite pulseNumber}@keyframes pulseNumber{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loader-mascot{font-size:40px;animation:2s ease-in-out infinite pulse;position:absolute}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}.processing-state h3{margin-bottom:12px;font-size:28px}.processing-state p{color:#666}.actions{flex-direction:column;gap:12px;width:100%;padding-top:24px;display:flex}.sec.modal-actions{justify-content:center;gap:12px;width:100%;margin-top:20px;display:flex}.action-btn{cursor:pointer;white-space:nowrap;border:none;border-radius:12px;align-items:center;gap:8px;padding:10px 20px;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.btn-icon{width:20px;height:20px}.filter-btn{color:#1e40af;background-color:#dbeafe}.filter-btn:hover{background-color:#bfdbfe}.retake-btn{color:#374151;background-color:#f3f4f6}.retake-btn:hover{background-color:#e5e7eb}.share-btn{color:#000;background-color:#facc15}.share-btn:hover{background-color:#eab308}.action-btn:active{transform:scale(.98)}.secondary-actions{gap:12px;display:flex}.btn-approve,.btn-reject,.btn-primary,.btn-secondary{width:100%;padding:var(--radius);font-weight:800;font-size:var(--radius);border-radius:var(--radius);cursor:pointer;text-transform:uppercase;border:none;justify-content:center;align-items:center;gap:8px;transition:all .2s;display:flex}.btn-primary{background:var(--accent);color:var(--primary);box-shadow:0 4px 0 var(--accent-dark)}.btn-primary:active{box-shadow:0 2px 0 var(--accent-dark);transform:translateY(2px)}.btn-approve{background:var(--primary);color:var(--white);box-shadow:0 4px 0 var(--primary-dark)}.btn-secondary,.btn-reject{color:var(--primary);background:#f2f2f2;flex:1}.btn-secondary:hover,.btn-reject:hover{background:#e6e6e6}.gallery-section{max-width:1240px;margin:60px auto;padding:0 20px}.gallery-header{margin-bottom:40px}.badge{padding:8px var(--radius);color:var(--primary);margin-bottom:var(--radius);background:#fff;border-radius:20px;align-items:center;gap:8px;font-weight:700;display:inline-flex;box-shadow:0 4px 12px #0000000d}.gallery-title{color:var(--primary);font-size:36px;font-weight:800}.gallery-grid{grid-template-columns:repeat(4,1fr);gap:24px;width:100%;display:grid}@media (width<=1100px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=800px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=500px){.gallery-grid{gap:var(--radius);grid-template-columns:repeat(1,1fr)}}.gallery-item{background:#fff;border-radius:24px;transition:transform .3s;overflow:hidden;box-shadow:0 10px 30px #0000000d}.gallery-item:hover{transform:translateY(-5px)}.gallery-item img{width:100%;height:auto;display:block}.gallery-image-container{aspect-ratio:1;width:100%;position:relative;overflow:hidden}.gallery-image-container img{object-fit:cover;width:100%;height:100%;transition:transform .5s}.gallery-item:hover img{transform:scale(1.05)}.gallery-item-overlay{padding:var(--radius);opacity:0;background:linear-gradient(#0000 60%,#0006 100%);justify-content:flex-end;align-items:flex-end;gap:12px;transition:opacity .3s;display:flex;position:absolute;inset:0}.gallery-item:hover .gallery-item-overlay{opacity:1}.gallery-icon-btn{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;transition:all .2s;display:flex}.gallery-icon-btn svg{width:22px;height:22px}.gallery-icon-btn:hover{background:#fff6;transform:translateY(-2px)}.gallery-icon-btn.delete-btn:hover{background:#ef4444;border-color:#ef4444}@media (width<=768px){.gallery-item-overlay{opacity:1;background:linear-gradient(#0000 70%,#0000004d 100%)}.gallery-icon-btn{width:36px;height:36px}}.footer{text-align:center;color:#fff;background:#111827;margin-top:auto;padding:60px 20px}.footer-logo{height:50px;margin-bottom:20px}.footer-text{color:#fff;margin-bottom:10px;font-size:20px;font-weight:700}.footer p{color:#9ca3af;font-size:14px}.footer .tagline{color:#9ca3af;font-size:var(--radius);font-weight:400}@media (width<=768px){.hero{background:#1835ab;max-height:none;padding:40px 20px 60px}.hero-container{flex-direction:column;align-items:center;gap:0;display:flex}.hero-text-content,.dragon-mascot-container{display:contents}.school-shield-container{order:1;justify-content:center;width:100%;margin-bottom:24px;display:flex}.school-shield{height:80px}.headline{font-size:var(--radius-btn);color:#fff;text-align:center;order:2;max-width:300px;margin-bottom:12px}.subtitle{color:#cbccfa;text-align:center;order:3;max-width:320px;margin-bottom:20px;font-size:18px;line-height:1.4}.dragon-mascot{filter:none;order:4;width:280px;height:auto;margin-bottom:20px}.upload-container{width:100%;margin-bottom:var(--radius);order:5;justify-content:center;display:flex}.btn-upload{border-radius:var(--radius-btn);background:#ffb800;border:none;width:280px;height:64px;padding:0;font-size:18px;box-shadow:0 4px #121a3d}.tagline{color:#fff;text-align:center;order:6;font-size:22px;font-weight:700}.hero-bg-elements{display:none}}@media (width<=480px){.headline{font-size:28px}.dragon-mascot{width:220px;margin-bottom:20px}}.hide-mobile{display:none}@media (width<=640px){.modal-content{border-radius:24px;width:95%;max-height:95vh}.photobooth-interface{padding:20px}.modal-actions{flex-direction:column;gap:12px;width:100%;padding-bottom:20px}.action-btn{justify-content:center;width:100%;height:56px}.viewfinder{height:250px}.hide-mobile{display:none}}.filter-selection-area{width:100%;margin-top:15px}.filter-label{color:#666;text-transform:uppercase;letter-spacing:1px;text-align:center;margin-bottom:8px;font-size:12px;font-weight:700}.filter-options{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.filter-card{cursor:pointer;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:6px;transition:all .2s;display:flex}.filter-card span{color:#475569;font-size:11px;font-weight:700}.filter-preview{border-radius:6px;width:100%;height:40px}.filter-preview.party{background:linear-gradient(135deg,gold,orange)}.filter-preview.pinata{background:linear-gradient(135deg,#ff69b4,#9b59b6)}.filter-preview.balloons{background:linear-gradient(135deg,#3498db,#2ecc71)}.filter-card.active{background:#eff6ff;border-color:#1835ab;transform:translateY(-2px);box-shadow:0 4px 12px #1835ab26}.filter-card.active span{color:#1835ab}@media (width<=480px){.filter-options{gap:8px}.filter-card{padding:8px}.filter-card span{font-size:11px}}
