:root{--bg-deep:#fbfaf7;--bg-mid:#fff;--cream:#fafaf8;--surface-card:#fff;--surface-hover:#f2f2f2;--accent-bg-soft:#fff4e3;--border-soft:#e5e7eb;--gold:#c98a2e;--gold-light:#d97706;--gold-dim:#c98a2e80;--accent-text:#92400e;--coral:#f9735b;--coral-soft:#ffe8e2;--coral-deep:#c03a22;--sky:#60a5fa;--sky-soft:#eaf3ff;--mint:#34d399;--mint-soft:#e8fff5;--amber:#f59e0b;--amber-soft:#fef3c7;--text-primary:#1c1c1e;--text-secondary:#6e6e73;--text-muted:#73737a;--glass-bg:#ffffffbf;--glass-border:#e5e2da;--glass-blur:blur(24px) saturate(1.1);--shadow-soft:0 1px 2px #1c1c1e0a, 0 6px 24px #1c1c1e14;--transition-smooth:.35s cubic-bezier(.25, .1, .25, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-deep);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{width:100%;min-height:100vh}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.dashboard-header{z-index:50;background:0 0;flex-shrink:0;justify-content:center;align-items:center;padding:1.5rem 2rem 1.1rem;display:flex;position:relative}.dashboard-header-left{text-align:center;flex-direction:column;align-items:center;display:flex}.dashboard-title{color:var(--text-primary);letter-spacing:-.015em;font-family:Playfair Display,serif;font-size:clamp(1.8rem,3.2vw,2.8rem);font-weight:700;line-height:1.15}.dashboard-title-60{color:var(--coral-deep)}.dashboard-subtitle{color:var(--text-secondary);letter-spacing:.04em;margin-top:8px;font-family:Inter,sans-serif;font-size:clamp(.78rem,1.1vw,.95rem);font-weight:400}.dashboard-title-accent{background:linear-gradient(90deg, var(--coral) 0%, var(--amber) 100%);opacity:.85;border-radius:2px;width:72px;height:3px;margin-top:12px;display:block}.dashboard-header-actions{align-items:center;gap:.6rem;display:flex;position:absolute;top:50%;right:1.5rem;transform:translateY(-50%)}.photo-count{color:var(--text-secondary);letter-spacing:.01em;background:var(--surface-card);border:1px solid var(--border-soft);border-radius:999px;padding:.4rem .85rem;font-family:Inter,sans-serif;font-size:.92rem;font-weight:600;box-shadow:0 1px 2px #1c1c1e0a}.slideshow-btn{background:var(--amber-soft);color:var(--coral-deep);cursor:pointer;letter-spacing:.01em;border:1px solid #f59e0b59;border-radius:999px;padding:.55rem 1.2rem;font-family:Inter,sans-serif;font-size:.92rem;font-weight:600;transition:all .2s;box-shadow:0 1px 2px #1c1c1e0a}.slideshow-btn:hover{border-color:var(--amber);background:#fcebc3;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b2e}.reset-btn{background:var(--surface-card);width:40px;height:40px;color:var(--text-secondary);border:1px solid var(--glass-border);cursor:pointer;border-radius:999px;justify-content:center;align-items:center;font-size:1.15rem;transition:all .2s;display:flex;box-shadow:0 1px 2px #1c1c1e0a}.reset-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:#d9d5cc}.pause-btn{background:var(--surface-card);width:40px;height:40px;color:var(--text-secondary);border:1px solid var(--glass-border);cursor:pointer;letter-spacing:-.05em;border-radius:999px;justify-content:center;align-items:center;font-size:.8rem;transition:all .2s;display:flex;box-shadow:0 1px 2px #1c1c1e0a}.pause-btn:hover{background:var(--surface-hover);color:var(--text-primary);border-color:#d9d5cc}.pause-btn.paused{background:var(--coral-soft);color:var(--coral-deep);border-color:#f9735b59}.pause-btn.paused:hover{background:#ffd7cc}.qr-floating-card{z-index:40;position:fixed;bottom:1.5rem;left:1.5rem}.qr-container{background:var(--surface-card);text-align:center;border:1px solid var(--border-soft);border-radius:18px;align-items:center;gap:1rem;padding:.85rem 1.25rem .85rem 1.45rem;display:flex;position:relative;overflow:hidden;box-shadow:0 1px 2px #1c1c1e0a,0 8px 32px #1c1c1e14}.qr-container:before{content:"";background:linear-gradient(180deg, var(--coral) 0%, var(--amber) 100%);border-radius:2px;width:3px;position:absolute;top:12px;bottom:12px;left:0}.qr-dismiss{background:var(--surface-hover);width:22px;height:22px;color:var(--text-muted);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:.55rem;transition:all .2s;display:flex;position:absolute;top:.35rem;right:.35rem}.qr-dismiss:hover{color:var(--text-primary);background:#e5e2da}.qr-pill{background:var(--surface-card);border:1px solid var(--glass-border);color:var(--text-primary);cursor:pointer;letter-spacing:.02em;border-radius:24px;padding:.5rem 1.1rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;transition:all .2s;box-shadow:0 2px 8px #1c1c1e0f}.qr-pill:hover{background:var(--surface-hover);border-color:#d9d5cc}.qr-text{text-align:left}.qr-title{color:var(--text-primary);align-items:center;gap:.4rem;margin-bottom:.15rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;display:flex}.qr-title-icon{color:var(--coral);flex-shrink:0}.qr-subtitle{color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.75rem}.qr-code-wrapper{background:#fff;border-radius:8px;flex-shrink:0;padding:0;line-height:0;display:inline-block}.qr-hero{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.qr-hero-card{text-align:center;background:var(--surface-card);border:1px solid var(--glass-border);white-space:nowrap;border-radius:28px;flex-direction:column;align-items:center;min-width:380px;padding:3rem 4rem;display:flex;position:relative;box-shadow:0 1px 3px #1c1c1e0a,0 12px 48px #1c1c1e14}.qr-hero-glow{pointer-events:none;background:radial-gradient(#d977060f 0%,#d9770605 50%,#0000 75%);border-radius:60px;animation:5s ease-in-out infinite heroGlow;position:absolute;inset:-40px}@keyframes heroGlow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.04)}}.qr-hero-title{color:var(--text-primary);letter-spacing:-.01em;margin-bottom:.5rem;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700}.qr-hero-subtitle{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:2rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:400}.qr-hero-code{background:#fff;border-radius:18px;padding:0;line-height:0;display:inline-block;box-shadow:0 1px 3px #1c1c1e0d,0 6px 20px #1c1c1e14}.qr-hero-hint{color:var(--coral-deep);letter-spacing:.04em;margin-top:1.5rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600}@media (prefers-reduced-motion:reduce){.qr-hero-glow{opacity:.7;animation:none}}.dashboard{height:100vh;color:var(--text-primary);background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Ccircle cx='40' cy='60' r='2' fill='%23F9735B' opacity='0.10'/%3E%3Ccircle cx='160' cy='30' r='1.6' fill='%2360A5FA' opacity='0.10'/%3E%3Ccircle cx='250' cy='90' r='2' fill='%2334D399' opacity='0.10'/%3E%3Ccircle cx='90' cy='180' r='1.7' fill='%23F59E0B' opacity='0.11'/%3E%3Ccircle cx='220' cy='230' r='1.5' fill='%23F9735B' opacity='0.10'/%3E%3Ccircle cx='30' cy='270' r='1.8' fill='%2360A5FA' opacity='0.10'/%3E%3C/svg%3E"), var(--bg-deep);flex-direction:column;display:flex;position:relative;overflow:hidden}.dashboard:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(35% 30% at 85% 18%,#f9735b1a 0%,#0000 70%),radial-gradient(30% 28% at 12% 80%,#60a5fa14 0%,#0000 70%),radial-gradient(32% 28% at 78% 75%,#34d39912 0%,#0000 70%);position:fixed;inset:0}.dashboard>*{z-index:1;position:relative}.dashboard-body{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative}.dashboard-main{width:100%;height:100%;overflow:hidden}.polaroid-card{padding:calc(var(--card-size,200px) * .045);transform:rotate(var(--rotation,0deg));transition:transform var(--transition-smooth,.35s ease), box-shadow var(--transition-smooth,.35s ease);will-change:transform;background:linear-gradient(175deg,#fff 0%,#fafaf8 100%);border-radius:3px;padding-bottom:0;position:relative;box-shadow:0 1px 2px #1c1c1e0d,0 4px 12px #1c1c1e14,0 12px 32px #1c1c1e1f,0 24px 56px #1c1c1e1a}.polaroid-card:hover{transform:rotate(var(--rotation,0deg)) translateY(-5px);z-index:10;box-shadow:0 2px 6px #1c1c1e0f,0 8px 20px #1c1c1e1a,0 20px 40px #1c1c1e24,0 32px 64px #1c1c1e29}.polaroid-image-wrapper{aspect-ratio:1;background:#f5f5f5;border-radius:1px;width:100%;overflow:hidden;box-shadow:inset 0 1px 3px #1c1c1e0f}.polaroid-image-wrapper img{object-fit:contain;opacity:0;background:#fafaf8;width:100%;height:100%;transition:opacity .5s;display:block}.polaroid-image-wrapper img.loaded{opacity:1}.polaroid-caption-area{height:calc(var(--card-size,200px) * .22);min-height:1.5rem;padding:0 calc(var(--card-size,200px) * .04);justify-content:center;align-items:center;display:flex;overflow:hidden}.polaroid-caption{font-family:Inter,sans-serif;font-size:calc(clamp(.5rem, calc(var(--card-size,200px) * .04), 2rem) * var(--caption-scale,1));color:#4b5563;text-align:center;letter-spacing:.01em;text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:0;font-weight:500;line-height:1.3;display:-webkit-box;overflow:hidden}@media (prefers-reduced-motion:reduce){.polaroid-card,.polaroid-card:hover{transition:none}.polaroid-image-wrapper img{opacity:1;transition:none}}.polaroid-tape{pointer-events:none;z-index:5;background-image:linear-gradient(90deg,#0000 0%,#ffffff59 50%,#0000 100%);width:30%;height:5.5%;position:absolute;box-shadow:0 1px 3px #1c1c1e1f}.polaroid-tape--coral{background-color:#f9735b66}.polaroid-tape--sky{background-color:#60a5fa66}.polaroid-tape--mint{background-color:#34d39966}.polaroid-tape--amber{background-color:#f59e0b73}.polaroid-tape--top-left{top:-1.5%;left:8%;transform:rotate(-8deg)}.polaroid-tape--top-center{top:-2%;left:35%;transform:rotate(2deg)}.polaroid-tape--top-right{top:-1.5%;right:8%;transform:rotate(7deg)}.memory-wall{width:100%;height:100%;position:relative;overflow:hidden}.memory-card{left:var(--x);top:var(--y);transform:translate(-50%, -50%) rotate(var(--rotation,0deg)) scale(var(--scale,1));cursor:pointer;filter:brightness();transition:left .8s,top .8s,width .8s,transform .8s,filter .5s,opacity .5s;position:absolute}.memory-card.entering{opacity:0;transform:translate(-50%, -50%) rotate(var(--rotation,0deg)) scale(calc(var(--scale,1) * .8))}.memory-card.spotlight{transform:translate(-50%, -50%) rotate(var(--rotation,0deg)) scale(calc(var(--scale,1) * 1.06));filter:brightness(1.08)}.memory-card.spotlight .polaroid-card{box-shadow:0 1px 2px #1c1c1e0d,0 6px 16px #1c1c1e1a,0 16px 40px #1c1c1e24,0 28px 64px #1c1c1e1f,0 0 48px #f9735b1f}@media (prefers-reduced-motion:reduce){.memory-card,.memory-card.spotlight{transition:none}}.cam-anchor{z-index:60;pointer-events:none;perspective:600px;position:fixed;top:68px;left:32px;transform:rotate(-10deg)}.cam-body-outer{filter:drop-shadow(0 8px 24px #00000080);width:230px;transform-style:preserve-3d;transform:rotateY(8deg)rotateX(4deg)}.cam-face{background:linear-gradient(#2e2e2e 0%,#242424 40%,#282828 100%);border-radius:12px 12px 4px 4px;padding:10px 12px 6px;position:relative;transform:translateZ(12px);box-shadow:inset 0 1px #ffffff1a,6px 0 #1a1a1a,-2px 0 #222,6px 4px #141414,-2px 4px #1c1c1c,6px 8px #111,8px 12px 24px #0000004d}.cam-face:after{content:"";transform-origin:0;background:linear-gradient(#1e1e1e,#161616);border-radius:0 3px 3px 0;width:7px;height:calc(100% - 8px);position:absolute;top:4px;right:-7px;transform:rotateY(90deg)}.cam-face:before{content:"";transform-origin:bottom;background:linear-gradient(#333,#2a2a2a);border-radius:10px 10px 0 0;height:5px;position:absolute;top:-5px;left:4px;right:4px;transform:rotateX(90deg)}.cam-top-row{justify-content:space-between;align-items:center;gap:6px;margin-bottom:6px;display:flex}.cam-flash-well{background:#1a1a1a;border-radius:4px;place-items:center;width:38px;height:34px;display:grid;box-shadow:inset 0 1px 3px #0009}.cam-fresnel{background:linear-gradient(145deg,#e0ddd8,#b8b4ae);border-radius:2px;place-items:center;width:28px;height:24px;display:grid;overflow:hidden}.fresnel-lines{background:repeating-linear-gradient(0deg,#0000 0 1.5px,#0000000d 1.5px 2px),repeating-linear-gradient(90deg,#0000 0 1.5px,#0000000d 1.5px 2px);width:100%;height:100%}.cam-lens-bezel{background:linear-gradient(145deg,#3a3a3a,#1a1a1a);border-radius:50%;place-items:center;width:68px;height:68px;display:grid;transform:translateZ(6px);box-shadow:0 0 0 2px #161616,0 3px 6px #0006}.cam-lens-ring{background:linear-gradient(145deg,#444,#222);border-radius:50%;place-items:center;width:56px;height:56px;display:grid;box-shadow:inset 0 1px 3px #00000080}.cam-lens-text-ring{background:#181820;border-radius:50%;place-items:center;width:46px;height:46px;display:grid;box-shadow:inset 0 1px 4px #0009}.cam-lens-glass{background:radial-gradient(circle at 35% 30%,#2a2a50,#080814);border-radius:50%;width:32px;height:32px;position:relative;box-shadow:inset 0 0 8px #000000b3,0 0 4px #3c64b414}.cam-lens-flare{filter:blur(2px);background:#8cb4ff26;border-radius:50%;width:10px;height:7px;position:absolute;top:5px;left:7px;transform:rotate(-25deg)}.cam-vf-well{background:#141414;border-radius:4px;place-items:center;width:38px;height:34px;display:grid;box-shadow:inset 0 1px 3px #000000b3}.cam-vf-glass{background:linear-gradient(145deg,#1a1a22,#0a0a10);border-radius:3px;width:28px;height:24px;box-shadow:inset 0 1px 3px #00000080}.cam-mid-row{justify-content:space-between;align-items:center;padding:3px 3px 4px;display:flex}.cam-shutter-btn{background:radial-gradient(circle at 40% 35%,#f44,#c22);border-radius:50%;width:20px;height:20px;box-shadow:0 1px 3px #00000080}.cam-rainbow-stripe{background:linear-gradient(90deg,#e53935 0% 16%,#fb8c00 16% 33%,#fdd835 33% 50%,#43a047 50% 66%,#1e88e5 66% 83%,#6a1b9a 83%);border-radius:2px;width:14px;height:28px}.cam-plus-btn{color:#48d;background:#1a1a1a;border:1px solid #333;border-radius:4px;place-items:center;width:16px;height:16px;font-size:.6rem;display:grid}.cam-brand-row{justify-content:space-between;padding:2px 4px 0;display:flex}.cam-brand-name{color:#ffffff4d;font-family:Inter;font-size:.38rem}.cam-brand-model{color:#ffffff40;font-family:Inter;font-size:.34rem;font-weight:700}.cam-tray{background:linear-gradient(#1c1c1c,#141414);border-radius:0 0 8px 8px;justify-content:center;padding:5px 10px 8px;display:flex;position:relative;transform:translateZ(8px);box-shadow:6px 0 #121212,-2px 0 #1a1a1a,6px 4px #0e0e0e,0 4px 8px #0000004d}.cam-tray:after{content:"";background:linear-gradient(#171717,#111);border-radius:0 3px 3px 0;width:6px;height:100%;position:absolute;top:0;right:-6px}.cam-slot{background:#050505;border-radius:2px;width:150px;height:4px;box-shadow:inset 0 1px 3px #000000e6}.print-backdrop{z-index:85;-webkit-backdrop-filter:blur(6px);pointer-events:none;background:#0a080699;position:fixed;inset:0}.print-flash{z-index:100;pointer-events:none;background:radial-gradient(circle at 55px 95px,#fffcf0e6 0%,#fff8dc80 8%,#0000 30%);position:fixed;inset:0}.anim-photo-wrapper{pointer-events:none;filter:drop-shadow(0 8px 28px #00000059);transition:left 1s,top 1s,width 1s,transform 1s,opacity .4s}.anim-clip{overflow:hidden}.anim-card-border{padding:calc(var(--card-size,300px) * .045);background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cfilter id='p'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100' height='100' filter='url(%23p)' opacity='0.015'/%3E%3C/svg%3E"),linear-gradient(175deg,#f6f1e9,#f0ebe2);border-radius:3px;padding-bottom:0}.anim-image-area{aspect-ratio:1;background:#e8e2d8;border-radius:1px;width:100%;position:relative;overflow:hidden}.anim-img{object-fit:contain;filter:saturate(.2)brightness(1.3)blur(2px);opacity:.4;background:#f4efe6;width:100%;height:100%;transition:filter 2s,opacity 2s;display:block}.anim-img.developed{filter:saturate()brightness()blur();opacity:1}.anim-silver{z-index:2;opacity:1;background:linear-gradient(120deg,#fff0 25%,#ffffff1f 45%,#fff0 55%) 0 0/300% 100%,linear-gradient(175deg,#bab6ae,#a8a49c 30%,#9a968e 60%,#b0aca4) 0 0/100% 100%;border-radius:1px;transition:opacity 2s;animation:2.5s ease-in-out infinite shimmer;position:absolute;inset:0}@keyframes shimmer{0%{background-position:150% 0,0 0}to{background-position:-150% 0,0 0}}.anim-silver.fade{opacity:0;animation:none}.anim-caption-area{height:calc(var(--card-size,300px) * .22);min-height:1.2rem;padding:0 calc(var(--card-size,300px) * .04);justify-content:center;align-items:center;display:flex}.anim-caption{color:#3c281499;text-align:center;font-family:Inter;font-weight:400;line-height:1.3;font-size:calc(clamp(.4rem, calc(var(--card-size,300px) * .04), 1.4rem) * var(--caption-scale,1));margin:0}@media (height<=800px){.cam-body-outer{width:170px}.cam-slot{width:110px}.cam-lens-bezel{width:56px;height:56px}.cam-lens-ring{width:46px;height:46px}.cam-lens-text-ring{width:38px;height:38px}.cam-lens-glass{width:26px;height:26px}.anim-photo.phase-flying-in,.anim-photo.phase-previewing{width:260px}}@media (prefers-reduced-motion:reduce){.anim-photo{transition:none!important}.anim-clip.emerging{max-height:600px;animation:none}.anim-silver{animation:none}.anim-img{filter:none;opacity:1;transition-duration:.3s}}.print-mask{filter:drop-shadow(0 6px 20px #0000004d)}.print-sliding-card{transform:translateY(calc(-1 * var(--card-h,400px)))}.print-sliding-card.sliding{animation:4s forwards slideFromSlot}.print-sliding-card.slid{transform:translateY(0)}@keyframes slideFromSlot{0%{transform:translateY(calc(-1 * var(--card-h,400px)))}to{transform:translateY(0)}}.center-photo{filter:drop-shadow(0 10px 36px #0006)}@media (prefers-reduced-motion:reduce){.print-sliding-card.sliding{animation:none;transform:translateY(0)}}.fly-photo{z-index:90;pointer-events:none;filter:drop-shadow(0 8px 28px #00000059);position:fixed}.fly-photo .anim-card{width:100%;container-type:inline-size}.fly-photo .anim-card-border{padding:4.5% 4.5% 0}.fly-photo .anim-caption-area{height:0;min-height:0;padding-top:22%;position:relative}.fly-photo .anim-caption{font-size:calc(4cqi * var(--caption-scale,1));justify-content:center;align-items:center;padding:0 4%;display:flex;position:absolute;inset:0}.slideshow-overlay{z-index:200;-webkit-backdrop-filter:blur(20px);background:#0a0806f0;position:fixed;inset:0}.slideshow-stage{place-items:center;padding:clamp(16px,2vh,32px) clamp(16px,3vw,48px);display:grid;position:absolute;inset:0}.slideshow-content{transition:max-width .35s,max-height .35s}.slideshow-content.size-m{--card-size:min(68vw, 640px);max-width:min(68vw,640px);max-height:68vh}.slideshow-content.size-l{--card-size:min(78vw, 860px);max-width:min(78vw,860px);max-height:78vh}.slideshow-content.size-xl{--card-size:min(90vw, 1200px);max-width:min(90vw,1200px);max-height:86vh}.slideshow-card{filter:drop-shadow(0 12px 48px #0006)}.slideshow-close{color:#ffffff80;cursor:pointer;z-index:220;background:#ffffff0f;border:1px solid #ffffff0d;border-radius:50%;justify-content:center;align-items:center;width:2.2rem;height:2.2rem;font-size:1.1rem;transition:opacity .28s,transform .28s,background .15s;display:flex;position:absolute;top:1.25rem;right:1.25rem}.slideshow-close:hover{color:#fffc;background:#ffffff1f}.slideshow-close.hidden{opacity:0;pointer-events:none;transform:translateY(-8px)}.slideshow-counter{color:#ffffff4d;z-index:220;letter-spacing:.08em;font-family:Inter,sans-serif;font-size:.72rem;font-weight:400;transition:opacity .28s,transform .28s;position:absolute;top:1.5rem;left:50%;transform:translate(-50%)}.slideshow-counter.hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(-8px)}.slideshow-controls{bottom:max(1.5rem, env(safe-area-inset-bottom,0px));-webkit-backdrop-filter:blur(24px);z-index:220;background:#00000073;border:1px solid #ffffff0a;border-radius:16px;align-items:center;gap:1.25rem;padding:.5rem 1.25rem;transition:opacity .28s,transform .28s;display:flex;position:absolute;left:50%;transform:translate(-50%)}.slideshow-controls.hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(20px)}.slideshow-controls-main{align-items:center;gap:.25rem;display:flex}.slideshow-nav-btn{color:#ffffff80;cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;width:2.2rem;height:2.2rem;font-family:Inter,sans-serif;font-size:1.4rem;transition:all .15s;display:flex}.slideshow-nav-btn:hover:not(:disabled){color:#ffffffd9;background:#ffffff0f}.slideshow-nav-btn:disabled{opacity:.2;cursor:default}.slideshow-play-btn{color:#fffc;cursor:pointer;letter-spacing:-.05em;background:#ffffff14;border:1px solid #ffffff14;border-radius:50%;justify-content:center;align-items:center;width:2.5rem;height:2.5rem;font-size:.75rem;transition:all .15s;display:flex}.slideshow-play-btn:hover{color:#fff;background:#ffffff24}.slideshow-controls-group{align-items:center;gap:.25rem;display:flex}.slideshow-control-label{color:#ffffff40;text-transform:uppercase;letter-spacing:.08em;margin-right:.25rem;font-family:Inter,sans-serif;font-size:.6rem;font-weight:500}.slideshow-option{color:#ffffff59;cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;min-height:28px;padding:.3rem .55rem;font-family:Inter,sans-serif;font-size:.7rem;font-weight:500;transition:all .15s}.slideshow-option:hover{color:#fff9;background:#ffffff0a}.slideshow-option.active{color:#ffffffd9;background:#ffffff1a;border-color:#ffffff14}@media (prefers-reduced-motion:reduce){.slideshow-controls,.slideshow-close,.slideshow-counter,.slideshow-content{transition:none}}.cropper-container{flex-direction:column;gap:.6rem;width:100%;display:flex;position:relative}.cropper-container .reactEasyCrop_Container{aspect-ratio:1;border-radius:14px;width:100%;overflow:hidden;position:relative!important}.cropper-controls{justify-content:center;align-items:center;gap:.75rem;padding:.2rem 0;display:flex}.fit-toggle{border:1.5px solid var(--form-border,#e8dfd4);color:var(--form-text-muted,#9a8a78);cursor:pointer;background:#fff9;border-radius:8px;min-height:32px;padding:.35rem .8rem;font-family:Inter,sans-serif;font-size:.75rem;font-weight:600;transition:all .2s}.fit-toggle:hover{color:var(--form-text,#2c1a10);background:#fffc}.fit-toggle.active{background:var(--form-accent,#c49a64);border-color:var(--form-accent-strong,#b8834a);color:#fff}.zoom-label{color:var(--form-text-muted,#9a8a78);align-items:center;gap:.6rem;font-family:Inter,sans-serif;font-size:.75rem;display:flex}.zoom-slider{width:120px;accent-color:var(--form-accent,#c49a64);height:3px}.submit-form{--form-bg:linear-gradient(170deg, #fbfaf7 0%, #fff4e3 50%, #ffe8e2 100%);--form-surface:#fff;--form-surface-hover:#f2f2f2;--form-text:#1c1c1e;--form-text-muted:#6e6e73;--form-text-faint:#9a9a9f;--form-accent:#f9735b;--form-accent-strong:#c03a22;--form-border:#e5e7eb;--form-radius-card:20px;--form-radius-btn:14px;--form-shadow-card:0 2px 16px #1c1c1e0a, 0 8px 40px #1c1c1e14;background:var(--form-bg);min-height:100svh;padding:2rem 1.25rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px));flex-direction:column;justify-content:center;align-items:center;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;display:flex}.submit-card{background:var(--form-surface);border-radius:var(--form-radius-card);width:100%;max-width:460px;box-shadow:var(--form-shadow-card);flex-direction:column;gap:1.5rem;padding:2rem 1.75rem;display:flex}.submit-header{text-align:center}.submit-header h1{color:var(--form-text);letter-spacing:-.01em;margin:0 0 .3rem;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700}.submit-header .form-subtitle{color:var(--form-accent);margin:0 0 .3rem;font-family:Inter,sans-serif;font-size:.85rem;font-weight:400}.submit-header .form-helper{color:var(--form-text-muted);margin:0;font-family:Inter,sans-serif;font-size:.78rem;font-weight:300;line-height:1.4}.submit-content{flex-direction:column;gap:1rem;width:100%;display:flex}.file-upload-area{width:100%}.file-upload-label{border:2px dashed var(--form-border);cursor:pointer;background:#ffffff80;border-radius:16px;flex-direction:column;align-items:center;gap:.5rem;min-height:44px;padding:2.5rem 2rem;transition:all .25s;display:flex}.file-upload-label:hover,.file-upload-label:focus-within{border-color:var(--form-accent);background:#fffc}.upload-icon{width:40px;height:40px;color:var(--form-accent);background:#f9735b1f;border-radius:50%;justify-content:center;align-items:center;font-size:1.2rem;display:flex}.upload-text{color:var(--form-text);font-size:.95rem;font-weight:600}.upload-hint{color:var(--form-text-faint);font-size:.72rem}.file-input-hidden{display:none}.caption-group{width:100%}.caption-input{border:1.5px solid var(--form-border);width:100%;color:var(--form-text);box-sizing:border-box;background:#fff;border-radius:12px;outline:none;min-height:44px;padding:.9rem 1rem;font-family:Inter,sans-serif;font-size:1rem;transition:all .25s}.caption-input:focus{border-color:var(--form-accent);box-shadow:0 0 0 3px #f9735b1f}.caption-input::placeholder{color:var(--form-text-faint)}.form-actions{gap:.75rem;display:flex}.btn{border-radius:var(--form-radius-btn);cursor:pointer;border:none;flex:1;min-height:48px;padding:.9rem 1.5rem;font-family:Inter,sans-serif;font-size:.95rem;font-weight:600;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--form-accent) 0%, var(--form-accent-strong) 100%);color:#fff;box-shadow:0 2px 8px #c03a222e}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #c03a2247}.btn-secondary{color:var(--form-text-muted);border:1.5px solid var(--form-border);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--form-surface-hover)}.upload-progress{background:var(--form-border);border-radius:2px;width:100%;height:3px;overflow:hidden}.upload-progress-bar{background:linear-gradient(90deg, var(--form-accent), var(--form-accent-strong));border-radius:2px;height:100%;transition:width .3s;animation:1.5s ease-in-out infinite progressPulse}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.6}}.error-message{color:#b91c1c;text-align:center;background:#b91c1c0f;border-radius:10px;margin:0;padding:.7rem 1rem;font-size:.85rem}.success-screen{text-align:center;padding:1.5rem 0 .5rem}.success-mark{background:linear-gradient(135deg, var(--form-accent) 0%, var(--form-accent-strong) 100%);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 1rem;animation:.5s cubic-bezier(.175,.885,.32,1.275) successPop;display:flex}.success-mark svg{width:24px;height:24px}@keyframes successPop{0%{opacity:0;transform:scale(0)}70%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.success-screen h2{color:var(--form-text);margin:0 0 .3rem;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700}.success-screen p{color:var(--form-text-muted);margin:0 0 1.5rem;font-size:.88rem;line-height:1.4}@media (width<=520px){.submit-card{box-shadow:none;border-radius:0;max-width:none;padding:1.75rem 1.25rem}.submit-form{padding:0;padding-bottom:env(safe-area-inset-bottom,0px);justify-content:flex-start}}@media (prefers-reduced-motion:reduce){.success-mark,.upload-progress-bar{animation:none}}.preload-form{--form-accent:#60a5fa;--form-accent-strong:#2563eb}.preload-counter{color:var(--form-accent-strong,#2563eb);background:#60a5fa1f;border-radius:20px;margin-top:.5rem;padding:.2rem .75rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:600;display:inline-block}.admin-page{color:#1c1c1e;min-height:100svh;padding:0 1rem 2rem;padding-bottom:calc(2rem + env(safe-area-inset-bottom,0px));-webkit-overflow-scrolling:touch;background:#fbfaf7;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow-y:auto}.admin-container{max-width:1100px;margin:0 auto}.admin-header{border-bottom:none;justify-content:space-between;align-items:center;margin-bottom:0;padding:1.5rem 0 1rem;display:flex}.admin-header h1{color:#1c1c1e;margin:0;font-family:Playfair Display,serif;font-size:1.5rem;font-weight:700}.admin-subtitle{color:#6e6e73;margin:.2rem 0 0;font-size:.82rem}.admin-tabs{border-bottom:1px solid #0000000f;gap:0;margin-bottom:1rem;display:flex}.admin-tab{color:#6e6e73;cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;min-height:44px;padding:.65rem 1.25rem;font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;transition:all .2s}.admin-tab:hover{color:#4b5563}.admin-tab.active{color:#1c1c1e;border-bottom-color:#f9735b}.admin-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.admin-filter{gap:.25rem;display:flex}.admin-filter-btn{color:#6e6e73;cursor:pointer;background:0 0;border:1px solid #00000014;border-radius:8px;min-height:36px;padding:.35rem .75rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;transition:all .15s}.admin-filter-btn:hover{color:#4b5563;background:#00000008}.admin-filter-btn.active{color:#fff;background:#c03a22;border-color:#c03a22}.admin-upload-section{max-width:460px;margin:0 auto;padding:1rem 0 2rem}.admin-upload-card{--form-accent:#f9735b;--form-accent-strong:#c03a22;--form-bg:#fbfaf7;--form-surface:#fff;--form-text:#1c1c1e;--form-text-muted:#6e6e73;--form-text-faint:#9a9a9f;--form-border:#e5e7eb;background:#fff;border-radius:20px;flex-direction:column;align-items:center;gap:1rem;padding:2rem 1.75rem;display:flex;box-shadow:0 1px 8px #0000000a,0 4px 20px #0000000f}.admin-upload-hint{color:#6e6e73;text-align:center;margin:0;font-size:.85rem;line-height:1.4}.admin-upload-success{text-align:center;padding:1rem 0}.admin-upload-success h2{color:#1c1c1e;margin:0 0 .3rem;font-family:Playfair Display,serif;font-size:1.3rem;font-weight:700}.admin-upload-success p{color:#6e6e73;margin:0 0 1.5rem;font-size:.88rem}.admin-upload-card .file-upload-label,.admin-upload-card .caption-group,.admin-upload-card .form-actions,.admin-upload-card .upload-progress,.admin-upload-card .error-message{width:100%}.preload-counter{color:#92400e;background:#f9735b1f;border-radius:20px;padding:.2rem .75rem;font-family:Inter,sans-serif;font-size:.78rem;font-weight:500;display:inline-block}.admin-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c03a22,#8b2818);border:none;border-radius:10px;padding:.55rem 1.2rem;font-family:Inter,sans-serif;font-size:.85rem;font-weight:600;transition:all .2s}.admin-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 12px #c03a2240}.admin-btn:disabled{opacity:.5;cursor:default}.admin-btn-sm{color:#4b5563;cursor:pointer;background:#0000000a;border:1px solid #00000014;border-radius:6px;padding:.3rem .6rem;font-family:Inter,sans-serif;font-size:.72rem;font-weight:500;transition:all .15s}.admin-btn-sm:hover:not(:disabled){background:#00000014}.admin-btn-sm:disabled{opacity:.4;cursor:default}.admin-btn-sm.save{color:#fff;background:#c03a22;border-color:#c03a22}.admin-btn-sm.save:hover:not(:disabled){background:#8b2818}.admin-btn-sm.danger{color:#b91c1c;border-color:#b91c1c26}.admin-btn-sm.danger:hover:not(:disabled){background:#b91c1c14}.admin-pagination{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.admin-per-page{color:#6e6e73;align-items:center;gap:.4rem;font-size:.78rem;display:flex}.admin-page-opt{color:#4b5563;cursor:pointer;text-align:center;background:0 0;border:1px solid #00000014;border-radius:6px;min-width:36px;min-height:32px;padding:.35rem .65rem;font-family:Inter,sans-serif;font-size:.75rem;font-weight:500;transition:all .15s}.admin-page-opt:hover{background:#0000000a}.admin-page-opt.active{color:#fff;background:#c03a22;border-color:#c03a22}.admin-page-nav{align-items:center;gap:.5rem;display:flex}.admin-page-info{color:#6e6e73;text-align:center;min-width:3rem;font-size:.78rem}.admin-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;display:grid}.admin-card{background:#fff;border-radius:14px;transition:opacity .3s,transform .3s;overflow:hidden;box-shadow:0 1px 8px #0000000a,0 4px 20px #0000000f}.admin-card.deleting{opacity:.4;transform:scale(.97)}.admin-card-img{aspect-ratio:1;background:#eee;position:relative;overflow:hidden}.admin-card-img img{object-fit:contain;background:#fafaf8;width:100%;height:100%;display:block}.admin-badge{text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:.25rem .6rem;font-size:.68rem;font-weight:600;position:absolute;top:.5rem;right:.5rem}.admin-badge.guest{color:#fff;background:#c03a22}.admin-badge.preloaded{color:#fff;background:#2563eb}.admin-card-body{padding:.75rem}.admin-caption{color:#1c1c1e;cursor:pointer;min-height:1.2rem;margin:0 0 .5rem;font-size:.85rem;line-height:1.35}.admin-caption:hover{color:#f9735b}.admin-no-caption{color:#9a9a9f;font-style:italic}.admin-edit-row{align-items:center;gap:.35rem;margin-bottom:.5rem;display:flex}.admin-edit-input{color:#1c1c1e;background:#fff;border:1.5px solid #f9735b;border-radius:6px;outline:none;flex:1;padding:.35rem .5rem;font-family:Inter,sans-serif;font-size:.82rem}.admin-meta{color:#6e6e73;justify-content:space-between;align-items:center;font-size:.7rem;display:flex}.admin-card-actions{gap:.3rem;display:flex}.admin-error{color:#b91c1c;background:#b91c1c0f;border-radius:10px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.85rem}.admin-empty{text-align:center;color:#6e6e73;padding:3rem 0;font-size:.95rem}@media (width<=600px){.admin-page{padding:0 .75rem 1.5rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom,0px))}.admin-header{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1.25rem 0 .75rem}.admin-header h1{font-size:1.3rem}.admin-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.admin-pagination{flex-direction:column;align-items:stretch;gap:.5rem}.admin-per-page,.admin-page-nav{justify-content:center}.admin-card-body{padding:.6rem}.admin-caption{font-size:.78rem}.admin-edit-row{flex-wrap:wrap}.admin-edit-input{flex:none;width:100%;min-height:44px;padding:.5rem;font-size:.9rem}.admin-btn-sm{min-height:36px;padding:.4rem .7rem;font-size:.75rem}.admin-btn{width:100%;min-height:44px}.admin-meta{flex-direction:column;align-items:flex-start;gap:.4rem}.admin-card-actions{gap:.4rem;width:100%;display:flex}.admin-card-actions .admin-btn-sm{text-align:center;flex:1;justify-content:center}}@media (width<=380px){.admin-grid{grid-template-columns:1fr}}.admin-pagination-bottom{justify-content:center;align-items:center;gap:.75rem;padding:1.5rem 0 .5rem;display:flex}.admin-bulk-section{padding:1rem 0 2rem}.bulk-summary{color:#4b5563;align-items:center;gap:.75rem;width:100%;font-size:.85rem;font-weight:500;display:flex}.bulk-error-count{color:#b91c1c;font-size:.8rem}.bulk-progress-bar{background:#0000000f;border-radius:2px;width:100%;height:4px;overflow:hidden}.bulk-progress-fill{background:linear-gradient(90deg,#f9735b,#c03a22);border-radius:2px;height:100%;transition:width .3s}.bulk-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;width:100%;display:grid}.bulk-item{flex-direction:column;align-items:center;gap:.3rem;display:flex}.bulk-thumb{aspect-ratio:1;background:#eee;border-radius:10px;width:100%;position:relative;overflow:hidden}.bulk-thumb img{object-fit:cover;width:100%;height:100%;display:block}.bulk-status-overlay{pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.bulk-item.pending .bulk-status-overlay,.bulk-item.converting .bulk-status-overlay,.bulk-item.uploading .bulk-status-overlay{background:#ffffff80}.bulk-item.done .bulk-status-overlay{background:#00000040}.bulk-item.error .bulk-status-overlay{background:#b91c1c33}.bulk-status-icon{font-size:1.4rem;font-weight:700}.bulk-status-icon.done{color:#fff;font-size:1.6rem}.bulk-status-icon.error{color:#b91c1c;font-size:1.6rem}.bulk-status-icon.spinning{color:#c03a22;font-size:1.6rem;animation:1s linear infinite bulk-spin}@keyframes bulk-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.bulk-remove{color:#fff;cursor:pointer;opacity:0;background:#0000008c;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:.85rem;line-height:1;transition:opacity .15s;display:flex;position:absolute;top:4px;right:4px}.bulk-thumb:hover .bulk-remove{opacity:1}.bulk-filename{color:#4b5563;text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:100%;font-size:.68rem;overflow:hidden}.bulk-error-msg{color:#b91c1c;text-align:center;font-size:.65rem}@media (width<=600px){.bulk-grid{grid-template-columns:repeat(3,1fr);gap:.5rem}.bulk-remove{opacity:1}}.queue-dashboard{min-height:100vh;color:var(--text-primary);flex-direction:column;justify-content:center;align-items:center;gap:clamp(1.5rem,2.5vh,2.5rem);padding:clamp(1.5rem,3vh,3rem) clamp(1.5rem,3vw,4rem);font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;display:flex;position:relative;overflow:hidden}.queue-dashboard__bg{z-index:-1;background:radial-gradient(ellipse 80% 60% at 50% 40%, #fff4e399 0%, transparent 70%), var(--bg-deep);position:fixed;inset:0}.queue-dashboard__header{text-align:center;flex-shrink:0}.queue-dashboard__title-row{justify-content:center;align-items:center;gap:.6rem;display:flex}.queue-dashboard__icon{filter:drop-shadow(0 2px 8px #f9735b40);font-size:clamp(1.8rem,3.5vw,2.8rem)}.queue-dashboard__title{letter-spacing:-.02em;background:linear-gradient(135deg, var(--coral-deep) 0%, var(--amber) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:clamp(2.2rem,4.5vw,3.8rem);font-weight:800}.queue-dashboard__subtitle{color:var(--text-secondary);letter-spacing:.04em;margin-top:.2rem;font-size:clamp(.85rem,1.6vw,1.15rem)}.queue-dashboard__accent{background:linear-gradient(90deg, var(--coral) 0%, var(--amber) 100%);opacity:.85;border-radius:2px;width:88px;height:3px;margin:.7rem auto 0;display:block}.queue-dashboard__loading{color:var(--text-secondary);font-size:1.25rem}.queue-dashboard__error{color:#b91c1c;text-align:center;background:#dc35451f;border:1px solid #dc35454d;border-radius:12px;padding:.5rem 1.25rem;font-size:.85rem}.queue-dashboard__banner{color:var(--accent-text);text-align:center;font-size:clamp(1.2rem,2.5vw,1.8rem);font-weight:600}.queue-dashboard__content{flex:1;justify-content:center;align-items:center;width:100%;max-width:1400px;display:flex}.table-grid{flex-direction:column;align-items:center;gap:clamp(1.25rem,2vw,2rem);width:100%;display:flex}.table-grid__row{flex-wrap:wrap;justify-content:center;align-items:stretch;gap:clamp(1rem,2vw,2rem);width:100%;display:flex}.table-grid__row>.table-card{flex:0 clamp(220px,28vw,340px)}.table-card{border:1.5px solid var(--border-soft);background:var(--surface-card);border-radius:22px;flex-direction:column;align-items:center;gap:clamp(.75rem,1.2vh,1.2rem);padding:clamp(1rem,1.8vh,1.5rem) clamp(.9rem,1.5vw,1.5rem);transition:all .4s;display:flex;position:relative;box-shadow:0 1px 2px #1c1c1e0a,0 6px 24px #1c1c1e0f}.table-card--idle{border-color:var(--border-soft)}.table-card--queued{background:var(--amber-soft);border-color:#f59e0b66}.table-card--serving{background:#22c55e0a;border-color:#22c55e8c;animation:2.5s ease-in-out infinite card-glow;box-shadow:0 0 0 4px #22c55e1a,0 0 40px #22c55e2e,0 8px 32px #1c1c1e14}@keyframes card-glow{0%,to{box-shadow:0 0 0 4px #22c55e1a,0 0 40px #22c55e2e,0 8px 32px #1c1c1e14}50%{box-shadow:0 0 0 6px #22c55e2e,0 0 60px #22c55e47,0 8px 32px #1c1c1e1a}}.table-card--done{border-color:var(--border-soft);opacity:.55}.table-card__header{justify-content:space-between;align-items:center;gap:.75rem;width:100%;min-height:1.6rem;display:flex}.table-card__number{color:var(--text-primary);letter-spacing:.01em;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:clamp(.85rem,1.2vw,1.05rem);font-weight:700;overflow:hidden}.status-badge{letter-spacing:.02em;white-space:nowrap;border-radius:100px;align-items:center;padding:.3rem .85rem;font-size:clamp(.7rem,1vw,.88rem);font-weight:700;display:inline-flex}.status-badge--idle{color:var(--text-muted);background:#f2f2f2}.status-badge--queued{background:var(--amber-soft);color:var(--accent-text);border:1px solid #f59e0b59}.status-badge--serving{color:#15803d;background:#22c55e1f;border:1px solid #22c55e59;animation:2s ease-in-out infinite badge-glow}.status-badge--done{color:#15803db3;background:#22c55e14}@keyframes badge-glow{0%,to{box-shadow:0 0 6px #22c55e33}50%{box-shadow:0 0 16px #22c55e59}}.table-card__circle-area{justify-content:center;align-items:center;display:flex;position:relative}.table-card__circle{background:radial-gradient(circle at 35% 30%,#ffffffe6 0%,#0000 55%),radial-gradient(circle,#fafafa 0%,#ececec 100%);border:2.5px solid;border-radius:50%;justify-content:center;align-items:center;width:clamp(90px,11vw,150px);height:clamp(90px,11vw,150px);transition:all .4s;display:flex;position:relative;box-shadow:0 2px 4px #1c1c1e0f,0 8px 18px #1c1c1e14,inset 0 -2px 6px #1c1c1e0a}.table-card__circle-ring{pointer-events:none;border:1px solid #1c1c1e14;border-radius:50%;position:absolute;inset:10%}.table-card__circle--idle{border-color:#d9d5cc}.table-card__circle--queued{background:radial-gradient(circle at 35% 30%,#ffffffe6 0%,#0000 55%),radial-gradient(circle,#fffbf0 0%,#fef3c7 100%);border-color:#f59e0b8c}.table-card__circle--serving{background:radial-gradient(circle at 35% 30%,#ffffffe6 0%,#0000 55%),radial-gradient(circle,#f0fdf4 0%,#dcfce7 100%);border-color:#22c55e99;animation:2.5s ease-in-out infinite circle-pulse;box-shadow:0 2px 4px #1c1c1e0f,0 0 30px #22c55e38,inset 0 -2px 6px #22c55e14}.table-card__circle--done{background:radial-gradient(circle at 35% 30%,#ffffffb3 0%,#0000 55%),radial-gradient(circle,#f5f5f5 0%,#e5e7eb 100%);border-color:#22c55e4d}@keyframes circle-pulse{0%,to{border-color:#22c55e99;box-shadow:0 2px 4px #1c1c1e0f,0 0 30px #22c55e38,inset 0 -2px 6px #22c55e14}50%{border-color:#22c55ecc;box-shadow:0 2px 4px #1c1c1e0f,0 0 50px #22c55e52,inset 0 -2px 6px #22c55e1f}}.table-card__pulse-ring{pointer-events:none;border:2px solid #22c55e59;border-radius:50%;animation:2.5s ease-in-out infinite ring-expand;position:absolute;inset:-10px}@keyframes ring-expand{0%{opacity:.7;transform:scale(.95)}50%{opacity:.2;transform:scale(1.08)}to{opacity:.7;transform:scale(.95)}}.table-card__circle-icon{z-index:1;font-size:clamp(1.8rem,3.2vw,2.6rem);position:relative}.table-card__circle-icon--idle{opacity:.35;font-size:clamp(1.3rem,2.2vw,1.8rem)}.table-card__circle-icon--done{color:#15803db3;z-index:1;font-size:clamp(2.2rem,3.8vw,3.2rem);font-weight:800;position:relative}.table-card__circle-position{color:var(--accent-text);z-index:1;font-size:clamp(1.5rem,2.5vw,2.2rem);font-weight:800;position:relative}.table-card__guests{flex-wrap:wrap;justify-content:center;gap:.4rem;max-width:100%;display:flex}.guest-chip{border:1px solid var(--border-soft);color:var(--text-primary);letter-spacing:.01em;text-overflow:ellipsis;white-space:nowrap;background:#f4f5f7;border-radius:999px;align-items:center;max-width:100%;padding:.32rem .75rem;font-size:clamp(.78rem,1.1vw,.95rem);font-weight:600;line-height:1.1;display:inline-flex;overflow:hidden}.table-card--queued .guest-chip{color:#92400e;background:#f59e0b1a;border-color:#f59e0b40}.table-card--serving .guest-chip{color:#15803d;background:#22c55e1a;border-color:#22c55e47}.table-card--done .guest-chip{border-color:var(--border-soft);color:var(--text-muted);background:#f4f5f7}.status-legend{flex-shrink:0}.status-legend__inner{background:var(--surface-card);border:1px solid var(--border-soft);border-radius:100px;align-items:center;gap:clamp(1.25rem,2.5vw,2.5rem);padding:.65rem 1.85rem;display:inline-flex;box-shadow:0 1px 2px #1c1c1e0a,0 4px 18px #1c1c1e0f}.status-legend__item{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:clamp(.78rem,1vw,.95rem);font-weight:600;display:flex}.status-legend__dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.status-legend__dot--idle{background:#c4c4c4}.status-legend__dot--queued{background:var(--gold)}.status-legend__dot--serving{background:#22c55e;box-shadow:0 0 6px #22c55e80}.status-legend__dot--done{background:#22c55e66}@media (width<=900px){.table-grid{gap:clamp(.75rem,1.5vw,1.25rem)}.table-grid__row>.table-card{flex:0 clamp(180px,42vw,280px)}}@media (width<=600px){.table-grid__row{flex-direction:column;align-items:center}.table-grid__row>.table-card{flex:none;width:min(340px,100%)}}.host-page{background:var(--bg-deep);min-height:100dvh;color:var(--text-primary);padding-bottom:calc(1rem + env(safe-area-inset-bottom,0));-webkit-tap-highlight-color:transparent;flex-direction:column;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;display:flex}.host-page__header{text-align:center;padding:1rem 1rem .5rem}.host-page__title{background:linear-gradient(135deg, var(--coral-deep) 0%, var(--amber) 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:800}.host-page__subtitle{color:var(--text-secondary);margin-top:.1rem;font-size:.78rem}.host-page__summary{display:none}.host-action-bar{border:1px solid var(--border-soft);background:var(--surface-card);border-radius:16px;align-items:center;gap:.6rem;margin:0 .75rem .75rem;padding:.75rem .85rem;display:flex;box-shadow:0 1px 2px #1c1c1e0a,0 4px 16px #1c1c1e0d}.host-action-bar__info{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.host-action-bar__label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-size:.6rem;font-weight:700}.host-action-bar__name{color:#15803d;text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:800;overflow:hidden}.host-action-bar__name--idle{color:var(--text-secondary);font-size:.9rem;font-weight:600}.host-action-bar__counts{color:var(--text-secondary);flex-wrap:wrap;gap:.6rem;margin-top:.2rem;font-size:.7rem;display:flex}.host-action-bar__counts strong{color:var(--text-primary);margin-right:.15rem;font-weight:700}.host-action-bar__buttons{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.host-page__loading{color:var(--text-secondary);flex:1;justify-content:center;align-items:center;font-size:1rem;display:flex}.host-page__error{color:#b91c1c;text-align:center;background:#dc354514;border:1px solid #dc354540;border-radius:10px;margin:.75rem 1rem 0;padding:.5rem .75rem;font-size:.8rem}.host-page__list{flex-direction:column;flex:1;gap:.65rem;padding:.75rem .75rem 1rem;display:flex}.host-card{border:1px solid var(--glass-border);background:var(--surface-card);border-radius:16px;flex-direction:column;gap:.6rem;padding:.75rem;transition:all .3s;display:flex;box-shadow:0 1px 2px #1c1c1e0a,0 4px 16px #1c1c1e0d}.host-card--idle{border-color:var(--glass-border)}.host-card--queued{background:var(--accent-bg-soft);border-color:#c98a2e59}.host-card--serving{background:#22c55e0a;border-color:#22c55e73;box-shadow:0 0 20px #22c55e1f,0 4px 16px #1c1c1e0d}.host-card--done{border-color:var(--glass-border);opacity:.55}.host-card__top{align-items:center;gap:.75rem;display:flex}.host-card__circle-wrap{flex-shrink:0}.host-card__circle{border:2px solid;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;transition:all .3s;display:flex}.host-card__circle--idle{background:#f2f2f2;border-color:#e5e2da}.host-card__circle--queued{background:var(--accent-bg-soft);border-color:#c98a2e73}.host-card__circle--serving{background:#22c55e14;border-color:#22c55e8c;animation:2s ease-in-out infinite host-pulse}.host-card__circle--done{background:#22c55e0a;border-color:#22c55e40}@keyframes host-pulse{0%,to{box-shadow:0 0 8px #22c55e33}50%{box-shadow:0 0 20px #22c55e59}}.host-card__icon{font-size:1.4rem}.host-card__icon--idle{opacity:.4;font-size:1.3rem}.host-card__icon--done{color:#15803d99;font-size:1.5rem;font-weight:800}.host-card__position{color:var(--accent-text);font-size:1rem;font-weight:800}.host-card__table-num{color:var(--text-secondary);font-size:1rem;font-weight:700}.host-card__info{flex-direction:column;flex:1;gap:.35rem;min-width:0;display:flex}.host-card__header{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.host-card__label-stack{flex-direction:column;flex:1;gap:.1rem;min-width:0;display:flex}.host-card__name{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:1rem;font-weight:700;overflow:hidden}.host-card__name-empty{border:1px dashed var(--border-soft);color:var(--text-muted);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:8px;align-self:flex-start;padding:.25rem .6rem;font-family:inherit;font-size:.85rem;font-weight:600;transition:all .15s}.host-card__name-empty:hover{color:var(--coral-deep);background:var(--coral-soft);border-color:#f9735b66}.host-card__sublabel{color:var(--text-muted);letter-spacing:.02em;font-size:.7rem;font-weight:500}.host-card--done .host-card__name{color:var(--text-secondary)}.host-card__guests{flex-wrap:wrap;gap:.3rem;display:flex}.host-card__guest-chip{color:var(--text-secondary);letter-spacing:.01em;border:1px solid var(--border-soft);background:#f4f5f7;border-radius:999px;padding:.18rem .55rem;font-size:.75rem;font-weight:600}.host-card--queued .host-card__guest-chip{color:var(--accent-text);background:#f59e0b1a;border-color:#f59e0b40}.host-card--serving .host-card__guest-chip{color:#15803d;background:#22c55e1a;border-color:#22c55e40}.host-card__actions{gap:.5rem;display:flex}.host-action-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;border:1px solid #0000;border-radius:12px;flex:1;min-height:44px;padding:.65rem .85rem;font-size:.85rem;font-weight:700;transition:all .2s}.host-action-btn:disabled{opacity:.35;cursor:not-allowed}.host-action-btn--primary{background:var(--coral-soft);color:var(--coral-deep);border-color:#f9735b59}.host-action-btn--primary:not(:disabled):active{background:#ffd7cc}.host-action-btn--serve{color:#fff;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border-color:#15803d;box-shadow:0 1px 2px #1c1c1e0f,0 2px 8px #22c55e33}.host-action-btn--serve:not(:disabled):active{transform:scale(.97)}.host-action-btn--secondary{background:var(--surface-card);color:var(--text-primary);border-color:var(--border-soft)}.host-action-btn--secondary:not(:disabled):active{background:var(--surface-hover)}.host-action-btn--edit{background:var(--surface-card);color:var(--text-secondary);border-color:var(--border-soft);flex:none;padding:.65rem .85rem}.host-action-btn--edit:active{background:var(--surface-hover)}.host-bottom-btn{cursor:pointer;-webkit-tap-highlight-color:transparent;white-space:nowrap;border:1px solid #0000;border-radius:12px;min-height:44px;padding:.65rem .85rem;font-size:.85rem;font-weight:700;transition:all .2s}.host-bottom-btn:disabled{opacity:.35;cursor:not-allowed}.host-bottom-btn--serve{color:#fff;background:linear-gradient(135deg,#22c55e 0%,#16a34a 100%);border-color:#15803d;box-shadow:0 1px 2px #1c1c1e0d,0 2px 8px #22c55e38}.host-bottom-btn--serve:not(:disabled):active{transform:scale(.97)}.host-bottom-btn--reset{background:var(--surface-card);color:var(--text-secondary);border-color:var(--border-soft);min-width:44px;padding:.65rem .7rem;font-size:1rem}.host-bottom-btn--reset:not(:disabled):active{background:var(--surface-hover)}.host-bottom-btn--confirm{color:#b91c1c!important;background:#dc35451f!important;border-color:#dc354580!important}.guest-editor-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#1c1c1e66;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;inset:0}.guest-editor{background:var(--surface-card);border:1px solid var(--glass-border);padding:1.25rem 1rem;padding-bottom:calc(1.25rem + env(safe-area-inset-bottom,0));border-radius:20px 20px 0 0;flex-direction:column;gap:.75rem;width:100%;max-width:500px;max-height:85dvh;display:flex;box-shadow:0 -8px 40px #1c1c1e2e}.guest-editor__title{color:var(--text-primary);text-align:center;font-size:1.15rem;font-weight:700}.guest-editor__name-field{flex-direction:column;gap:.35rem;display:flex}.guest-editor__label{color:var(--text-secondary);letter-spacing:.02em;font-size:.78rem;font-weight:600}.guest-editor__label-hint{color:var(--text-muted);font-weight:400}.guest-editor__section-label{color:var(--text-secondary);letter-spacing:.02em;margin-top:.25rem;font-size:.78rem;font-weight:600}.guest-editor__list{flex-direction:column;flex:1;gap:.4rem;display:flex;overflow-y:auto}.guest-editor__row{align-items:center;gap:.4rem;display:flex}.guest-editor__input{border:1px solid var(--glass-border);background:var(--cream);color:var(--text-primary);-webkit-appearance:none;border-radius:10px;outline:none;flex:1;padding:.65rem .75rem;font-size:1rem;transition:border-color .2s}.guest-editor__input:focus{border-color:var(--gold);background:var(--surface-card)}.guest-editor__input::placeholder{color:var(--text-muted)}.guest-editor__remove{color:#b91c1c;cursor:pointer;-webkit-tap-highlight-color:transparent;background:#dc35451a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.95rem;display:flex}.guest-editor__remove:active{background:#dc354533}.guest-editor__add{border:1px dashed var(--glass-border);color:var(--accent-text);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border-radius:10px;min-height:44px;padding:.75rem;font-size:.9rem;font-weight:600}.guest-editor__add:active{background:var(--accent-bg-soft)}.guest-editor__count{color:var(--text-muted);text-align:center;font-size:.7rem}.guest-editor__actions{gap:.5rem;display:flex}.guest-editor__actions .queue-btn,.guest-editor__actions button{cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:12px;flex:1;padding:.8rem;font-size:.95rem;font-weight:700}.guest-editor__actions button:first-child{background:var(--surface-card);color:var(--text-secondary);border:1px solid var(--glass-border)}.guest-editor__actions button:last-child{color:#052e16;background:linear-gradient(135deg,#4ade80,#22c55e)}.guest-editor__actions button:last-child:disabled{opacity:.4}@media (width>=600px){.host-page{align-items:center}.host-page__list,.host-page__header>*,.host-action-bar{width:100%;max-width:720px}.host-action-bar{margin-left:auto;margin-right:auto}.guest-editor{border-radius:20px;margin-bottom:2rem}.guest-editor-overlay{align-items:center;padding:1rem}}
