*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#333;background:linear-gradient(#f5f5f5 0%,#e0e0e0 100%);height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;overflow:hidden}#app{height:100%}.main-layout{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.camera-section{background:#000;flex:1;min-height:50vh;position:relative;overflow:hidden}.camera-section video,.camera-section canvas{object-fit:cover;background:linear-gradient(#f5f5f5 0%,#e0e0e0 100%);width:100%;height:100%;position:absolute;top:0;left:0}.camera-section video{z-index:1;opacity:0;pointer-events:none}.camera-section canvas{z-index:2}.gallery-section{z-index:500;background:#f5f5f5;border-top-left-radius:20px;border-top-right-radius:20px;width:100%;height:75vh;max-height:75vh;padding:28px 16px 16px;transition:transform .3s ease-out;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;transform:translateY(calc(100% - 80px));box-shadow:0 -4px 16px #00000026}.gallery-section:before{content:"";background:#999;border-radius:2px;width:48px;height:4px;position:absolute;top:10px;left:50%;transform:translate(-50%)}.gallery-header{cursor:pointer;-webkit-user-select:none;user-select:none}.main-layout.gallery-open .gallery-section{transform:translateY(0)}.gallery-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.gallery-header h2{color:#333;font-size:18px;font-weight:600}.photo-count{color:#666;font-size:14px}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;display:grid}.gallery-item{aspect-ratio:1;cursor:pointer;background:#ddd;border-radius:0;position:relative;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;display:block}.gallery-item:hover{transition:transform .2s;transform:scale(1.02)}.gallery-empty{text-align:center;color:#888;padding:40px 20px}.gallery-actions{justify-content:center;gap:12px;display:flex}.action-btn{color:#fff;cursor:pointer;background:#333;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 20px;font-size:14px;font-weight:500;transition:background .2s,transform .1s;display:flex}.action-btn:hover{background:#555}.action-btn:active{transform:scale(.98)}.action-btn:disabled{cursor:not-allowed;background:#ccc}.btn-icon{font-size:16px}.hidden{display:none!important}.modal{z-index:1000;justify-content:center;align-items:center;width:100vw;height:100vh;display:flex;position:fixed;top:0;left:0}.modal-backdrop{background:#000000eb;width:100%;height:100%;position:absolute;top:0;left:0}.modal-content{z-index:1;flex-direction:column;align-items:center;max-width:90vw;max-height:90vh;display:flex;position:relative}.modal-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:8px;font-size:32px;line-height:1;position:absolute;top:-40px;right:0}.modal-nav{color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;z-index:2;padding:20px;font-size:48px;position:absolute;top:50%;transform:translateY(-50%)}.modal-prev{left:-60px}.modal-next{right:-60px}.modal-nav:hover{color:#ccc}.modal-photo-container{justify-content:center;align-items:center;max-width:100%;max-height:65vh;display:flex}.modal-photo-container img{object-fit:contain;border-radius:8px;max-width:100%;max-height:65vh}.modal-info{text-align:center;margin-top:20px}.modal-timestamp{color:#aaa;margin-bottom:16px;font-size:15px}.modal-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.flash-overlay{opacity:0;pointer-events:none;z-index:9999;background:#fff;width:100vw;height:100vh;position:fixed;top:0;left:0}.flash-overlay.active{animation:.15s ease-out flash}@keyframes flash{0%{opacity:0}40%{opacity:1}to{opacity:0}}.toast{color:#fff;z-index:10000;text-align:center;background:#000000d9;border-radius:12px;max-width:90vw;padding:14px 28px;font-size:14px;transition:transform .3s ease-out;position:fixed;bottom:24px;left:50%;transform:translate(-50%)translateY(100px)}.toast.visible{transform:translate(-50%)translateY(0)}.gallery-backdrop{display:none}@media (width>=768px){.main-layout{flex-direction:column;justify-content:center;align-items:center}.camera-section{border-radius:0;flex:none;width:100%;max-width:700px;height:100vh;min-height:0;max-height:100vh}.gallery-section{z-index:500;border-left:1px solid #ddd;border-radius:0;width:420px;max-width:90vw;height:100vh;max-height:100vh;padding:16px;transition:transform .3s ease-out;position:fixed;inset:0 0 auto auto;transform:translate(100%);box-shadow:-8px 0 24px #00000040}.gallery-section:before{display:none}.gallery-header{cursor:default}.main-layout.gallery-open .gallery-section{transform:translate(0)}.gallery-backdrop{opacity:0;pointer-events:none;z-index:499;background:#0006;width:100vw;height:100vh;transition:opacity .3s ease-out;display:block;position:fixed;top:0;left:0}.main-layout.gallery-open .gallery-backdrop{opacity:1;pointer-events:auto}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}}@media (width>=1200px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=480px){.modal-prev{left:-20px}.modal-next{right:-20px}.modal-nav{padding:15px;font-size:36px}.gallery-actions{flex-direction:column}.action-btn{justify-content:center;width:100%}}
