:root{--font-family: "Nunito", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.25rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--font-weight-light: 300;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--letter-spacing-tight: -.02em;--letter-spacing-normal: 0;--letter-spacing-wide: .05em;--color-primary: #f97066;--color-primary-hover: #ef5a4e;--color-primary-light: #fef2f1;--color-primary-dark: #dc4a3d;--color-secondary: #ffb088;--color-secondary-hover: #ff9966;--color-secondary-light: #fff5ee;--color-accent: #c67d5a;--color-accent-light: #faf0e9;--color-bg: #fffcfa;--color-bg-secondary: #fef7f3;--color-bg-hover: #fdeee6;--color-bg-warm: #fff8f0;--color-text: #3d2c24;--color-text-secondary: #8b7355;--color-text-light: #b5a08a;--color-border: #ede0d4;--color-border-light: #f5ebe3;--color-success: #4ade80;--color-success-light: #dcfce7;--color-success-text: #166534;--color-warning: #fbbf24;--color-warning-light: #fef3c7;--color-warning-text: #78350f;--color-error: #f87171;--color-error-light: #fee2e2;--color-error-dark: #dc2626;--color-error-text: #991b1b;--color-info: #60a5fa;--color-info-light: #dbeafe;--color-info-text: #1e40af;--rel-family: #7dd3fc;--rel-family-bg: #e0f2fe;--rel-friend: #86efac;--rel-friend-bg: #dcfce7;--rel-colleague: #fcd34d;--rel-colleague-bg: #fef3c7;--rel-partner: #f9a8d4;--rel-partner-bg: #fce7f3;--rel-acquaintance: #d4c7b8;--rel-acquaintance-bg: #f5f0ea;--rel-avoid: #fca5a5;--rel-avoid-bg: #fee2e2;--badge-wedding-bg: #fce7f3;--badge-wedding-text: #be185d;--badge-corporate-bg: #dbeafe;--badge-corporate-text: #1d4ed8;--badge-gala-bg: #fef3c7;--badge-gala-text: #b45309;--badge-party-bg: #d1fae5;--badge-party-text: #047857;--badge-social-bg: #e0e7ff;--badge-social-text: #4338ca;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(61, 44, 36, .05);--shadow-md: 0 4px 12px rgba(61, 44, 36, .08);--shadow-lg: 0 8px 24px rgba(61, 44, 36, .12);--shadow-xl: 0 16px 48px rgba(61, 44, 36, .16);--shadow-glow: 0 0 20px rgba(249, 112, 102, .3);--focus-ring-color: rgba(249, 112, 102, .15);--focus-ring-strong: rgba(249, 112, 102, .3);--duration-micro: .08s;--duration-fast: .1s;--duration-normal: .15s;--duration-slow: .2s;--duration-slower: .3s;--ease-out: cubic-bezier(.33, 1, .68, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-bounce: cubic-bezier(.34, 1.2, .64, 1);--ease-spring: cubic-bezier(.175, .885, .32, 1.1);--touch-target-min: 44px;--touch-target-comfortable: 48px;--mobile-spacing-xs: 8px;--mobile-spacing-sm: 12px;--mobile-spacing-md: 16px;--mobile-spacing-lg: 20px;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--mobile-header-height: 56px;--mobile-toolbar-height: 48px;--mobile-bottom-nav-height: 64px;font-family:var(--font-family);line-height:var(--line-height-normal);font-weight:var(--font-weight-normal);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=dark]{--color-primary: #ff8a7d;--color-primary-hover: #ff9f94;--color-primary-light: #3d2520;--color-primary-dark: #ffb4aa;--color-secondary: #ffbe98;--color-secondary-hover: #ffcaa8;--color-secondary-light: #2d2018;--color-accent: #d99b7c;--color-accent-light: #2a1f18;--color-bg: #1a1412;--color-bg-secondary: #241c18;--color-bg-hover: #2e241f;--color-bg-warm: #1f1815;--color-text: #faf5f0;--color-text-secondary: #c9b8a8;--color-text-light: #8a7968;--color-border: #3d3028;--color-border-light: #2e261f;--rel-family-bg: #1e3a4f;--rel-friend-bg: #1a3326;--rel-colleague-bg: #3d3018;--rel-partner-bg: #3d1f30;--rel-acquaintance-bg: #2d2820;--rel-avoid-bg: #3d1f1f;--color-error-dark: #b91c1c;--color-success-light: #14532d;--color-success-text: #86efac;--color-warning-light: #451a03;--color-warning-text: #fcd34d;--color-error-light: #450a0a;--color-error-text: #fca5a5;--color-info-light: #1e3a5f;--color-info-text: #93c5fd;--badge-wedding-bg: #4a1d35;--badge-wedding-text: #f9a8d4;--badge-corporate-bg: #1e3a5f;--badge-corporate-text: #93c5fd;--badge-gala-bg: #451a03;--badge-gala-text: #fcd34d;--badge-party-bg: #14532d;--badge-party-text: #86efac;--badge-social-bg: #312e81;--badge-social-text: #c7d2fe;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(255, 138, 125, .25);--focus-ring-color: rgba(255, 138, 125, .25);--focus-ring-strong: rgba(255, 138, 125, .4)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]){--color-primary: #ff8a7d;--color-primary-hover: #ff9f94;--color-primary-light: #3d2520;--color-primary-dark: #ffb4aa;--color-secondary: #ffbe98;--color-secondary-hover: #ffcaa8;--color-secondary-light: #2d2018;--color-accent: #d99b7c;--color-accent-light: #2a1f18;--color-bg: #1a1412;--color-bg-secondary: #241c18;--color-bg-hover: #2e241f;--color-bg-warm: #1f1815;--color-text: #faf5f0;--color-text-secondary: #c9b8a8;--color-text-light: #8a7968;--color-border: #3d3028;--color-border-light: #2e261f;--rel-family-bg: #1e3a4f;--rel-friend-bg: #1a3326;--rel-colleague-bg: #3d3018;--rel-partner-bg: #3d1f30;--rel-acquaintance-bg: #2d2820;--rel-avoid-bg: #3d1f1f;--color-error-dark: #b91c1c;--color-success-light: #14532d;--color-success-text: #86efac;--color-warning-light: #451a03;--color-warning-text: #fcd34d;--color-error-light: #450a0a;--color-error-text: #fca5a5;--color-info-light: #1e3a5f;--color-info-text: #93c5fd;--badge-wedding-bg: #4a1d35;--badge-wedding-text: #f9a8d4;--badge-corporate-bg: #1e3a5f;--badge-corporate-text: #93c5fd;--badge-gala-bg: #451a03;--badge-gala-text: #fcd34d;--badge-party-bg: #14532d;--badge-party-text: #86efac;--badge-social-bg: #312e81;--badge-social-text: #c7d2fe;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .3);--shadow-xl: 0 16px 48px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(255, 138, 125, .25);--focus-ring-color: rgba(255, 138, 125, .25);--focus-ring-strong: rgba(255, 138, 125, .4)}}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.8)}70%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-4px)}40%,80%{transform:translate(4px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes staggerIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-2deg)}75%{transform:rotate(2deg)}}@keyframes overlayFade{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}*{box-sizing:border-box}body{margin:0;font-family:var(--font-family);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);background-color:var(--color-bg);color:var(--color-text)}#root{width:100vw;height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6{margin:0;font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);letter-spacing:var(--letter-spacing-tight)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}button{font-family:inherit;cursor:pointer;transition:all var(--duration-normal) var(--ease-out)}button:hover{transform:translateY(-1px)}button:active{transform:scale(.97) translateY(0);transition:transform var(--duration-micro) var(--ease-out)}input,select,textarea{font-family:inherit;background:var(--color-bg);color:var(--color-text);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--focus-ring-color)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full);border:2px solid var(--color-bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background:var(--color-primary-light);color:var(--color-primary-dark)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(pointer:coarse){button:hover{transform:none}*{-webkit-tap-highlight-color:rgba(249,112,102,.15)}.scrollable{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}}@media(max-width:768px){html,body{overscroll-behavior:none}#root{height:100dvh}}@keyframes touchPulse{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}@keyframes rippleExpand{0%{transform:scale(0);opacity:.4}to{transform:scale(2.5);opacity:0}}@keyframes longPressGrow{0%{box-shadow:0 0 #f9706666}to{box-shadow:0 0 0 8px #f970661a}}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideInFromBottom{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeInBackdrop{0%{background-color:transparent}to{background-color:#00000080}}@media(pointer:coarse){button,[role=button],a,input[type=checkbox],input[type=radio],select{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}input[type=checkbox],input[type=radio]{width:20px;height:20px}select{padding:.75rem 1rem}}.touch-ripple{position:relative;overflow:hidden}.touch-ripple:after{content:"";position:absolute;top:50%;left:50%;width:0;height:0;background:#f970664d;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;opacity:0}.touch-ripple:active:after{animation:rippleExpand .4s ease-out}@media(pointer:coarse){.touch-press:active{transform:scale(.97);opacity:.9;transition:transform var(--duration-micro),opacity var(--duration-micro)}}.long-press-indicator{position:relative}.long-press-indicator:before{content:"";position:absolute;inset:-4px;border-radius:inherit;border:2px solid transparent;pointer-events:none;transition:border-color var(--duration-normal)}@media(pointer:coarse){.long-press-indicator:active:before{animation:longPressGrow .3s ease-out forwards}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.toast-container{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;gap:8px;z-index:1000;pointer-events:none}.toast{padding:12px 20px;border-radius:var(--radius-lg);background:var(--color-bg);border:2px solid var(--color-border);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px;pointer-events:auto;animation:toastSlideUp var(--duration-fast) var(--ease-out);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.toast-success{border-color:var(--color-success);background:var(--color-success-light);color:var(--color-success-text)}.toast-info{border-color:var(--color-info);background:var(--color-info-light);color:var(--color-info-text)}.toast-warning{border-color:var(--color-warning);background:var(--color-warning-light);color:var(--color-warning-text)}.toast-error{border-color:var(--color-error);background:var(--color-error-light);color:var(--color-error-text)}.toast-message{flex:1}.toast-action{padding:6px 12px;border-radius:var(--radius-md);border:none;background:#0000001a;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.toast-action:hover{background:#00000026}@keyframes toastSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:480px){.toast-container{bottom:calc(90px + env(safe-area-inset-bottom,0));left:12px;right:12px;transform:none;max-width:none}.toast{padding:10px 16px;border-radius:var(--radius-md);font-size:var(--font-size-xs)}.toast-action{padding:8px 12px;min-height:36px}}.landing-page{min-height:100vh;min-height:100dvh;height:100vh;height:100dvh;background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-bg-warm) 100%);overflow-x:hidden;overflow-y:auto;position:relative}.landing-page:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%' height='100%' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");pointer-events:none;z-index:0}.landing-content{position:relative;z-index:1;max-width:900px;margin:0 auto;padding:2rem}.hero-section{text-align:center;padding:4rem 1rem 3rem;animation:fadeIn var(--duration-slow) var(--ease-out)}.logo-wrapper{position:relative;display:inline-block;margin-bottom:.5rem}.logo-wrapper:after{content:"";position:absolute;bottom:-4px;left:50%;width:120px;height:8px;transform:translate(-50%);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 120 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 5 Q30 2, 60 5 T118 4' stroke='%23f97066' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat}.landing-logo{font-size:3.5rem;font-weight:var(--font-weight-extrabold);margin:0;letter-spacing:-.02em;animation:floatDown .6s var(--ease-bounce) backwards;animation-delay:.1s}.logo-seat{color:var(--color-text)}.logo-ify{color:var(--color-primary);font-family:Caveat,cursive;font-size:4rem;font-weight:600}@keyframes floatDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.landing-tagline{font-size:1.5rem;font-weight:var(--font-weight-semibold);color:var(--color-text);margin:1.5rem 0 1rem;animation:slideUp .5s var(--ease-out) backwards;animation-delay:.2s}.landing-description{font-size:var(--font-size-lg);color:var(--color-text-secondary);max-width:480px;margin:0 auto 2rem;line-height:var(--line-height-relaxed);animation:slideUp .5s var(--ease-out) backwards;animation-delay:.3s}.cta-button{display:inline-block;padding:1rem 2.5rem;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;box-shadow:0 4px 0 var(--color-primary-hover),0 8px 20px #f9706640;transition:all .15s ease;position:relative;top:0;overflow:hidden;animation:popIn .4s var(--ease-bounce) backwards;animation-delay:.4s}.cta-button:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.4) 50%,transparent 60%);transform:translate(-100%);transition:none;pointer-events:none}.cta-button:hover:after{transform:translate(100%);transition:transform .6s ease-out}.cta-button:hover{top:2px;box-shadow:0 2px 0 var(--color-primary-hover),0 4px 12px #f970664d;transform:none}.cta-button:active{top:4px;box-shadow:0 0 0 var(--color-primary-hover),0 2px 8px #f9706633}.wave-divider{width:100%;height:60px;margin:2rem 0}.wave-divider svg{width:100%;height:100%}.features-section{padding:2rem 0}.features-stack{display:flex;flex-direction:column;gap:1.5rem}.feature-card{background:var(--color-bg);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:0 1px 0 var(--color-border),0 4px 12px #3d2c240f;display:flex;gap:1.25rem;align-items:flex-start;position:relative;transition:transform .2s var(--ease-out);animation:staggerIn .5s var(--ease-out) backwards}.feature-card:nth-child(1){animation-delay:.5s}.feature-card:nth-child(2){animation-delay:.6s}.feature-card:nth-child(3){animation-delay:.7s}.feature-card:hover{transform:translate(8px)}.feature-card:nth-child(odd){margin-left:2rem}.feature-card:nth-child(2n){margin-right:2rem}.feature-card:before{content:"";position:absolute;top:0;right:0;width:24px;height:24px;background:linear-gradient(135deg,transparent 50%,var(--color-bg-secondary) 50%);border-bottom-left-radius:8px}.feature-icon-wrap{width:48px;height:48px;background:var(--color-bg-warm);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.feature-icon{width:24px;height:24px;color:var(--color-accent)}.feature-content h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:.375rem}.feature-content p{font-size:var(--font-size-base);color:var(--color-text-secondary);line-height:1.6;margin:0}.use-cases{display:flex;justify-content:center;flex-wrap:wrap;gap:.75rem;padding:2rem 0}.use-case-tag{padding:.5rem 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all .2s var(--ease-out)}.use-case-tag:hover{border-color:var(--color-primary);color:var(--color-primary)}.preview-section{padding:2rem 0;animation:fadeIn .6s var(--ease-out) backwards;animation-delay:.8s}.demo-container{position:relative;width:100%;max-width:450px;height:180px;margin:0 auto;display:flex;align-items:center;justify-content:center;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.demo-guest-chip{position:absolute;left:15%;top:50%;transform:translateY(-50%);padding:.5rem 1rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);box-shadow:var(--shadow-md);animation:guestDragDemo 5s ease-in-out infinite;z-index:10}@keyframes guestDragDemo{0%,10%{left:15%;transform:translateY(-50%) scale(1);box-shadow:var(--shadow-md);opacity:1}15%,20%{left:15%;transform:translateY(-50%) scale(1.05);box-shadow:0 0 0 4px #f970664d,var(--shadow-lg);border-color:var(--color-primary)}25%{left:15%;transform:translateY(-50%) scale(1.05)}55%{left:calc(85% + 14px);transform:translateY(-50%) scale(1.05);opacity:1}60%{left:calc(85% + 14px);transform:translateY(-50%) scale(.5);opacity:0}65%,95%{left:calc(85% + 14px);opacity:0}to{left:15%;transform:translateY(-50%) scale(1);opacity:1}}.demo-trail{position:absolute;left:18%;right:18%;top:50%;height:40px;transform:translateY(-50%);opacity:0;animation:trailShow 5s ease-in-out infinite}@keyframes trailShow{0%,20%{opacity:0}30%,50%{opacity:.6}60%,to{opacity:0}}.demo-table{position:absolute;right:15%;top:50%;transform:translateY(-50%);width:80px;height:80px;background:var(--color-secondary);border:3px solid var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);animation:tableGlow 5s ease-in-out infinite}@keyframes tableGlow{0%,50%{box-shadow:var(--shadow-md);border-color:var(--color-primary)}55%,70%{box-shadow:0 0 0 6px #4ade804d,var(--shadow-lg);border-color:var(--color-success)}80%,to{box-shadow:var(--shadow-md);border-color:var(--color-primary)}}.demo-capacity{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text);position:relative}.capacity-before,.capacity-after{display:inline-block}.capacity-before{animation:showBefore 5s ease-in-out infinite}.capacity-after{position:absolute;left:0;animation:showAfter 5s ease-in-out infinite}@keyframes showBefore{0%,55%{opacity:1}58%,95%{opacity:0}98%,to{opacity:1}}@keyframes showAfter{0%,55%{opacity:0}58%,95%{opacity:1}98%,to{opacity:0}}.demo-seat{position:absolute;width:24px;height:24px}.demo-seated{width:100%;height:100%;border-radius:50%;border:2px solid white;box-shadow:var(--shadow-sm)}.demo-seated.family{background:var(--rel-family)}.demo-seated.friend{background:var(--rel-friend)}.demo-seated.colleague{background:var(--rel-colleague)}.demo-seated.new-guest{background:var(--color-primary);opacity:0;animation:newGuestAppear 5s ease-in-out infinite}@keyframes newGuestAppear{0%,55%{opacity:0;transform:scale(.5)}60%,95%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.5)}}.demo-success{position:absolute;right:calc(15% - 60px);top:25%;width:32px;height:32px;background:var(--color-success);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transform:scale(.5);animation:successShow 5s ease-in-out infinite}.demo-success svg{width:18px;height:18px}@keyframes successShow{0%,55%{opacity:0;transform:scale(.5)}60%,75%{opacity:1;transform:scale(1)}80%,to{opacity:0;transform:scale(.5)}}.coming-soon-section{padding:2rem 0}.coming-soon-header{text-align:center;margin-bottom:1.5rem}.coming-soon-header h2{font-family:Caveat,cursive;font-size:1.75rem;color:var(--color-accent);font-weight:600}.coming-soon-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}.coming-soon-card{background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:1.25rem;border:1px dashed var(--color-border);transition:all .2s var(--ease-out)}.coming-soon-card:hover{border-color:var(--color-accent)}.coming-soon-card h3{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.coming-soon-card h3:before{content:"";width:8px;height:8px;background:var(--color-secondary);border-radius:50%;flex-shrink:0}.coming-soon-card p{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5;margin:0}.supported-platforms{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.75rem;font-size:.8125rem}.platforms-label{color:var(--color-text-secondary)}.platform-name{padding:.25rem .5rem;background:var(--color-bg);border-radius:var(--radius-sm);color:var(--color-text);font-weight:500}.platform-name.coming-soon{opacity:.6}.platform-name.coming-soon small{font-weight:400;font-size:.7em}.email-capture{padding:3rem 2rem;text-align:center;background:var(--color-bg);border-radius:var(--radius-xl);margin:2rem 0;box-shadow:var(--shadow-md)}.email-capture h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:.5rem}.email-description{color:var(--color-text-secondary);font-size:var(--font-size-base);margin-bottom:1.5rem}.email-form{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.email-input{padding:.875rem 1.25rem;font-size:var(--font-size-base);border:2px solid var(--color-border);border-radius:var(--radius-md);width:260px;font-family:inherit;transition:all .2s var(--ease-out)}.email-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #f9706626}.subscribe-button{display:inline-block;padding:.875rem 1.5rem;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-accent);border:none;border-radius:var(--radius-md);cursor:pointer;text-decoration:none;transition:all .2s var(--ease-out)}.subscribe-button:hover{background:var(--color-primary);transform:translateY(-2px)}.subscribe-button:active{transform:translateY(0)}.landing-footer{text-align:center;padding:2rem 1rem;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.footer-meta{display:flex;align-items:center;justify-content:center;gap:1rem;margin-bottom:.75rem}.version-tag{font-size:var(--font-size-xs);color:var(--color-text-secondary);opacity:.7}.trust-line{font-size:var(--font-size-xs);opacity:.8;margin:0}@media(max-width:768px){.landing-content{padding:1.5rem}.hero-section{padding:3rem 1rem 2rem}.landing-logo{font-size:2.5rem}.logo-ify{font-size:3rem}.landing-tagline{font-size:var(--font-size-xl)}.landing-description{font-size:var(--font-size-base)}.feature-card:nth-child(odd),.feature-card:nth-child(2n){margin-left:0;margin-right:0}.feature-card:hover{transform:none}.demo-container{height:160px;max-width:350px}.demo-table{width:70px;height:70px}.demo-seat{width:20px;height:20px}.email-input{width:100%;max-width:300px}}@media(max-width:480px){.landing-content{padding:1rem}.hero-section{padding:2rem .5rem 1.5rem}.landing-logo{font-size:2rem}.logo-ify{font-size:2.5rem}.logo-wrapper:after{width:80px}.landing-tagline{font-size:var(--font-size-lg)}.landing-description{font-size:var(--font-size-sm);padding:0 .5rem}.cta-button{width:100%;padding:1rem 1.5rem;font-size:var(--font-size-base)}.feature-card{padding:1.25rem;flex-direction:column;align-items:center;text-align:center}.feature-content h3{font-size:var(--font-size-base)}.feature-content p{font-size:var(--font-size-sm)}.demo-container{height:140px;max-width:280px}.demo-guest-chip{padding:.375rem .75rem;font-size:var(--font-size-xs)}.demo-table{width:60px;height:60px}.demo-seat{width:18px;height:18px}.demo-success{width:24px;height:24px}.demo-success svg{width:14px;height:14px}.email-capture{padding:2rem 1rem;margin:1rem 0}.email-form{flex-direction:column;align-items:center}.email-input,.subscribe-button{width:100%;max-width:280px}}@media(prefers-color-scheme:dark){.landing-page{background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}.landing-page:before{background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%' height='100%' filter='url(%23noise)' opacity='0.02'/%3E%3C/svg%3E")}.cta-button{box-shadow:0 4px 0 var(--color-primary-dark),0 8px 20px #ff8a7d33}.cta-button:hover{box-shadow:0 2px 0 var(--color-primary-dark),0 4px 12px #ff8a7d40}.feature-card{background:var(--color-bg-secondary)}.feature-card:before{background:linear-gradient(135deg,transparent 50%,var(--color-bg) 50%)}.demo-container,.demo-guest-chip,.email-capture{background:var(--color-bg-secondary)}}:root[data-theme=dark] .landing-page{background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}:root[data-theme=dark] .feature-card{background:var(--color-bg-secondary)}:root[data-theme=dark] .feature-card:before{background:linear-gradient(135deg,transparent 50%,var(--color-bg) 50%)}:root[data-theme=dark] .demo-container{background:var(--color-bg-secondary)}:root[data-theme=dark] .demo-guest-chip{background:var(--color-bg-secondary)}:root[data-theme=dark] .email-capture{background:var(--color-bg-secondary)}@keyframes floatShape{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-12px) rotate(3deg)}}@keyframes floatShapeSlow{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(-2deg)}}.floating-shapes{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}.floating-shape{position:absolute;opacity:.18;animation:floatShape 8s ease-in-out infinite}.shape-table-round{top:6%;right:3%;width:140px;height:140px;color:var(--color-primary);animation-delay:0s}.shape-guest-1{top:28%;left:4%;width:60px;height:60px;color:var(--color-secondary);animation:floatShapeSlow 10s ease-in-out infinite;animation-delay:-3s}.shape-table-rect{bottom:8%;left:3%;width:160px;height:95px;color:var(--color-secondary);animation:floatShapeSlow 12s ease-in-out infinite;animation-delay:-4s}.shape-heart{top:12%;left:12%;width:50px;height:50px;color:var(--color-primary);animation-delay:-1s}.shape-guest-2{top:65%;right:5%;width:55px;height:55px;color:var(--color-primary);animation-delay:-5s}.shape-namecard{top:42%;right:4%;width:90px;height:55px;color:var(--color-primary);animation:floatShapeSlow 11s ease-in-out infinite;animation-delay:-2s}@media(max-width:768px){.floating-shapes{display:none}}.updates-btn--landing{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.updates-btn--landing:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.updates-btn--header{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.updates-btn--header:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:scale(1.1)}.updates-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn var(--duration-fast) var(--ease-out);padding:1rem}.updates-popup{background:var(--color-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:80vh;display:flex;flex-direction:column;animation:slideUp var(--duration-normal) var(--ease-spring)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.updates-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border-light)}.updates-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.updates-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-bg-secondary);border:none;border-radius:50%;font-size:1.25rem;color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.updates-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.updates-content{flex:1;overflow-y:auto;padding:1.5rem}.update-section{margin-bottom:1.5rem}.update-section:last-child{margin-bottom:0}.update-version{display:inline-block;padding:.25rem .625rem;margin-bottom:.5rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border-radius:var(--radius-full)}.update-list{margin:0;padding-left:1.5rem;list-style:none;text-align:left}.update-list li{position:relative;padding:.375rem 0 .375rem .5rem;font-size:var(--font-size-sm);color:var(--color-text);line-height:var(--line-height-relaxed);text-align:left}.update-list li:before{content:"•";position:absolute;left:-.75rem;color:var(--color-primary);font-weight:700}.updates-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border-light);text-align:center}.current-version{font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media(max-width:480px){.updates-overlay{padding:.5rem;align-items:flex-end}.updates-popup{max-height:85vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.updates-header{padding:1rem 1.25rem}.updates-header h2{font-size:var(--font-size-lg)}.updates-content{padding:1.25rem}.updates-btn--landing{padding:.5rem 1rem;font-size:var(--font-size-xs)}}@media(prefers-color-scheme:dark){.updates-overlay{background:#000000b3}.updates-popup{background:var(--color-bg-secondary)}}.event-form-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:550px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalSlideUp var(--duration-slow) var(--ease-spring)}.event-form-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border-light);position:sticky;top:0;background:var(--color-bg);z-index:10}.event-form-modal .modal-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.event-form-modal .close-btn{width:36px;height:36px;border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-bg-secondary);font-size:var(--font-size-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-bounce)}.event-form-modal .close-btn:hover{background:var(--color-error-light);border-color:var(--color-error);color:var(--color-error);transform:rotate(90deg)}.event-form-modal form{padding:1.5rem}.event-form-modal .form-section{margin-bottom:1.5rem;animation:fadeIn var(--duration-normal) var(--ease-out) backwards}.event-form-modal .form-section:nth-child(1){animation-delay:0s}.event-form-modal .form-section:nth-child(2){animation-delay:.05s}.event-form-modal .form-section h3{margin:0 0 1rem;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);font-weight:var(--font-weight-bold)}.event-form-modal .form-row{margin-bottom:1rem}.event-form-modal .form-row:last-child{margin-bottom:0}.event-form-modal .form-row.two-columns{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.event-form-modal label{display:flex;flex-direction:column;gap:.5rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.event-form-modal input[type=text],.event-form-modal input[type=date],.event-form-modal input[type=number],.event-form-modal select,.event-form-modal textarea{padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text);background:var(--color-bg);transition:all var(--duration-fast) var(--ease-out);width:100%;box-sizing:border-box}.event-form-modal input:focus,.event-form-modal select:focus,.event-form-modal textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.event-form-modal input::placeholder,.event-form-modal textarea::placeholder{color:var(--color-text-light)}.event-form-modal textarea{resize:vertical;min-height:60px}.event-form-modal .form-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border-light);margin-top:.5rem}.event-form-modal .btn-cancel{padding:.75rem 1.25rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.event-form-modal .btn-cancel:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.event-form-modal .btn-submit{padding:.75rem 1.5rem;border:none;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fff;cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d}.event-form-modal .btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f9706666}@media(max-width:600px){.event-form-modal{width:100%;margin:1rem}.event-form-modal .form-row.two-columns{grid-template-columns:1fr}.event-form-modal .form-actions{flex-direction:column}.event-form-modal .btn-cancel,.event-form-modal .btn-submit{width:100%}}.delete-event-dialog{background:var(--color-bg);border-radius:var(--radius-xl);padding:2rem;width:400px;max-width:90vw;text-align:center;box-shadow:var(--shadow-xl);animation:modalSlideUp var(--duration-slow) var(--ease-spring)}.dialog-icon{font-size:3rem;margin-bottom:1rem}.delete-event-dialog h2{margin:0 0 .5rem;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.event-name-display{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary);margin:0 0 1rem;padding:.5rem 1rem;background:var(--color-primary-light);border-radius:var(--radius-md);display:inline-block}.warning-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:1rem;line-height:1.5}.deletion-summary{display:flex;justify-content:center;gap:1.5rem;padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:1.5rem}.summary-item{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text)}.summary-icon{font-size:1rem}.dialog-actions{display:flex;gap:.75rem;justify-content:center}.delete-event-dialog .btn-cancel{flex:1;padding:.75rem 1.25rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.delete-event-dialog .btn-cancel:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.delete-event-dialog .btn-delete{flex:1;padding:.75rem 1.25rem;border:none;border-radius:var(--radius-md);background:var(--color-error);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fff;cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.delete-event-dialog .btn-delete:hover{background:var(--color-error-hover, #dc2626);transform:translateY(-2px);box-shadow:0 4px 12px #ef444466}@media(max-width:480px){.delete-event-dialog{padding:1.5rem}.dialog-actions{flex-direction:column}}.event-list-view{padding:2rem;overflow-y:auto;height:100%;flex:1;max-width:1200px;margin:0 auto}.event-list-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.header-content h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0 0 .25rem}.header-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.create-event-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d;white-space:nowrap}.create-event-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #f9706666}.create-event-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon{font-size:1.25rem;line-height:1}.header-actions{display:flex;align-items:center;gap:1rem}.view-toggle{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem;gap:.125rem}.view-toggle-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:transparent;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.view-toggle-btn:hover{color:var(--color-text);background:var(--color-bg)}.view-toggle-btn.active{background:var(--color-bg);color:var(--color-primary);box-shadow:var(--shadow-sm)}.view-toggle-btn svg{width:16px;height:16px}.view-toggle-label{display:inline}.limit-warning{background:var(--color-warning-light);color:var(--color-warning);padding:.75rem 1rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:1.5rem;text-align:center}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;background:var(--color-bg);border:2px dashed var(--color-border);border-radius:var(--radius-xl);animation:fadeIn var(--duration-normal) var(--ease-out)}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-state h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0 0 .5rem}.empty-state p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 1.5rem}.create-first-btn{display:flex;align-items:center;gap:.5rem;padding:1rem 2rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d}.create-first-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f9706666}.event-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-bottom:1.5rem}.event-card{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);padding:1.5rem;cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:var(--shadow-sm);animation:fadeIn var(--duration-normal) var(--ease-out)}.event-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.event-card:focus{outline:none;box-shadow:0 0 0 3px var(--color-primary-light)}.event-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.event-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0;line-height:1.3;flex:1}.event-type-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:.25rem .625rem;border-radius:var(--radius-full);white-space:nowrap}.badge-wedding{background:var(--badge-wedding-bg);color:var(--badge-wedding-text)}.badge-corporate{background:var(--badge-corporate-bg);color:var(--badge-corporate-text)}.badge-gala{background:var(--badge-gala-bg);color:var(--badge-gala-text)}.badge-party{background:var(--badge-party-bg);color:var(--badge-party-text)}.badge-social{background:var(--badge-social-bg);color:var(--badge-social-text)}.badge-other{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.event-date,.event-venue{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:.5rem}.date-icon,.venue-icon{font-size:1rem}.event-card-stats{display:flex;gap:1.5rem;padding:1rem 0;margin:.75rem 0;border-top:1px solid var(--color-border-light);border-bottom:1px solid var(--color-border-light)}.stat{display:flex;align-items:center;gap:.375rem}.stat-icon{font-size:1rem}.stat-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.event-card-actions{display:flex;gap:.75rem;margin-top:.75rem}.card-action-btn{flex:1;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.card-action-btn.edit{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.card-action-btn.edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.card-action-btn.delete{background:transparent;color:var(--color-text-light);border:1px solid var(--color-border-light)}.card-action-btn.delete:hover{border-color:var(--color-error);color:var(--color-error);background:var(--color-error-light)}.event-list-table{background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);overflow:hidden;margin-bottom:1.5rem}.event-list-header-row{display:grid;grid-template-columns:2fr 1fr 1fr .75fr .75fr 1fr;gap:1rem;padding:.875rem 1.25rem;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.025em}.event-list-row{display:grid;grid-template-columns:2fr 1fr 1fr .75fr .75fr 1fr;gap:1rem;padding:1rem 1.25rem;align-items:center;border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.event-list-row:last-child{border-bottom:none}.event-list-row:hover{background:var(--color-bg-hover)}.event-list-row:focus{outline:none;background:var(--color-bg-hover);box-shadow:inset 0 0 0 2px var(--color-primary-light)}.event-list-row .col-name{display:flex;flex-direction:column;gap:.125rem}.event-list-row .event-name{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text)}.event-list-row .event-venue-inline{font-size:var(--font-size-xs);color:var(--color-text-light)}.event-list-row .col-date{font-size:var(--font-size-sm);color:var(--color-text)}.event-list-row .no-date{color:var(--color-text-light)}.event-list-row .col-guests,.event-list-row .col-tables{text-align:center}.event-list-row .stat-value{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text)}.event-list-row .col-actions{display:flex;gap:.5rem;justify-content:flex-end}.list-action-btn{padding:.375rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.list-action-btn.edit{background:var(--color-bg-secondary);color:var(--color-text);border:1px solid var(--color-border)}.list-action-btn.edit:hover{border-color:var(--color-primary);color:var(--color-primary)}.list-action-btn.delete{background:transparent;color:var(--color-text-light);border:1px solid var(--color-border-light)}.list-action-btn.delete:hover{border-color:var(--color-error);color:var(--color-error);background:var(--color-error-light)}.event-count{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-light)}@media(max-width:768px){.event-list-view{padding:1rem}.event-list-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:row;justify-content:space-between}.view-toggle-label{display:none}.view-toggle-btn{padding:.5rem}.create-event-btn{justify-content:center;flex:1}.event-cards-grid{grid-template-columns:1fr}.event-list-header-row{display:none}.event-list-row{display:flex;flex-direction:column;gap:.75rem;padding:1rem}.event-list-row .col-name{width:100%}.event-list-row .col-type{position:absolute;top:1rem;right:1rem}.event-list-row{position:relative}.event-list-row .col-date,.event-list-row .col-guests,.event-list-row .col-tables{display:inline-flex;align-items:center;gap:.25rem}.event-list-row .col-date:before{content:"📅";font-size:.875rem}.event-list-row .col-guests:before{content:"👥";font-size:.875rem}.event-list-row .col-tables:before{content:"🪑";font-size:.875rem}.event-list-row .col-date,.event-list-row .col-guests,.event-list-row .col-tables{text-align:left}.event-list-row .col-actions{width:100%;justify-content:stretch}.event-list-row .list-action-btn{flex:1;justify-content:center}}@media(max-width:480px){.header-actions{flex-wrap:wrap}.view-toggle{order:2;width:100%;justify-content:center}.create-event-btn{width:100%;order:1}.event-card-stats{flex-direction:column;gap:.75rem}.event-card-actions{flex-direction:column}}.qr-info-page{min-height:100vh;background:linear-gradient(135deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);display:flex;align-items:center;justify-content:center;padding:1rem}.qr-info-container{width:100%;max-width:400px;display:flex;flex-direction:column;gap:1.5rem}.qr-info-header{text-align:center}.qr-brand{font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.qr-brand .logo-seat{color:var(--color-text)}.qr-brand .logo-ify{color:var(--color-primary)}.event-name{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:.5rem 0 0}.event-date{font-size:.875rem;color:var(--color-text-secondary);margin:.25rem 0 0}.qr-table-card{background:var(--color-bg);border:2px solid var(--color-primary);border-radius:var(--radius-xl);padding:2rem;text-align:center;box-shadow:var(--shadow-lg)}.table-badge{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-bg);border-radius:50%;color:var(--color-primary);margin-bottom:1rem}.table-name{font-size:2rem;font-weight:700;color:var(--color-text);margin:0 0 .5rem}.table-capacity{font-size:.875rem;color:var(--color-text-secondary);margin:0}.qr-guest-list{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.qr-guest-list h3{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin:0 0 1rem}.qr-guest-list h3 svg{color:var(--color-primary)}.qr-guest-list ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.75rem}.qr-guest-list li{display:flex;align-items:center;gap:.75rem;font-size:1rem;color:var(--color-text);padding:.5rem 0;border-bottom:1px solid var(--color-border)}.qr-guest-list li:last-child{border-bottom:none}.qr-guest-list li:before{content:"";width:8px;height:8px;background:var(--color-primary);border-radius:50%;flex-shrink:0}.qr-no-guests{text-align:center;padding:2rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);color:var(--color-text-secondary)}.qr-info-error{text-align:center;padding:2rem}.error-icon{color:var(--color-warning);margin-bottom:1rem}.qr-info-error h2{font-size:1.25rem;color:var(--color-text);margin:0 0 .5rem}.qr-info-error p{color:var(--color-text-secondary);margin:0 0 1.5rem}.qr-info-loading{text-align:center;padding:3rem}.loading-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;margin:0 auto 1rem;animation:spin 1s linear infinite}.qr-info-loading p{color:var(--color-text-secondary);margin:0}.qr-info-footer{text-align:center;padding-top:1rem}.cta-button{display:inline-flex;align-items:center;justify-content:center;padding:.875rem 2rem;background:var(--color-primary);color:#fff;font-size:1rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast)}.cta-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.cta-button-secondary{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;background:transparent;color:var(--color-primary);font-size:.875rem;font-weight:500;border:1px solid var(--color-primary);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast)}.cta-button-secondary:hover{background:var(--color-primary-bg)}@media(max-width:480px){.qr-info-page{padding:.5rem}.qr-table-card{padding:1.5rem}.table-name{font-size:1.75rem}.qr-guest-list{padding:1rem}}.readonly-canvas-container{display:flex;flex-direction:column;flex:1;min-height:0;background:var(--color-bg-secondary)}.readonly-canvas-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.readonly-header-left{display:flex;align-items:center;gap:1rem}.readonly-event-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.readonly-stats{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.readonly-header-right{display:flex;align-items:center;gap:.5rem}.readonly-grid-toggle{width:36px;height:36px;border:1px solid var(--color-border);background:var(--color-bg-secondary);border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all var(--duration-fast)}.readonly-grid-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.readonly-grid-toggle.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.readonly-zoom-controls{display:flex;align-items:center;gap:.25rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.25rem}.readonly-zoom-controls button{width:28px;height:28px;border:none;background:transparent;color:var(--color-text);font-size:var(--font-size-base);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--duration-fast)}.readonly-zoom-controls button:hover{background:var(--color-bg-tertiary)}.readonly-zoom-controls .zoom-display{font-size:var(--font-size-xs);color:var(--color-text-secondary);min-width:40px;text-align:center}.readonly-zoom-controls .recenter-btn{font-size:var(--font-size-lg)}.readonly-canvas{flex:1;overflow:hidden;position:relative;cursor:grab;background:var(--color-bg-secondary)}.readonly-canvas:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(249,112,102,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(255,176,136,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.readonly-canvas.show-grid{background-image:radial-gradient(circle,var(--color-border) 1.5px,transparent 1.5px);background-size:24px 24px}.readonly-canvas:active{cursor:grabbing}.readonly-canvas-content{position:absolute;width:3000px;height:3000px;transition:opacity var(--duration-normal)}.readonly-table-wrapper{position:absolute}.readonly-table{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(145deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);border:3px solid var(--color-border);box-shadow:var(--shadow-lg);transition:border-color var(--duration-normal),box-shadow var(--duration-normal)}.readonly-table:hover{border-color:var(--color-primary);box-shadow:var(--shadow-xl)}.readonly-table-round,.readonly-table-oval{border-radius:50%}.readonly-table-rectangle,.readonly-table-square{border-radius:var(--radius-xl)}.readonly-table-half-round{border-radius:0 0 50% 50%/0 0 100% 100%}.readonly-table-serpentine{border-radius:var(--radius-xl);background:linear-gradient(90deg,var(--color-bg) 0%,var(--color-bg-secondary) 25%,var(--color-bg) 50%,var(--color-bg-secondary) 75%,var(--color-bg) 100%)}.readonly-table .table-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);text-align:center}.readonly-table .table-count{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);background:var(--color-bg-secondary);padding:.25rem .5rem;border-radius:var(--radius-full);margin-top:.25rem}.readonly-table .table-count.capacity-available{color:var(--color-text-secondary)}.readonly-table .table-count.capacity-nearly-full{color:#78350f;background:var(--color-warning-light)}.readonly-table .table-count.capacity-full{color:var(--color-success);background:var(--color-success-light);font-weight:var(--font-weight-semibold)}.readonly-table .table-count.capacity-over{color:var(--color-error);background:var(--color-error-light);font-weight:var(--font-weight-bold)}.readonly-table.capacity-full{border-color:var(--color-success)}.readonly-table.capacity-over{border-color:var(--color-error)}.readonly-capacity-ring{z-index:-1}.capacity-progress{transition:stroke-dashoffset var(--duration-slow) var(--ease-out)}.capacity-progress.capacity-available{stroke:var(--color-success)}.capacity-progress.capacity-nearly-full{stroke:var(--color-warning)}.capacity-progress.capacity-full{stroke:var(--color-success)}.capacity-progress.capacity-over{stroke:var(--color-error)}.readonly-violation-badge{position:absolute;top:-12px;left:-12px;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:.25rem;cursor:help;z-index:20}.readonly-violation-badge.preferred{background:var(--color-warning);color:#78350f}.readonly-violation-badge.required{background:var(--color-error);color:#fff}.readonly-dietary-summary{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--color-bg);border-radius:var(--radius-full);font-size:var(--font-size-xs);box-shadow:var(--shadow-sm);cursor:help;opacity:.7;transition:opacity var(--duration-fast);z-index:5;border:1px solid var(--color-border-light)}.readonly-table:hover .readonly-dietary-summary{opacity:1}.readonly-guest{position:absolute;width:48px;height:48px;transform:translate(-50%,-50%);cursor:pointer;transition:transform var(--duration-fast) var(--ease-bounce)}.readonly-guest:hover{transform:translate(-50%,-50%) scale(1.15);z-index:10}.readonly-guest .guest-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:2px solid var(--color-bg);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md);transition:transform var(--duration-fast) var(--ease-bounce),box-shadow var(--duration-fast)}.readonly-guest:hover .guest-circle{box-shadow:var(--shadow-lg)}.readonly-guest.has-group .guest-circle{border-style:solid}.readonly-guest .guest-initials{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:#fff;text-transform:uppercase}.readonly-guest .status-dot{position:absolute;top:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-bg)}.readonly-guest .group-dot{position:absolute;top:0;left:0;width:12px;height:12px;border-radius:50%;border:2px solid var(--color-bg);box-shadow:var(--shadow-sm)}.readonly-guest .dietary-icon{position:absolute;bottom:0;left:0;font-size:10px;background:var(--color-bg);border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.readonly-guest .accessibility-icon{position:absolute;bottom:0;right:0;font-size:10px;background:var(--color-info-light);border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.readonly-guest-unassigned .guest-circle{background:var(--color-bg-tertiary);border:2px dashed var(--color-border)}.readonly-guest-unassigned .guest-initials{color:var(--color-text-secondary)}.readonly-venue-element{position:absolute;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:2px dashed var(--color-border);border-radius:var(--radius-md);opacity:.7}.readonly-venue-element .venue-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.readonly-venue-dance-floor{background:#f970661a;border-color:var(--color-primary)}.readonly-venue-stage{background:#3b82f61a;border-color:#3b82f6}.readonly-venue-bar{background:#8b5cf61a;border-color:#8b5cf6}.readonly-venue-buffet{background:#10b9811a;border-color:#10b981}.readonly-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--color-text-secondary)}.readonly-tooltip{position:fixed;z-index:1000;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.5rem .75rem;font-size:var(--font-size-sm);color:var(--color-text);box-shadow:var(--shadow-lg);pointer-events:none;max-width:220px;white-space:pre-wrap}@media(max-width:600px){.readonly-canvas-header{flex-direction:column;gap:.5rem;align-items:flex-start}.readonly-header-right{width:100%;justify-content:space-between}.readonly-event-name{font-size:var(--font-size-base)}.readonly-guest{width:40px;height:40px}.readonly-guest .guest-circle{width:36px;height:36px}.readonly-guest .guest-initials{font-size:var(--font-size-xs)}}.shareable-page{min-height:100vh;background:linear-gradient(135deg,#fdf2f1,#fff,#f0f7ff);display:flex;align-items:center;justify-content:center;padding:1rem}.shareable-page-full{padding:0;flex-direction:column;background:var(--color-bg-secondary)}.shareable-container{max-width:480px;width:100%;text-align:center}.shareable-header{margin-bottom:2rem}.shareable-brand{font-size:2rem;font-weight:var(--font-weight-bold);margin:0}.shareable-brand .logo-seat{color:var(--color-text)}.shareable-brand .logo-ify{color:var(--color-primary);font-family:Caveat,cursive;font-size:1.15em;font-weight:600;vertical-align:baseline}.shareable-upload-prompt{background:var(--color-bg);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg)}.shareable-upload-prompt .upload-icon{color:var(--color-primary);margin-bottom:1.5rem}.shareable-upload-prompt h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 .5rem}.shareable-upload-prompt p{color:var(--color-text-secondary);margin:0 0 1.5rem}.upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-fast);margin-bottom:1rem}.upload-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f970664d}.upload-btn:disabled{opacity:.5;cursor:not-allowed}.secondary-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline;transition:color var(--duration-fast)}.secondary-btn:hover{color:var(--color-primary)}.shareable-error{background:var(--color-bg);border-radius:var(--radius-xl);padding:2.5rem;box-shadow:var(--shadow-lg)}.shareable-error .error-icon{color:var(--color-warning);margin-bottom:1.5rem}.shareable-error h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0 0 .5rem}.shareable-error p{color:var(--color-text-secondary);margin:0 0 1.5rem}.error-actions{display:flex;flex-direction:column;gap:.75rem}.shareable-topbar{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.shareable-topbar-left{display:flex;align-items:center;gap:.75rem}.shareable-brand-small{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin:0}.shareable-brand-small .logo-seat{color:var(--color-text)}.shareable-brand-small .logo-ify{color:var(--color-primary);font-family:Caveat,cursive;font-size:1.15em;font-weight:600;vertical-align:baseline}.shareable-badge{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-primary);background:var(--color-primary-light);padding:.25rem .5rem;border-radius:var(--radius-full)}.shareable-topbar-right{display:flex;align-items:center;gap:.5rem}.topbar-btn{padding:.5rem 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast)}.topbar-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.shareable-canvas-wrapper{flex:1;display:flex;overflow:hidden;min-height:0;height:0}@media(max-width:600px){.shareable-upload-prompt,.shareable-error{padding:1.5rem}.shareable-brand{font-size:1.5rem}.shareable-topbar{flex-direction:column;gap:.5rem;padding:.5rem}.shareable-topbar-left,.shareable-topbar-right{width:100%;justify-content:center}.topbar-btn{font-size:var(--font-size-xs);padding:.375rem .75rem}}:root[data-theme=dark] .shareable-page{background:linear-gradient(135deg,#1a1412,#241c18,#1a1820)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .shareable-page{background:linear-gradient(135deg,#1a1412,#241c18,#1a1820)}}.header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.5rem;background:#fffcfad9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--color-border-light);gap:2rem;position:relative;z-index:100}[data-theme=dark] .header{background:#1a1412e6}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .header{background:#1a1412e6}}.header-left{display:flex;align-items:center;gap:1.5rem}.back-to-events-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem .75rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.back-to-events-btn:hover{background:var(--color-bg);border-color:var(--color-primary);color:var(--color-primary)}.back-arrow{font-size:1.125rem;line-height:1}.back-text{line-height:1}@media(max-width:600px){.back-text{display:none}.back-to-events-btn{padding:.5rem}}.logo{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold);margin:0;letter-spacing:var(--letter-spacing-tight);transition:all var(--duration-normal) var(--ease-bounce);position:relative;display:inline-block;padding-bottom:4px}.logo:after{content:"";position:absolute;bottom:0;left:50%;width:70px;height:6px;transform:translate(-50%);background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 70 6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 4 Q17 1, 35 4 T68 3' stroke='%23f97066' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;opacity:.8}.logo:hover{transform:scale(1.02)}.logo:hover:after{opacity:1}.header .logo-seat{color:var(--color-text)}.header .logo-ify{color:var(--color-primary);font-family:Caveat,cursive;font-size:1.15em;font-weight:600;vertical-align:baseline}.version-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.25rem .5rem;border-radius:var(--radius-full);font-weight:var(--font-weight-medium)}.tour-btn{display:flex;align-items:center;justify-content:center;padding:.25rem .625rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.tour-btn:hover{background:var(--color-secondary);border-color:var(--color-secondary);color:#fff}.help-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.help-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff;transform:scale(1.1)}.theme-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;font-size:var(--font-size-base);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.theme-btn:hover{background:var(--color-secondary);border-color:var(--color-secondary);color:var(--color-text);transform:scale(1.1)}.event-info{display:flex;align-items:center;gap:.75rem}.event-name-input{padding:.625rem 1rem;border:2px solid transparent;border-radius:var(--radius-lg);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);background:transparent;min-width:200px;transition:all var(--duration-normal) var(--ease-out)}.event-name-input:focus{border-color:var(--color-primary);background:var(--color-bg);box-shadow:var(--shadow-md);outline:none}.event-type-select{padding:.5rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);cursor:pointer;background:var(--color-bg);transition:all var(--duration-normal) var(--ease-bounce)}.event-type-select:hover{border-color:var(--color-primary);transform:translateY(-1px)}.undo-redo-group{display:flex;gap:.25rem;margin-left:1rem;padding-left:1rem;border-left:1px solid var(--color-border)}.undo-btn,.redo-btn{width:36px;height:36px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:1.1rem;cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);display:flex;align-items:center;justify-content:center}.undo-btn:hover:not(:disabled),.redo-btn:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-1px)}.undo-btn:disabled,.redo-btn:disabled{opacity:.4;cursor:not-allowed}.header-nav{display:flex;gap:.5rem;background:var(--color-bg-secondary);padding:.25rem;border-radius:var(--radius-lg)}.nav-btn{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-secondary);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.nav-btn:hover{background:var(--color-bg);color:var(--color-text);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.nav-btn.active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;box-shadow:var(--shadow-md)}.nav-btn.active:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.header-right{display:flex;gap:.75rem}.action-btn{padding:.625rem 1.25rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.action-btn:hover{background:var(--color-bg-secondary);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-btn.danger{color:var(--color-error);border-color:var(--color-error-light)}.action-btn.danger:hover{background:var(--color-error);color:#fff;border-color:var(--color-error)}.action-btn.demo-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;font-weight:var(--font-weight-semibold);animation:demoShimmer 3s ease-in-out infinite}.action-btn.demo-btn:hover{background:linear-gradient(135deg,#5a6fd6,#6a4190);transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@keyframes demoShimmer{0%,to{box-shadow:0 2px 8px #667eea4d}50%{box-shadow:0 4px 16px #667eea80}}.import-modal{background:var(--color-bg);border-radius:var(--radius-xl);padding:2rem;max-width:500px;width:100%;animation:modalSlideUp var(--duration-slow) var(--ease-spring);box-shadow:var(--shadow-xl)}.import-modal h2{margin-bottom:1.5rem;font-size:var(--font-size-xl)}.import-option{padding:1.25rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1rem;transition:all var(--duration-normal) var(--ease-out)}.import-option:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.import-option h3{margin-bottom:.5rem;font-size:var(--font-size-base);font-weight:var(--font-weight-bold)}.import-option p{margin:0 0 1rem;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.import-option input[type=file]{width:100%}.close-modal{width:100%;padding:.875rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg);font-weight:var(--font-weight-semibold);cursor:pointer;margin-top:1rem;transition:all var(--duration-normal) var(--ease-bounce)}.close-modal:hover{background:var(--color-bg-secondary);border-color:var(--color-primary)}@media(max-width:1024px){.header{flex-wrap:wrap;gap:1rem;padding:.75rem 1rem}.header-left{flex:1;min-width:0;gap:1rem}.header-nav{order:3;width:100%;justify-content:center;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-btn{padding:.5rem 1rem;font-size:var(--font-size-xs);white-space:nowrap}.event-name-input{min-width:150px;padding:.5rem .75rem;font-size:var(--font-size-sm)}}@media(max-width:768px){.header{padding:.625rem .875rem}.logo{font-size:var(--font-size-lg)}.header-left{gap:.75rem}.event-info{flex-direction:column;align-items:flex-start;gap:.5rem}.event-name-input{min-width:120px;width:100%}.event-type-select{padding:.375rem .75rem;font-size:.625rem}.header-nav{gap:.25rem;padding:.125rem}.nav-btn{padding:.5rem .75rem;font-size:.625rem}.header-right{gap:.5rem}.action-btn{padding:.5rem .875rem;font-size:var(--font-size-xs)}}@media(max-width:480px){.header{padding:.5rem .75rem}.logo{font-size:var(--font-size-base)}.event-info{display:none}.header-nav{flex-wrap:nowrap;justify-content:center;gap:.25rem;padding:.25rem;overflow-x:auto;-webkit-overflow-scrolling:touch}.nav-btn{padding:.75rem 1rem;min-height:44px;min-width:auto;flex:1;text-align:center;font-size:var(--font-size-xs)}.undo-redo-group{margin-left:.5rem;padding-left:.5rem}.undo-btn,.redo-btn{width:44px;height:44px}.header-right{position:fixed;bottom:0;left:0;right:0;background:var(--color-bg);border-top:1px solid var(--color-border-light);padding:.5rem .75rem;padding-bottom:calc(.5rem + env(safe-area-inset-bottom,0));justify-content:center;gap:.5rem;z-index:100;box-shadow:0 -4px 12px #0000001a}.action-btn{flex:1;text-align:center;min-height:44px;padding:.75rem .5rem}.import-modal{margin:1rem;padding:1.5rem;max-height:90vh;overflow-y:auto}}.modal-overlay{position:fixed;inset:0;background:#3d2c2466;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem;animation:overlayFade var(--duration-normal) var(--ease-out)}.guest-form-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:700px;min-width:500px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:modalSlideUp var(--duration-slow) var(--ease-spring)}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--color-border-light);position:sticky;top:0;background:var(--color-bg);z-index:10}.modal-header h2{margin:0;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold)}.close-btn{width:36px;height:36px;border-radius:var(--radius-md);border:2px solid var(--color-border);background:var(--color-bg-secondary);font-size:var(--font-size-lg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-bounce)}.close-btn:hover{background:var(--color-error-light);border-color:var(--color-error);color:var(--color-error);transform:rotate(90deg)}.guest-form-modal form{padding:1.75rem}.form-section{margin-bottom:1.75rem;animation:fadeIn var(--duration-normal) var(--ease-out) backwards}.form-section:nth-child(1){animation-delay:0s}.form-section:nth-child(2){animation-delay:.03s}.form-section:nth-child(3){animation-delay:.06s}.form-section:nth-child(4){animation-delay:.09s}.form-section h3{margin:0 0 1.25rem;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);font-weight:var(--font-weight-bold)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.form-section label{display:flex;flex-direction:column;gap:.5rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-bottom:1.25rem}.form-section input[type=text],.form-section input[type=email],.form-section select,.form-section textarea{padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-family:inherit;transition:all var(--duration-fast) var(--ease-out)}.form-section input:focus,.form-section select:focus,.form-section textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 4px var(--focus-ring-color)}.checkbox-group{display:flex;flex-wrap:wrap;gap:.875rem}.checkbox-label{display:flex;flex-direction:row;align-items:center;gap:.5rem;font-weight:var(--font-weight-medium);cursor:pointer;margin-bottom:0;padding:.5rem .75rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);transition:all var(--duration-fast) var(--ease-out)}.checkbox-label:hover{background:var(--color-primary-light)}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--color-primary)}.relationship-list{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1.25rem}.relationship-item{display:flex;align-items:center;gap:.625rem;padding:.75rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);animation:slideUp var(--duration-fast) var(--ease-out)}.rel-type{font-size:.625rem;padding:.375rem .625rem;border-radius:var(--radius-full);text-transform:uppercase;font-weight:var(--font-weight-bold);letter-spacing:var(--letter-spacing-wide)}.rel-type.family{background:var(--rel-family-bg);color:var(--color-text)}.rel-type.friend{background:var(--rel-friend-bg);color:var(--color-text)}.rel-type.colleague{background:var(--rel-colleague-bg);color:var(--color-text)}.rel-type.partner{background:var(--rel-partner-bg);color:var(--color-text)}.rel-type.acquaintance{background:var(--rel-acquaintance-bg);color:var(--color-text)}.rel-type.avoid{background:var(--rel-avoid-bg);color:var(--color-text)}.rel-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.rel-strength{color:var(--color-warning);font-size:var(--font-size-xs)}.rel-remove{width:24px;height:24px;border-radius:var(--radius-md);border:none;background:var(--color-bg);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast) var(--ease-bounce)}.rel-remove:hover{background:var(--color-error);color:#fff}.add-relationship{display:flex;gap:.625rem;align-items:center}.add-relationship select{flex:1;padding:.625rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.add-relationship input[type=range]{width:70px;accent-color:var(--color-primary)}.add-relationship button{padding:.625rem 1rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);transition:all var(--duration-normal) var(--ease-bounce)}.add-relationship button:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-md)}.add-relationship button:disabled{opacity:.5;cursor:not-allowed}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.25rem;border-top:1px solid var(--color-border-light);margin-top:1.25rem}.btn-primary{padding:.875rem 1.75rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9706666}.btn-secondary{padding:.875rem 1.75rem;background:var(--color-bg-secondary);color:var(--color-text);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.btn-secondary:hover{background:var(--color-bg);border-color:var(--color-primary);transform:translateY(-1px)}.btn-danger{padding:.875rem 1.75rem;background:linear-gradient(135deg,var(--color-error) 0%,var(--color-error-dark) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;margin-right:auto;transition:all var(--duration-normal) var(--ease-bounce)}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 4px 12px #f8717166}.guest-form-modal.success-flash{animation:formSuccessFlash var(--duration-normal) var(--ease-out)}@keyframes formSuccessFlash{0%,to{box-shadow:var(--shadow-xl)}50%{box-shadow:0 0 0 4px var(--color-success),var(--shadow-xl)}}.btn-accent{padding:.875rem 1.75rem;background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-hover) 100%);color:var(--color-text);border:none;border-radius:var(--radius-lg);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-out);box-shadow:0 4px 12px #ffb0884d}.btn-accent:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ffb08866}@media(max-width:768px){.modal-overlay{padding:1rem}.guest-form-modal{width:100%;min-width:auto;max-width:100%;max-height:100%;border-radius:var(--radius-lg)}.guest-form-modal form{padding:1.25rem}.form-row{grid-template-columns:1fr;gap:0}.form-section label{margin-bottom:1rem}.add-relationship{flex-wrap:wrap;gap:.5rem}.add-relationship select{flex:1 1 100%}.add-relationship input[type=range]{flex:1;min-width:100px}.add-relationship button{flex:1;min-height:44px}}@media(max-width:480px){.modal-overlay{padding:0}.guest-form-modal{border-radius:0;height:100%;max-height:100vh}.modal-header{padding:1rem}.modal-header h2{font-size:var(--font-size-lg)}.close-btn{width:44px;height:44px}.form-section h3{font-size:var(--font-size-xs);margin-bottom:1rem}.form-section input[type=text],.form-section input[type=email],.form-section select,.form-section textarea{min-height:44px;font-size:var(--font-size-base)}.checkbox-group{gap:.5rem}.checkbox-label{padding:.625rem .75rem;min-height:44px}.form-actions{flex-direction:column;gap:.75rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0))}.btn-primary,.btn-secondary,.btn-danger,.btn-accent{width:100%;min-height:48px;margin-right:0}.btn-danger{order:3}}.onboarding-overlay{position:fixed;inset:0;z-index:10001;pointer-events:auto}.onboarding-spotlight-svg{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.onboarding-backdrop{position:absolute;inset:0;background:#000000bf;animation:fadeIn var(--duration-fast) var(--ease-out)}.onboarding-spotlight-ring{position:fixed;border:3px solid var(--color-primary);border-radius:8px;pointer-events:none;animation:spotlightPulse 2s ease-in-out infinite;box-shadow:0 0 0 4px rgba(var(--color-primary-rgb, 231, 111, 81),.3)}@keyframes spotlightPulse{0%,to{box-shadow:0 0 0 4px rgba(var(--color-primary-rgb, 231, 111, 81),.3)}50%{box-shadow:0 0 0 8px rgba(var(--color-primary-rgb, 231, 111, 81),.1)}}.onboarding-tooltip{position:fixed;width:360px;max-width:calc(100vw - 32px);background:var(--color-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);animation:tooltipSlideIn var(--duration-normal) var(--ease-spring);pointer-events:auto;overflow:hidden}@keyframes tooltipSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.onboarding-tooltip--center{animation:tooltipScaleIn var(--duration-normal) var(--ease-spring)}@keyframes tooltipScaleIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.onboarding-tooltip-content{padding:1.5rem}.onboarding-tooltip-content h3{margin:0 0 .75rem;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text)}.onboarding-tooltip-content p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-relaxed)}.onboarding-tooltip-footer{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-bg-secondary);border-top:1px solid var(--color-border-light)}.onboarding-progress{display:flex;gap:6px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:all var(--duration-fast) var(--ease-out)}.onboarding-dot.active{background:var(--color-primary);transform:scale(1.25)}.onboarding-dot.completed{background:var(--color-primary);opacity:.5}.onboarding-nav{display:flex;gap:.5rem}.onboarding-btn{padding:.5rem 1rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.onboarding-btn--back{background:transparent;border:1px solid var(--color-border);color:var(--color-text-secondary)}.onboarding-btn--back:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark);color:var(--color-text)}.onboarding-btn--skip{background:transparent;border:1px solid transparent;color:var(--color-text-secondary)}.onboarding-btn--skip:hover{color:var(--color-text);text-decoration:underline}.onboarding-btn--next{background:var(--color-primary);border:1px solid var(--color-primary);color:#fff}.onboarding-btn--next:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}@media(max-width:768px){.onboarding-tooltip{width:340px;max-width:calc(100vw - 24px)}}@media(max-width:480px){.onboarding-tooltip{width:calc(100vw - 32px);max-width:none;inset:auto 16px 24px!important;transform:none!important}.onboarding-tooltip--center{top:50%!important;bottom:auto!important;transform:translateY(-50%)!important}.onboarding-tooltip-content{padding:1.25rem}.onboarding-tooltip-content h3{font-size:var(--font-size-base)}.onboarding-tooltip-content p{font-size:var(--font-size-sm);line-height:1.5}.onboarding-tooltip-footer{flex-direction:column;gap:.75rem;padding:1rem}.onboarding-progress{justify-content:center;width:100%}.onboarding-nav{width:100%;justify-content:space-between}.onboarding-btn{flex:1;padding:.75rem 1rem;text-align:center}.onboarding-btn--skip{flex:0 0 auto}.onboarding-spotlight-ring,.onboarding-spotlight-svg{display:none}.onboarding-overlay:before{content:"";position:absolute;inset:0;background:#000000bf}}[data-theme=dark] .onboarding-tooltip{background:var(--color-bg-secondary)}[data-theme=dark] .onboarding-tooltip-footer{background:var(--color-bg)}[data-theme=dark] .onboarding-spotlight-ring{border-color:var(--color-primary)}@media(prefers-color-scheme:dark){.onboarding-tooltip{background:var(--color-bg-secondary)}.onboarding-tooltip-footer{background:var(--color-bg)}}.empty-state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;animation:fadeIn var(--duration-normal) var(--ease-out)}.empty-state-illustration{width:120px;height:100px;margin-bottom:1.5rem;opacity:.9}.empty-illustration{width:100%;height:100%}.illustration-primary{fill:var(--color-primary);opacity:.8}.illustration-secondary{fill:var(--color-secondary);opacity:.7}.illustration-accent{fill:var(--color-accent);opacity:.6}.illustration-bg{fill:var(--color-bg-secondary);stroke:var(--color-border)}.illustration-text{fill:var(--color-bg);font-weight:var(--font-weight-bold)}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);margin:0 0 .5rem}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 1.5rem;max-width:280px;line-height:var(--line-height-relaxed)}.empty-state-action{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d}.empty-state-action:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f9706666}.empty-state-action:active{transform:scale(.97)}.qr-print-view{position:fixed;inset:0;background:var(--color-bg);z-index:10000;display:flex;flex-direction:column;overflow:hidden}.qr-print-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border);flex-shrink:0}.qr-print-header-content h2{margin:0;font-size:1.25rem;font-weight:600}.qr-print-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--color-text-secondary)}.qr-print-actions{display:flex;gap:.75rem}.qr-print-actions .btn-primary,.qr-print-actions .btn-secondary{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.qr-print-actions .btn-primary{background:var(--color-primary);color:#fff;border:none}.qr-print-actions .btn-primary:hover{background:var(--color-primary-dark)}.qr-print-actions .btn-secondary{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.qr-print-actions .btn-secondary:hover{background:var(--color-bg-secondary)}.qr-print-content{flex:1;overflow:auto;padding:2rem;background:var(--color-bg-secondary)}.print-title{display:none}.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;max-width:1200px;margin:0 auto}.qr-card{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:var(--shadow-sm)}.qr-code-wrapper{padding:.5rem;background:#fff;border-radius:var(--radius-md);margin-bottom:1rem}.qr-code-wrapper svg{display:block}.qr-card-info{margin-bottom:.75rem}.qr-card .table-name{margin:0 0 .25rem;font-size:1.125rem;font-weight:600;color:var(--color-text)}.qr-card .table-meta{margin:0;font-size:.75rem;color:var(--color-text-secondary)}.scan-hint{margin:0;font-size:.625rem;color:var(--color-text-tertiary);font-style:italic}.print-footer{display:none}@media print{.no-print{display:none!important}.print-only{display:block!important}.qr-print-view{position:static;background:#fff}.qr-print-content{padding:0;background:#fff;overflow:visible}.print-title{display:block;text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #333}.print-title h1{margin:0;font-size:1.5rem;font-weight:700}.print-title .event-date{margin:.25rem 0 0;font-size:1rem;color:#666}.print-title .subtitle{margin:.5rem 0 0;font-size:.875rem;color:#888}.qr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;page-break-inside:auto}.qr-card{box-shadow:none;border:1px solid #ddd;padding:1rem;page-break-inside:avoid}.qr-code-wrapper{margin-bottom:.75rem}.qr-card .table-name{font-size:1rem}.print-footer{display:block;text-align:center;margin-top:2rem;padding-top:1rem;border-top:1px solid #ddd;font-size:.75rem;color:#888}@page{margin:.75in}}@media(max-width:768px){.qr-print-header{flex-direction:column;gap:1rem;text-align:center}.qr-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.qr-card{padding:1rem}.qr-code-wrapper svg{width:120px;height:120px}}.pdf-preview-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn var(--duration-fast) var(--ease-out)}.pdf-preview-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:100%;max-width:900px;height:90vh;max-height:800px;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:slideUp var(--duration-normal) var(--ease-bounce)}.pdf-preview-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-light);flex-shrink:0}.pdf-preview-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.pdf-preview-actions{display:flex;align-items:center;gap:.5rem}.pdf-preview-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-fast)}.pdf-preview-btn.download{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none}.pdf-preview-btn.download:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #f970664d}.pdf-preview-btn.download:disabled{opacity:.5;cursor:not-allowed}.pdf-preview-btn.close{background:var(--color-bg-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.5rem}.pdf-preview-btn.close:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.pdf-preview-btn.options{background:var(--color-bg-secondary);color:var(--color-text-secondary);border:1px solid var(--color-border);padding:.5rem}.pdf-preview-btn.options:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.pdf-preview-btn.options.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.pdf-options-panel{padding:1rem 1.5rem;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-secondary);display:flex;flex-wrap:wrap;gap:1.5rem;align-items:flex-start;animation:slideDown var(--duration-fast) var(--ease-out)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pdf-option-group{display:flex;flex-direction:column;gap:.5rem}.pdf-option-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.pdf-option-label{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer}.pdf-option-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--color-primary)}.pdf-font-size-options{display:flex;gap:.5rem}.pdf-font-option{display:flex;align-items:center;cursor:pointer}.pdf-font-option input[type=radio]{display:none}.pdf-font-label{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--duration-fast)}.pdf-font-option input[type=radio]:checked+.pdf-font-label{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.pdf-font-label:hover{border-color:var(--color-primary)}.pdf-font-small{font-size:var(--font-size-xs)}.pdf-font-medium{font-size:var(--font-size-sm)}.pdf-font-large{font-size:var(--font-size-base)}.pdf-font-family-helvetica{font-family:Helvetica,Arial,sans-serif}.pdf-font-family-times{font-family:Times New Roman,Times,serif}.pdf-font-family-courier{font-family:Courier New,Courier,monospace}.pdf-theme-options{display:flex;flex-wrap:wrap;gap:.5rem}.pdf-theme-option{display:flex;align-items:center;gap:.375rem;cursor:pointer;padding:.25rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--duration-fast)}.pdf-theme-option input[type=radio]{display:none}.pdf-theme-option:hover{border-color:var(--color-primary)}.pdf-theme-option input[type=radio]:checked+.pdf-theme-swatch+.pdf-theme-label,.pdf-theme-option input[type=radio]:checked~.pdf-theme-label{color:var(--color-primary)}.pdf-theme-option:has(input[type=radio]:checked){background:var(--color-primary-bg);border-color:var(--color-primary)}.pdf-theme-swatch{width:14px;height:14px;border-radius:50%;flex-shrink:0;box-shadow:inset 0 0 0 1px #0000001a}.pdf-theme-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap}.pdf-size-options{display:flex;gap:.5rem}.pdf-size-option{display:flex;align-items:center;cursor:pointer}.pdf-size-option input[type=radio]{display:none}.pdf-size-label{padding:.375rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:all var(--duration-fast)}.pdf-size-option input[type=radio]:checked+.pdf-size-label{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.pdf-size-label:hover{border-color:var(--color-primary)}.pdf-options-note{font-size:var(--font-size-xs);color:var(--color-text-light);margin:0;align-self:center}.pdf-preview-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--color-bg-secondary)}.pdf-preview-iframe{width:100%;height:100%;border:none}.pdf-preview-loading{display:flex;flex-direction:column;align-items:center;gap:1rem;color:var(--color-text-secondary)}.pdf-preview-spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.pdf-preview-empty{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:var(--color-text-secondary);padding:2rem}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:600px){.pdf-preview-modal{height:100vh;max-height:100vh;border-radius:0}.pdf-preview-header{padding:.75rem 1rem}.pdf-preview-header h2{font-size:var(--font-size-base)}.pdf-preview-btn.download span{display:none}}.share-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn var(--duration-fast) var(--ease-out)}.share-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp var(--duration-normal) var(--ease-bounce)}.share-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border-light)}.share-modal-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.share-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.share-modal-close:hover{background:var(--color-bg-tertiary);color:var(--color-text)}.share-modal-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.share-event-summary{text-align:center;padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg)}.share-event-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:.25rem}.share-event-stats{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.share-warning{display:flex;gap:.75rem;padding:1rem;background:var(--color-warning-light);border:1px solid var(--color-warning);border-radius:var(--radius-lg)}.share-warning svg{flex-shrink:0;color:var(--color-warning)}.share-warning strong{display:block;color:var(--color-text);margin-bottom:.25rem}.share-warning p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.share-url-section{display:flex;flex-direction:column;gap:.75rem}.share-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.share-url-container{display:flex;gap:.5rem}.share-url-input{flex:1;padding:.75rem 1rem;font-size:var(--font-size-sm);font-family:monospace;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);overflow:hidden;text-overflow:ellipsis}.share-url-input:focus{outline:none;border-color:var(--color-primary)}.share-copy-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--duration-fast);white-space:nowrap}.share-copy-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f970664d}.share-copy-btn.copied{background:var(--color-success)}.share-url-hint{font-size:var(--font-size-xs);color:var(--color-text-light);margin:0;line-height:1.5}.share-data-size{color:var(--color-text-secondary)}.share-qr-toggle{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast);align-self:flex-start}.share-qr-toggle:hover{background:var(--color-bg-tertiary);color:var(--color-text);border-color:var(--color-primary)}.share-qr-container{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:#fff;border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.share-qr-code{display:block}.share-qr-hint{font-size:var(--font-size-xs);color:var(--color-text-light);margin:0}.share-download-section{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.share-download-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast)}.share-download-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.share-download-hint{font-size:var(--font-size-xs);color:var(--color-text-light);margin:0}.share-modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--color-border-light);background:var(--color-bg-secondary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.share-footer-note{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-xs);color:var(--color-text-light);margin:0}.share-footer-note svg{flex-shrink:0}@media(max-width:500px){.share-modal{max-height:100vh;border-radius:var(--radius-lg)}.share-modal-content{padding:1rem}.share-url-container{flex-direction:column}.share-copy-btn{justify-content:center}}.dashboard-view{padding:1.5rem;overflow-y:auto;height:100%;flex:1}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;max-width:1400px;margin:0 auto}.dashboard-card{background:var(--color-bg);border-radius:var(--radius-xl);padding:1.5rem;border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm);animation:fadeIn var(--duration-normal) var(--ease-out)}.dashboard-card h3{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:1rem}.card-header-with-action{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-header-with-action h3{margin:0}.qr-print-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.qr-print-btn:hover{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.qr-print-btn svg{flex-shrink:0}.tables-header-actions{display:flex;align-items:center;gap:.5rem}.qr-help-btn{display:flex;align-items:center;justify-content:center;width:24px;height:24px;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text-light);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:50%;cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.qr-help-btn:hover{color:var(--color-primary);border-color:var(--color-primary);background:var(--color-primary-light)}.event-summary .event-info{display:flex;flex-direction:column;gap:.75rem}.event-name-input{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text);border:2px solid transparent;padding:.5rem;margin:-.5rem;border-radius:var(--radius-md);background:transparent;width:calc(100% + 1rem)}.event-name-input:hover{background:var(--color-bg-secondary)}.event-name-input:focus{border-color:var(--color-primary);background:var(--color-bg)}.event-meta{display:flex;align-items:center;gap:.75rem}.event-type-select{padding:.375rem .75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text);background:var(--color-bg)}.event-date{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem}.stat-item{text-align:center;padding:.875rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);transition:transform var(--duration-fast) var(--ease-bounce)}.stat-item:hover{transform:translateY(-2px)}.stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text);line-height:1.2}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide)}.stat-item.confirmed .stat-value{color:var(--color-success)}.stat-item.warning .stat-value{color:var(--color-warning)}.stat-item.error .stat-value{color:var(--color-error)}.progress-card{display:flex;flex-direction:column;align-items:center}.progress-ring-container{position:relative;width:140px;height:140px;margin-bottom:1rem}.progress-ring{transform:rotate(-90deg)}.progress-ring-bg{stroke:var(--color-border)}.progress-ring-fill{stroke:var(--color-primary);transition:stroke-dasharray var(--duration-slow) var(--ease-out)}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.progress-percentage{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.progress-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.progress-detail{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.capacity-info{font-size:var(--font-size-xs);color:var(--color-text-light);margin-top:.5rem}.actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.action-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);transition:all var(--duration-normal) var(--ease-bounce)}.action-btn.primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;box-shadow:0 4px 12px #f970664d}.action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #f9706666}.action-btn.secondary{background:var(--color-bg-secondary);color:var(--color-text);border:2px solid var(--color-border)}.action-btn.secondary:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.action-btn.outline{background:transparent;color:var(--color-text-secondary);border:2px solid var(--color-border)}.action-btn.outline:hover{border-color:var(--color-primary);color:var(--color-primary)}.action-btn.small{padding:.5rem 1rem;font-size:var(--font-size-xs)}.action-icon{font-size:1.125rem;line-height:1}.constraints-summary .empty-state,.tables-summary .empty-state{text-align:center;padding:1rem;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.constraints-list{display:flex;flex-direction:column;gap:.5rem}.constraint-item{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.constraint-priority{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);padding:.125rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase}.constraint-priority.required{background:var(--color-error-light);color:var(--color-error)}.constraint-priority.preferred{background:var(--color-warning-light);color:var(--color-warning)}.constraint-priority.optional{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.constraint-type{flex:1;color:var(--color-text);text-transform:capitalize}.constraint-guests{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.view-all-btn{width:100%;padding:.5rem;margin-top:.5rem;background:transparent;border:1px dashed var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-xs);cursor:pointer}.view-all-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.print-materials-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 1rem}.print-materials-grid{display:flex;flex-direction:column;gap:.75rem}.print-material-btn{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast);text-align:left;width:100%}.print-material-btn:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary-bg)}.print-material-btn:disabled{opacity:.5;cursor:not-allowed}.print-material-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-bg);border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0}.print-material-info{display:flex;flex-direction:column;flex:1;min-width:0}.print-material-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text)}.print-material-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.print-material-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg);padding:.25rem .75rem;border-radius:var(--radius-full);white-space:nowrap}.btn-loading-spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.print-material-btn:disabled{cursor:wait}.print-material-btn:disabled .print-material-icon{background:transparent}.tables-grid{display:flex;flex-direction:column;gap:.625rem;max-height:200px;overflow-y:auto}.table-summary-item{display:flex;align-items:center;gap:1rem;padding:.625rem .875rem;background:var(--color-bg-secondary);border-radius:var(--radius-md)}.table-info{display:flex;align-items:center;gap:.5rem;min-width:120px}.table-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.table-shape{font-size:var(--font-size-xs);padding:.125rem .375rem;background:var(--color-bg);border-radius:var(--radius-sm);color:var(--color-text-light);text-transform:capitalize}.table-occupancy{flex:1;position:relative;height:20px;background:var(--color-border-light);border-radius:var(--radius-sm);overflow:hidden}.occupancy-bar{position:absolute;top:0;left:0;height:100%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-sm);transition:width var(--duration-normal) var(--ease-out)}.occupancy-text{position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:var(--color-text)}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.dashboard-view{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}.actions-grid{grid-template-columns:1fr}}.table-component{position:absolute;cursor:grab;-webkit-user-select:none;user-select:none;transition:box-shadow var(--duration-normal) var(--ease-bounce),border-color var(--duration-normal) var(--ease-bounce),opacity var(--duration-normal) var(--ease-bounce)}.table-component:active{cursor:grabbing}.table-component.dragging{opacity:.9;z-index:100;transition:none}.table-component.selected{z-index:10}.table-component.selected .table-surface{box-shadow:0 0 0 4px var(--color-primary),var(--shadow-lg)}.table-component.selected:after{content:"";position:absolute;inset:-10px;border:2px dashed var(--color-primary-light);border-radius:inherit;pointer-events:none;animation:selectedPulse 2s ease-in-out infinite}@keyframes selectedPulse{0%,to{opacity:.5}50%{opacity:1}}.table-component.drop-target .table-surface{box-shadow:0 0 0 4px var(--color-success),0 0 20px #4ade804d;background:#4ade801a;animation:pulse 1s ease-in-out infinite}.table-surface{width:100%;height:100%;background:linear-gradient(145deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%);border:3px solid var(--color-border);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:all var(--duration-normal) var(--ease-out)}.table-surface:hover{border-color:var(--color-primary);box-shadow:var(--shadow-xl)}.table-component.round .table-surface{border-radius:50%}.table-component.rectangle .table-surface,.table-component.square .table-surface{border-radius:var(--radius-xl)}.table-component.oval .table-surface{border-radius:50%}.table-component.half-round .table-surface{border-radius:0 0 50% 50%/0 0 100% 100%}.table-component.serpentine .table-surface{border-radius:var(--radius-xl);background:linear-gradient(90deg,var(--color-bg) 0%,var(--color-bg-secondary) 25%,var(--color-bg) 50%,var(--color-bg-secondary) 75%,var(--color-bg) 100%)}.table-label{display:flex;flex-direction:column;align-items:center;gap:.375rem;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);pointer-events:none}.table-name-input{width:90px;text-align:center;padding:.375rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);pointer-events:auto;background:var(--color-bg);transition:all var(--duration-fast) var(--ease-out)}.table-name-input:focus{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.table-count{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);background:var(--color-bg-secondary);padding:.25rem .5rem;border-radius:var(--radius-full)}.seat{position:absolute;width:48px;height:48px;display:flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-bounce)}.seat:hover{transform:scale(1.1)}.table-delete{position:absolute;top:-14px;right:-14px;width:28px;height:28px;border-radius:var(--radius-full);border:none;background:linear-gradient(135deg,var(--color-error) 0%,#dc2626 100%);color:#fff;font-size:var(--font-size-base);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:var(--shadow-md);opacity:0;transform:scale(.8)}.table-component:hover .table-delete{opacity:1;transform:scale(1)}.table-delete:hover{transform:scale(1.15)!important;box-shadow:var(--shadow-lg)}.table-component.snap-target .table-surface{box-shadow:0 0 0 4px var(--color-success),0 0 24px #4ade8066;border-color:var(--color-success)}.seat-guest{position:relative;cursor:grab;transition:transform var(--duration-normal) var(--ease-bounce)}.seat-guest:active{cursor:grabbing}@media(pointer:coarse){.seat-guest:before{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid transparent;pointer-events:none;z-index:-1}.seat-guest:active:before{animation:longPressRing .2s ease-out forwards}@keyframes longPressRing{0%{border-color:transparent;transform:scale(.8);opacity:0}to{border-color:var(--color-primary);transform:scale(1);opacity:1}}}.seat-guest.dragging{opacity:.5;z-index:1000}.seat-guest.dimmed{opacity:.25;pointer-events:none}.seat-guest.optimized{animation:optimizedPulse 1.2s ease-out}.seat-guest.optimized .seat-guest-circle{animation:optimizedGlow 1.2s ease-out}@keyframes optimizedPulse{0%{transform:scale(.3);opacity:0}30%{transform:scale(1.2);opacity:1}50%{transform:scale(.95)}70%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes optimizedGlow{0%,to{box-shadow:var(--shadow-sm)}30%,50%{box-shadow:0 0 20px #8b5cf699,0 0 40px #8b5cf64d}}.seat-guest-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:2px solid var(--color-bg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-sm);transition:transform var(--duration-normal) var(--ease-bounce),box-shadow var(--duration-normal) var(--ease-out)}.seat-guest:hover .seat-guest-circle{transform:scale(1.15);box-shadow:var(--shadow-md)}.seat-guest .status-dot{position:absolute;top:-2px;right:-2px;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-bg)}.seat-guest .initials{text-transform:uppercase}.seat-guest .dietary-icon{position:absolute;bottom:-4px;left:-4px;font-size:10px;background:var(--color-bg);border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.seat-guest .accessibility-icon{position:absolute;bottom:-4px;right:-4px;font-size:10px;background:var(--color-info-light);border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.seat-guest .group-dot{position:absolute;top:-4px;left:-4px;width:12px;height:12px;border-radius:50%;border:2px solid var(--color-bg);box-shadow:var(--shadow-sm)}.seat-guest.has-group .seat-guest-circle{border-style:solid}.capacity-ring{z-index:-1}.capacity-progress{stroke:var(--color-success);transition:stroke-dashoffset var(--duration-slow) var(--ease-out),stroke var(--duration-normal)}.capacity-nearly-full .capacity-progress,.table-count.nearly-full{stroke:var(--color-warning)}.capacity-full .capacity-progress{stroke:var(--color-success)}.capacity-over .capacity-progress{stroke:var(--color-error)}.table-count.available{color:var(--color-text-secondary)}.table-count.nearly-full{color:#78350f;background:var(--color-warning-light)}.table-count.full{color:var(--color-success);background:var(--color-success-light);font-weight:var(--font-weight-semibold)}.table-count.over{color:var(--color-error);background:var(--color-error-light);font-weight:var(--font-weight-bold);animation:pulse 1s ease-in-out infinite}.table-component.capacity-full .table-surface{border-color:var(--color-success)}.table-component.capacity-over .table-surface{border-color:var(--color-error);animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.table-component.has-violations .table-surface{box-shadow:0 0 0 3px var(--color-warning),var(--shadow-md)}.table-component.has-required-violations .table-surface{box-shadow:0 0 0 3px var(--color-error),var(--shadow-md);animation:violationPulse 2s ease-in-out infinite}@keyframes violationPulse{0%,to{box-shadow:0 0 0 3px var(--color-error),var(--shadow-md)}50%{box-shadow:0 0 0 3px var(--color-error),0 0 16px #f8717180}}.violation-badge{position:absolute;top:-12px;left:-12px;padding:.25rem .5rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);display:flex;align-items:center;gap:.25rem;cursor:help;z-index:20;animation:popIn var(--duration-normal) var(--ease-spring)}.violation-badge.preferred{background:var(--color-warning);color:#78350f}.violation-badge.required{background:var(--color-error);color:#fff}.violation-badge:hover{transform:scale(1.1)}.seat-guest.swap-target{z-index:50}.seat-guest.swap-target .seat-guest-circle{box-shadow:0 0 0 4px var(--color-info),0 0 16px #3b82f680;animation:swapPulse 1s ease-in-out infinite;transform:scale(1.15)}@keyframes swapPulse{0%,to{box-shadow:0 0 0 4px var(--color-info),0 0 16px #3b82f680}50%{box-shadow:0 0 0 6px var(--color-info),0 0 24px #3b82f6b3}}.swap-icon{position:absolute;top:-20px;left:50%;transform:translate(-50%);background:var(--color-info);color:#fff;padding:.125rem .375rem;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);white-space:nowrap;box-shadow:var(--shadow-md);animation:popIn var(--duration-normal) var(--ease-spring);z-index:100}.availability-indicator{position:absolute;bottom:-32px;left:50%;transform:translate(-50%);background:var(--color-success);color:#fff;padding:.375rem .75rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);white-space:nowrap;box-shadow:var(--shadow-md);animation:popIn var(--duration-fast) var(--ease-out);z-index:100}.availability-indicator.full{background:var(--color-error)}.table-dietary-summary{position:absolute;bottom:8px;right:8px;display:flex;align-items:center;gap:.25rem;padding:.25rem .5rem;background:var(--color-bg);border-radius:var(--radius-full);font-size:var(--font-size-xs);box-shadow:var(--shadow-sm);cursor:help;opacity:.7;transition:opacity var(--duration-fast) var(--ease-out);z-index:5;border:1px solid var(--color-border-light)}.table-component:hover .table-dietary-summary{opacity:1}.dietary-summary-icon{font-size:12px}.dietary-summary-count{font-weight:var(--font-weight-bold);color:var(--color-text-secondary)}.table-component.newly-added{animation:newTablePulse 1.5s ease-out}.table-component.newly-added .table-surface{animation:newTableGlow 1.5s ease-out}@keyframes newTablePulse{0%{transform:scale(.5);opacity:0}20%{transform:scale(1.05);opacity:1}40%{transform:scale(.98)}60%{transform:scale(1.02)}to{transform:scale(1)}}@keyframes newTableGlow{0%{box-shadow:0 0 #f97066b3,var(--shadow-lg)}50%{box-shadow:0 0 0 20px #f9706600,var(--shadow-xl)}to{box-shadow:var(--shadow-lg)}}.guest-chip{display:flex;align-items:center;gap:.625rem;padding:.625rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:grab;transition:all var(--duration-normal) var(--ease-bounce);-webkit-user-select:none;user-select:none}.guest-chip:hover{border-color:var(--color-primary);background:var(--color-bg);box-shadow:var(--shadow-md);transform:translateY(-2px)}.guest-chip:active{cursor:grabbing;transform:scale(.98)}.guest-chip.dragging{opacity:.95;box-shadow:var(--shadow-xl);z-index:1000;transform:rotate(2deg) scale(1.02);border-color:var(--color-primary)}.guest-chip.assigned{background:var(--color-bg-secondary);border-style:dashed}.guest-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);flex-shrink:0;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);box-shadow:0 2px 8px #f970664d}.guest-info{display:flex;flex-direction:column;min-width:0;flex:1}.guest-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guest-company{font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.guest-group{font-size:.625rem;color:var(--color-primary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-bold)}.assigned-badge{color:var(--color-success);font-size:var(--font-size-base);animation:popIn var(--duration-normal) var(--ease-spring)}.guest-chip.compact{width:36px;height:36px;padding:0;border-radius:var(--radius-full);justify-content:center;position:relative;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;border:3px solid var(--color-bg);box-shadow:var(--shadow-md)}.guest-chip.compact:hover{transform:scale(1.1);box-shadow:var(--shadow-lg)}.guest-chip.compact .initials{font-size:.625rem;font-weight:var(--font-weight-bold)}.guest-chip.compact .status-dot{position:absolute;bottom:-3px;right:-3px;width:12px;height:12px;border-radius:var(--radius-full);border:2px solid var(--color-bg);animation:popIn var(--duration-fast) var(--ease-spring)}.guest-chip.has-group{border-left:4px solid var(--group-color)}.guest-chip.has-group:hover{border-left-color:var(--group-color)}.guest-group{font-size:.625rem;color:var(--color-text);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-bold);padding:.125rem .375rem;border-radius:var(--radius-sm);display:inline-block;margin-top:.125rem}.guest-chip.compact .group-indicator{position:absolute;top:-3px;left:-3px;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-bg)}.guest-chip.compact .dietary-indicator{position:absolute;bottom:-4px;left:-4px;font-size:10px;background:var(--color-bg);border-radius:50%;width:16px;height:16px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light)}.guest-tags{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap;margin-top:.125rem}.guest-dietary-tags{display:inline-flex;gap:.125rem}.dietary-icon-inline,.accessibility-icon-inline{font-size:.75rem;padding:.0625rem .25rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);line-height:1}.accessibility-icon-inline{background:var(--color-info-light)}@media(max-width:768px){.guest-chip{min-height:var(--touch-target-min);padding:.75rem}}@media(max-width:480px){.guest-chip{min-height:var(--touch-target-comfortable);padding:.875rem .75rem}.guest-avatar{width:40px;height:40px}.guest-name{font-size:var(--font-size-base)}}@media(pointer:coarse){.guest-chip:hover{transform:none;box-shadow:none}.guest-chip:active{transform:scale(.98);background:var(--color-bg-hover)}.guest-chip.compact{width:44px;height:44px}.guest-chip.compact:hover{transform:none}.guest-chip.compact:active{transform:scale(.95)}}.canvas-guest{position:absolute;display:flex;flex-direction:column;align-items:center;cursor:grab;-webkit-user-select:none;user-select:none;transform:translate(-50%,-50%);transition:filter var(--duration-normal) var(--ease-out);z-index:5}.canvas-guest:active{cursor:grabbing}@media(pointer:coarse){.canvas-guest:after{content:"";position:absolute;inset:-6px;border-radius:50%;border:2px solid transparent;pointer-events:none;z-index:-1}.canvas-guest:active:after{animation:longPressRingCanvas .2s ease-out forwards}@keyframes longPressRingCanvas{0%{border-color:transparent;transform:scale(.8);opacity:0}to{border-color:var(--color-primary);transform:scale(1);opacity:1}}}.canvas-guest.dragging{z-index:1000;opacity:.8;filter:drop-shadow(0 8px 16px rgba(0,0,0,.2))}.canvas-guest.dimmed{opacity:.25;pointer-events:none}.canvas-guest.selected .canvas-guest-circle{box-shadow:0 0 0 4px var(--color-primary),var(--shadow-lg)}.canvas-guest.near-table .canvas-guest-circle{box-shadow:0 0 0 4px var(--color-success),0 0 20px #4ade8066}.canvas-guest-circle{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:3px solid var(--color-bg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);box-shadow:var(--shadow-md);transition:transform var(--duration-normal) var(--ease-bounce),box-shadow var(--duration-normal) var(--ease-out)}.canvas-guest:hover .canvas-guest-circle{transform:scale(1.1);box-shadow:var(--shadow-lg)}.canvas-guest .status-dot{position:absolute;top:0;right:0;width:14px;height:14px;border-radius:50%;border:2px solid var(--color-bg)}.canvas-guest .dietary-icon{position:absolute;bottom:0;left:0;font-size:12px;background:var(--color-bg);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:2px solid var(--color-bg)}.canvas-guest .accessibility-icon{position:absolute;bottom:0;right:0;font-size:12px;background:var(--color-info-light);border-radius:50%;width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);border:2px solid var(--color-bg)}.canvas-guest-label{margin-top:4px;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text);background:var(--color-bg);padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap;max-width:100px;overflow:hidden;text-overflow:ellipsis;opacity:0;transform:translateY(-4px);transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);box-shadow:var(--shadow-sm)}.canvas-guest:hover .canvas-guest-label,.canvas-guest.selected .canvas-guest-label{opacity:1;transform:translateY(0)}.canvas-guest-overlay{display:flex;flex-direction:column;align-items:center;pointer-events:none}.canvas-guest-overlay .canvas-guest-circle{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border:3px solid var(--color-bg);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);box-shadow:0 8px 24px #00000040;transform:scale(1.1)}.canvas-guest.newly-added{animation:newGuestPulse 1.5s ease-out}.canvas-guest.newly-added .canvas-guest-circle{animation:newGuestGlow 1.5s ease-out}@keyframes newGuestPulse{0%{transform:translate(-50%,-50%) scale(.5);opacity:0}20%{transform:translate(-50%,-50%) scale(1.15);opacity:1}40%{transform:translate(-50%,-50%) scale(.95)}60%{transform:translate(-50%,-50%) scale(1.05)}to{transform:translate(-50%,-50%) scale(1)}}@keyframes newGuestGlow{0%{box-shadow:0 0 #f97066b3,var(--shadow-md)}50%{box-shadow:0 0 0 20px #f9706600,var(--shadow-lg)}to{box-shadow:var(--shadow-md)}}.qr-modal-overlay{z-index:10000}.qr-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:400px;max-width:95vw;box-shadow:var(--shadow-lg);animation:modalSlideUp var(--duration-slow) var(--ease-spring)}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.qr-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.qr-modal-header h2{margin:0;font-size:1.125rem;font-weight:600}.qr-modal-header .close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast)}.qr-modal-header .close-btn:hover{background:var(--color-bg-secondary);color:var(--color-text)}.qr-modal-content{padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1.25rem}.qr-code-container{background:#fff;padding:1rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.qr-code-container svg{display:block}.qr-table-info{text-align:center}.qr-table-name{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0 0 .25rem}.qr-table-meta{font-size:.875rem;color:var(--color-text-secondary);margin:0}.qr-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.qr-action-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;font-weight:500;color:var(--color-text);cursor:pointer;transition:all var(--duration-fast)}.qr-action-btn:hover{background:var(--color-bg-tertiary, var(--color-border));border-color:var(--color-text-tertiary)}.qr-action-btn svg{color:var(--color-text-secondary)}.qr-hint{font-size:.75rem;color:var(--color-text-tertiary);text-align:center;margin:0}@media(max-width:480px){.qr-modal{width:100%;margin:1rem}.qr-actions{flex-direction:column;width:100%}.qr-action-btn{justify-content:center;width:100%}}.table-properties-panel{position:absolute;right:1rem;top:4rem;width:280px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1rem;z-index:100;animation:panelSlideIn var(--duration-normal) var(--ease-out)}@keyframes panelSlideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border-light);gap:.5rem}.panel-title{flex:1;min-width:0}.panel-title h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-bold);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.table-counter{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.nav-btn{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);width:32px;height:32px;font-size:1.25rem;cursor:pointer;color:var(--color-text);display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast);flex-shrink:0}.nav-btn:hover{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;line-height:1;border-radius:var(--radius-sm);transition:all var(--duration-fast);flex-shrink:0}.close-btn:hover{color:var(--color-text);background:var(--color-bg-secondary)}.quick-actions{display:flex;gap:.5rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border-light)}.quick-action-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);cursor:pointer;transition:all var(--duration-fast);min-height:44px}.quick-action-btn svg{flex-shrink:0}.quick-action-btn span{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.quick-action-btn:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.quick-action-btn.delete{border-color:var(--color-error);color:var(--color-error)}.quick-action-btn.delete:hover{background:var(--color-error);color:#fff}.property-group{margin-bottom:1rem}.property-group label{display:block;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);margin-bottom:.5rem}.property-group>input[type=text],.property-group>input[type=number]{width:100%;padding:.5rem .75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:border-color var(--duration-fast);background:var(--color-bg-secondary);color:var(--color-text)}.property-group>input:focus{border-color:var(--color-primary);outline:none}.shape-selector{display:flex;flex-wrap:wrap;gap:.5rem}.shape-selector button{flex:1 1 calc(33.333% - .5rem);min-width:0;padding:.625rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);cursor:pointer;font-size:1.25rem;transition:all var(--duration-fast);min-height:44px}.shape-selector button:hover{border-color:var(--color-primary);background:var(--color-bg-hover)}.shape-selector button.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.capacity-control{display:flex;align-items:center;gap:.5rem}.capacity-control button{width:44px;height:44px;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);font-size:1.25rem;cursor:pointer;transition:all var(--duration-fast);display:flex;align-items:center;justify-content:center;flex-shrink:0}.capacity-control button:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-primary);color:#fff}.capacity-control button:disabled{opacity:.4;cursor:not-allowed}.capacity-control input{flex:1;min-width:50px;text-align:center;padding:.5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);background:var(--color-bg-secondary);color:var(--color-text);height:44px}.capacity-control input:focus{border-color:var(--color-primary);outline:none}.capacity-hint{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:.375rem}.size-presets{display:flex;gap:.5rem}.size-presets button{flex:1;padding:.5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-fast);min-height:44px}.size-presets button:hover{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.dimension-inputs{display:flex;gap:.75rem}.dimension-inputs>div{flex:1;display:flex;align-items:center;gap:.5rem}.dimension-inputs span{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold);min-width:16px}.dimension-inputs input{width:100%;padding:.5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;background:var(--color-bg-secondary);color:var(--color-text);min-height:44px}.dimension-inputs input:focus{border-color:var(--color-primary);outline:none}.panel-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.delete-btn{width:100%;padding:.625rem;border:2px solid var(--color-error);border-radius:var(--radius-md);background:transparent;color:var(--color-error);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-fast);min-height:44px}.delete-btn:hover{background:var(--color-error);color:#fff}.assigned-guests{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.assigned-guests ul{margin:0;padding:0;list-style:none;max-height:150px;overflow-y:auto}.assigned-guests li{padding:.375rem 0;font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border-light)}.assigned-guests li:last-child{border-bottom:none}.advanced-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.75rem;margin-bottom:.5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);color:var(--color-text);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-fast);min-height:44px}.advanced-toggle:hover{border-color:var(--color-primary)}.advanced-toggle .toggle-icon{transition:transform var(--duration-fast);font-size:1.25rem}.advanced-toggle .toggle-icon.open{transform:rotate(90deg)}.advanced-section{padding-top:.5rem;animation:fadeIn var(--duration-fast) var(--ease-out)}.table-panel-backdrop{position:fixed;inset:0;background:#00000080;z-index:99;animation:fadeInBackdrop var(--duration-normal) var(--ease-out)}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.panel-drag-handle{display:flex;justify-content:center;padding:.5rem 0 .75rem;cursor:grab;touch-action:none}.panel-drag-handle:active{cursor:grabbing}.drag-handle-bar{width:40px;height:4px;background:var(--color-border);border-radius:2px}@media(max-width:768px){.table-properties-panel.mobile{position:fixed;inset:auto 0 0;width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:70vh;overflow-y:auto;animation:panelSlideUp var(--duration-normal) var(--ease-out);padding:0 1rem 1rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom,0));box-shadow:0 -4px 20px #00000026}@keyframes panelSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.table-properties-panel.mobile .panel-header{position:sticky;top:0;background:var(--color-bg);padding-top:.5rem;margin-left:-1rem;margin-right:-1rem;padding-left:1rem;padding-right:1rem;z-index:1}.table-properties-panel.mobile .nav-btn{width:44px;height:44px}.table-properties-panel.mobile .close-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center}.table-properties-panel.mobile .quick-action-btn{min-height:56px;padding:.75rem .5rem}.table-properties-panel.mobile .quick-action-btn svg{width:24px;height:24px}.table-properties-panel.mobile .shape-selector button{min-height:48px;font-size:1.5rem}}@media(pointer:coarse){.nav-btn,.close-btn,.quick-action-btn,.shape-selector button,.capacity-control button,.size-presets button,.dimension-inputs input,.advanced-toggle,.delete-btn{min-height:44px}.capacity-control button,.shape-selector button{min-width:44px}}.canvas-search-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;padding-top:15vh;z-index:1000;animation:fadeIn var(--duration-fast) var(--ease-out)}.canvas-search-modal{width:100%;max-width:500px;background:var(--color-bg);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden;animation:slideDown var(--duration-normal) var(--ease-spring)}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.search-input-wrapper{display:flex;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border-light);gap:.75rem}.search-icon{font-size:1.25rem;opacity:.5}.search-input-wrapper input{flex:1;border:none;outline:none;font-size:var(--font-size-lg);background:transparent}.search-input-wrapper input::placeholder{color:var(--color-text-secondary)}.shortcut-hint{font-size:var(--font-size-xs);padding:.25rem .5rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);color:var(--color-text-secondary)}.search-results{list-style:none;margin:0;padding:.5rem;max-height:320px;overflow-y:auto}.search-result{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast)}.search-result:hover,.search-result.selected{background:var(--color-bg-hover)}.search-result.selected{background:var(--color-primary-light)}.result-icon{font-size:1.25rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-full)}.result-info{flex:1;display:flex;flex-direction:column;gap:.125rem}.result-name{font-weight:var(--font-weight-medium)}.result-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.result-type{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.25rem .5rem;border-radius:var(--radius-sm)}.search-empty{padding:2rem;text-align:center;color:var(--color-text-secondary)}.search-footer{display:flex;justify-content:center;gap:1.5rem;padding:.75rem;background:var(--color-bg-secondary);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.search-footer kbd{display:inline-block;padding:.125rem .375rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:var(--font-size-xs);margin-right:.25rem}.canvas-minimap{position:absolute;bottom:1rem;right:1rem;z-index:50;background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;border:2px solid var(--color-border);animation:fadeInUp var(--duration-normal) var(--ease-out)}@media(prefers-color-scheme:dark){.canvas-minimap{background:#2a2420;border-color:var(--color-primary)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.canvas-minimap svg{display:block;cursor:pointer}.minimap-table{transition:opacity var(--duration-fast)}.minimap-table:hover{opacity:1!important}.viewport-indicator{transition:stroke-dashoffset var(--duration-normal)}.minimap-label{display:flex;justify-content:space-between;padding:.5rem .75rem;font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-secondary);border-top:1px solid var(--color-border-light)}.minimap-tooltip{position:absolute;bottom:calc(100% + 8px);right:0;background:var(--color-text);color:var(--color-bg);padding:.5rem .75rem;border-radius:var(--radius-md);font-size:var(--font-size-xs);white-space:nowrap;display:flex;flex-direction:column;gap:.125rem;animation:fadeIn var(--duration-fast)}.minimap-tooltip:after{content:"";position:absolute;top:100%;right:1rem;border:6px solid transparent;border-top-color:var(--color-text)}.minimap-tooltip strong{font-weight:var(--font-weight-semibold)}.minimap-tooltip span{opacity:.8}@media(max-width:768px){.canvas-minimap{display:none}}.selection-toolbar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:12px;box-shadow:0 8px 32px #00000026;z-index:1000;animation:slideUp .2s ease-out}.selection-count{font-weight:600;color:var(--color-text);padding-right:12px;border-right:1px solid var(--color-border);white-space:nowrap}.selection-toolbar-dropdown{position:relative}.selection-toolbar-button{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--color-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.selection-toolbar-button:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.selection-toolbar-button.danger{background:var(--color-error)}.selection-toolbar-button.danger:hover{background:#c0392b}.selection-toolbar-button.clear{background:var(--color-bg-secondary);color:var(--color-text-secondary);padding:8px 10px;font-size:18px;line-height:1}.selection-toolbar-button.clear:hover{background:var(--color-border);color:var(--color-text)}.dropdown-arrow{font-size:10px;margin-left:2px}.selection-dropdown-menu{position:absolute;bottom:100%;left:0;margin-bottom:8px;min-width:200px;max-height:300px;overflow-y:auto;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 4px 20px #00000026;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 14px;background:none;border:none;font-size:14px;color:var(--color-text);cursor:pointer;transition:background .1s ease}.dropdown-item:hover{background:var(--color-bg-secondary)}.dropdown-item:first-child{border-radius:8px 8px 0 0}.dropdown-item:last-child{border-radius:0 0 8px 8px}.dropdown-item:only-child{border-radius:8px}.dropdown-item.warning{color:var(--color-warning)}.dropdown-item.warning:hover{background:#f39c121a}.seat-count{font-size:12px;color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:2px 8px;border-radius:10px}.dropdown-empty{padding:16px;text-align:center;color:var(--color-text-secondary);font-size:14px}@media(max-width:768px){.selection-toolbar{bottom:80px;padding:10px 14px;gap:10px}.selection-toolbar-button{padding:10px 14px;min-height:44px}}@media(max-width:480px){.selection-toolbar{bottom:70px;left:12px;right:12px;transform:none;width:auto;max-width:none;justify-content:space-between}.selection-count{font-size:13px;padding-right:10px}.selection-toolbar-button{padding:10px 12px;font-size:13px}.selection-toolbar-button.clear{padding:10px}.selection-dropdown-menu{max-height:200px;min-width:180px}}.context-menu{position:fixed;z-index:2000;min-width:180px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 8px 32px #0003;padding:4px 0;animation:contextMenuFadeIn .12s ease-out}@keyframes contextMenuFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;font-size:14px;color:var(--color-text);cursor:pointer;text-align:left;transition:background .1s ease}.context-menu-item:hover:not(.disabled){background:var(--color-bg-secondary)}.context-menu-item.disabled{opacity:.5;cursor:not-allowed}.context-menu-item.danger{color:var(--color-error)}.context-menu-item.danger:hover:not(.disabled){background:#e74c3c1a}.context-menu-icon{width:20px;text-align:center;font-size:14px}.context-menu-label{flex:1}.context-menu-divider{height:1px;background:var(--color-border);margin:4px 0}@media(pointer:coarse){.context-menu{min-width:220px;border-radius:12px;padding:6px 0}.context-menu-item{min-height:48px;padding:12px 16px;font-size:16px;gap:14px}.context-menu-icon{width:24px;font-size:18px}.context-menu-divider{margin:6px 0}}@media(max-width:480px){.context-menu{position:fixed!important;left:12px!important;right:12px!important;bottom:calc(12px + env(safe-area-inset-bottom,0px))!important;top:auto!important;width:auto!important;max-height:70vh;overflow-y:auto;border-radius:16px;animation:slideUpContextMenu .2s ease-out}@keyframes slideUpContextMenu{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.context-menu-item{min-height:52px;padding:14px 20px}}.layout-toolbar{position:fixed;top:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;padding:8px 16px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:12px;box-shadow:0 4px 20px #0000001f;z-index:900;animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.layout-toolbar-section{display:flex;align-items:center;gap:8px}.section-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px}.layout-buttons{display:flex;align-items:center;gap:2px;background:var(--color-bg-secondary);border-radius:6px;padding:2px}.layout-btn{display:flex;align-items:center;justify-content:center;gap:4px;width:32px;height:32px;background:transparent;border:none;border-radius:4px;color:var(--color-text);cursor:pointer;transition:all .15s ease}.layout-btn:hover:not(:disabled){background:var(--color-bg);color:var(--color-primary)}.layout-btn:disabled{opacity:.4;cursor:not-allowed}.layout-btn.auto-arrange{width:auto;padding:0 10px;gap:6px;font-size:12px;font-weight:500}.layout-btn svg{flex-shrink:0}.separator{width:1px;height:20px;background:var(--color-border);margin:0 4px}@media(max-width:768px){.layout-toolbar{top:70px;padding:6px 12px;gap:10px}.section-label{display:none}.layout-btn{width:36px;height:36px}}@media(max-width:480px){.layout-toolbar{top:auto;bottom:80px;left:50%;transform:translate(-50%);padding:8px 12px;gap:8px;max-width:calc(100vw - 24px);overflow-x:auto}.layout-toolbar-section{gap:4px}.layout-btn{width:40px;height:40px;min-width:40px}.layout-btn.auto-arrange{padding:0 8px;font-size:11px}}.view-toggle-container{display:flex;align-items:center;gap:.5rem}.view-toggle-switch{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem}.toggle-option{padding:.5rem 1rem;border:none;background:transparent;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.toggle-option:hover{color:var(--color-text)}.toggle-option.active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.toggle-option.relationships{background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.5rem 1rem}.toggle-option.relationships.active{background:var(--color-primary);color:#fff}@media(max-width:768px){.toggle-option{padding:.5rem .75rem;font-size:var(--font-size-xs)}.toggle-option.relationships{padding:.5rem .75rem}}@media(max-width:480px){.view-toggle-container{gap:.25rem}.view-toggle-switch{padding:.125rem}.toggle-option,.toggle-option.relationships{padding:.5rem;min-height:40px;min-width:40px}}@media(pointer:coarse){.toggle-option{min-height:var(--touch-target-min);min-width:var(--touch-target-min);padding:.625rem 1rem}.toggle-option:hover{color:var(--color-text-secondary)}.toggle-option.active:hover{color:var(--color-text)}.toggle-option:active{transform:scale(.97);transition:transform var(--duration-micro)}}.mobile-toolbar-menu{position:relative}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.hamburger-btn:hover,.hamburger-btn.active{background:var(--color-primary);border-color:var(--color-primary)}.hamburger-btn:hover .hamburger-line,.hamburger-btn.active .hamburger-line{background:#fff}.hamburger-icon{display:flex;flex-direction:column;gap:4px;width:20px}.hamburger-line{display:block;width:100%;height:2px;background:var(--color-text);border-radius:1px;transition:all .15s ease}.hamburger-btn.active .hamburger-line:nth-child(1){transform:translateY(6px) rotate(45deg)}.hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}.hamburger-btn.active .hamburger-line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.mobile-menu-backdrop{position:fixed;inset:0;background:#0000004d;z-index:998;animation:fadeIn .2s ease-out}.mobile-menu-sheet{position:fixed;bottom:calc(12px + env(safe-area-inset-bottom,0px));left:12px;right:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-xl);z-index:999;animation:slideUpMenu .2s ease-out forwards;overflow-y:auto;max-height:calc(100vh - 80px - env(safe-area-inset-bottom,0px))}@keyframes slideUpMenu{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.menu-section{padding:12px 0;border-bottom:1px solid var(--color-border-light)}.menu-section:last-of-type{border-bottom:none}.menu-section-label{padding:0 16px 8px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary)}.menu-view-buttons{display:flex;gap:8px;padding:0 16px}.menu-view-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 16px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:12px;font-size:13px;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;min-height:44px}.menu-view-btn:hover{background:var(--color-bg-hover);border-color:var(--color-primary-light)}.menu-view-btn.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.menu-view-btn .menu-icon{font-size:18px}.menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:transparent;border:none;text-align:left;font-size:15px;font-weight:500;color:var(--color-text);cursor:pointer;transition:background .15s ease;min-height:48px}.menu-item:hover{background:var(--color-bg-hover)}.menu-item:disabled{opacity:.4;cursor:not-allowed}.menu-item:disabled:hover{background:transparent}.menu-item.back{color:var(--color-text-secondary);font-weight:400}.menu-item.toggle.active{background:var(--color-primary-light);color:var(--color-primary)}.menu-icon{width:24px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.menu-icon svg{color:var(--color-text-secondary)}.menu-item.toggle.active .menu-icon svg{color:var(--color-primary)}.menu-chevron{margin-left:auto;font-size:18px;color:var(--color-text-secondary)}.checkmark{margin-left:auto;color:var(--color-primary);font-weight:700}.menu-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--color-bg-secondary);border-top:1px solid var(--color-border-light)}.event-name{font-size:13px;font-weight:600;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.guest-count{font-size:12px;color:var(--color-text-secondary);padding:4px 10px;background:var(--color-bg);border-radius:var(--radius-full)}.mobile-bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background:var(--color-bg);border-top:1px solid var(--color-border);padding:8px 0;padding-bottom:calc(8px + env(safe-area-inset-bottom,0px));z-index:500;box-shadow:0 -2px 10px #0000001a}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 16px;background:transparent;border:none;color:var(--color-text-secondary);font-size:11px;font-weight:500;cursor:pointer;transition:all .15s ease;min-width:64px}.bottom-nav-item svg{transition:transform .15s ease}.bottom-nav-item:active svg{transform:scale(.9)}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.add-btn{position:relative}.bottom-nav-item.add-btn svg{background:var(--color-primary);border-radius:50%;padding:6px;color:#fff;box-shadow:0 2px 8px rgba(var(--color-primary-rgb, 194, 65, 12),.3)}.bottom-nav-item.add-btn svg path{fill:#fff}.mobile-menu-sheet{bottom:calc(70px + env(safe-area-inset-bottom,0px))!important}[data-theme=dark] .mobile-menu-backdrop{background:#00000080}[data-theme=dark] .mobile-bottom-nav{box-shadow:0 -2px 10px #0000004d}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .mobile-menu-backdrop{background:#00000080}:root:not([data-theme=light]):not([data-theme=dark]) .mobile-bottom-nav{box-shadow:0 -2px 10px #0000004d}}.menu-zoom-controls{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);margin:.5rem 1rem .75rem}.menu-zoom-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;transition:all .15s ease}.menu-zoom-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.menu-zoom-btn:active{transform:scale(.95)}.menu-zoom-btn.reset{width:36px;height:36px;margin-left:.5rem;border-color:transparent;background:transparent;color:var(--color-text-secondary)}.menu-zoom-btn.reset:hover{color:var(--color-primary);background:var(--color-primary-light)}.menu-zoom-value{min-width:50px;text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text)}.main-toolbar{display:flex;align-items:center;padding:.75rem 1.25rem;background:#fffcfaf2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border-light);gap:1rem;min-height:56px;position:relative;z-index:200}[data-theme=dark] .main-toolbar{background:#241c18f2}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .main-toolbar{background:#241c18f2}}.toolbar-section{display:flex;align-items:center;gap:.625rem}.toolbar-left{flex-shrink:0}.toolbar-middle{flex:1;justify-content:center}.toolbar-right{flex-shrink:0}.toolbar-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.btn-icon{font-size:1rem;line-height:1}.btn-text{white-space:nowrap}.toolbar-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-1px)}.toolbar-btn.active:hover{background:var(--color-primary-hover)}.toolbar-btn.primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border-color:var(--color-primary);font-weight:var(--font-weight-bold);text-shadow:0 1px 2px rgba(0,0,0,.2)}.toolbar-btn.primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.toolbar-btn.optimize{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-color:#7c3aed;font-weight:var(--font-weight-bold)}.toolbar-btn.optimize:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.toolbar-btn.optimize:disabled{background:var(--color-bg-secondary);color:var(--color-text-secondary);border-color:var(--color-border);cursor:not-allowed;transform:none}.toolbar-btn.optimize.optimizing{animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.toolbar-btn.reset{background:linear-gradient(135deg,#64748b,#475569);color:#fff;border-color:#475569;font-weight:var(--font-weight-bold)}.toolbar-btn.reset:hover{transform:translateY(-2px);box-shadow:0 4px 12px #64748b66}.add-dropdown .dropdown-menu{position:absolute;top:100%;right:0;margin-top:.5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;min-width:160px}.add-dropdown .dropdown-menu button{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;text-align:left;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text);transition:background var(--duration-fast)}.add-dropdown .dropdown-menu button:hover{background:var(--color-bg-hover)}.toolbar-middle .search-input{padding:.5rem .875rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);min-width:200px;background:var(--color-bg)}.toolbar-middle .search-input:focus{border-color:var(--color-primary);outline:none}.toolbar-middle .filter-select{padding:.5rem .75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text)}.toolbar-middle .view-mode-toggle{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem}.toolbar-middle .view-mode-toggle button{padding:.375rem .75rem;border:none;background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast)}.toolbar-middle .view-mode-toggle button:hover{color:var(--color-text)}.toolbar-middle .view-mode-toggle button.active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.zoom-controls{display:flex;align-items:center;background:var(--color-bg);border-radius:var(--radius-lg);padding:.25rem;border:1px solid var(--color-border-light)}.zoom-controls button{padding:.375rem .625rem;border:none;background:transparent;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text);cursor:pointer}.zoom-controls button:hover{background:var(--color-bg-hover);color:var(--color-primary)}.zoom-display{min-width:50px;text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);padding:0 .5rem}.table-nav-dropdown .dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;min-width:180px;max-height:300px;overflow-y:auto}.table-nav-dropdown .dropdown-menu button{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.625rem 1rem;background:transparent;border:none;text-align:left;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text);transition:background var(--duration-fast)}.table-nav-dropdown .dropdown-menu button:hover{background:var(--color-bg-hover)}.guest-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:.25rem .75rem;background:var(--color-bg-secondary);border-radius:var(--radius-full)}@media(max-width:768px){.main-toolbar{padding:.5rem .75rem;flex-wrap:nowrap;gap:.5rem}.toolbar-section{gap:.375rem}.toolbar-middle{flex:1;min-width:0;justify-content:center}.toolbar-middle .search-input{min-width:0;flex:1}.toolbar-btn{min-width:var(--touch-target-min);min-height:var(--touch-target-min);padding:.625rem;justify-content:center}.btn-icon{font-size:1.125rem}.main-toolbar.mobile{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem}.main-toolbar.mobile .toolbar-middle.mobile-middle{flex:1;display:flex;justify-content:flex-end;align-items:center}}@media(max-width:480px){.main-toolbar{padding:.375rem .5rem}.toolbar-section{gap:.25rem}.toolbar-btn{min-width:40px;min-height:40px;padding:.5rem;border-radius:var(--radius-sm)}.btn-icon{font-size:1rem}.zoom-controls,.table-nav-dropdown,.guest-count{display:none}}.optimize-toast{position:fixed;bottom:80px;left:50%;transform:translate(-50%);z-index:1000;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-content{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:var(--radius-lg);box-shadow:0 8px 24px #8b5cf666}.toast-icon{font-size:1.25rem}.toast-message{display:flex;flex-direction:column;gap:.125rem}.toast-message strong{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold)}.toast-details{font-size:var(--font-size-xs);opacity:.9}.toast-close{background:#fff3;border:none;color:#fff;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;margin-left:.5rem;transition:background var(--duration-fast)}.toast-close:hover{background:#ffffff4d}@media(max-width:480px){.optimize-toast{bottom:calc(90px + env(safe-area-inset-bottom,0));left:12px;right:12px;transform:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.toast-content{padding:.75rem 1rem;width:100%;box-sizing:border-box}.toast-icon{font-size:1rem}.toast-message strong{font-size:var(--font-size-xs)}.toast-details{font-size:10px}}.grid-controls{display:flex;align-items:center;gap:6px;background:var(--color-bg-secondary);border-radius:8px;padding:4px 8px 4px 10px}.grid-controls-label{font-size:11px;font-weight:600;text-transform:uppercase;color:var(--color-text-secondary);letter-spacing:.5px;margin-right:2px}.grid-control-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:6px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;position:relative;z-index:1}.grid-control-btn.has-tooltip:after{content:attr(data-tooltip);position:absolute;left:100%;top:50%;transform:translateY(-50%);padding:6px 10px;background:var(--color-text);color:var(--color-bg);font-size:12px;font-weight:500;white-space:nowrap;border-radius:6px;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;margin-left:8px;z-index:10000}.grid-control-btn.has-tooltip:before{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:var(--color-text);opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;margin-left:-4px;z-index:10000}.grid-control-btn.has-tooltip:hover:after,.grid-control-btn.has-tooltip:hover:before{opacity:1;visibility:visible}.grid-control-btn:hover{background:var(--color-bg);color:var(--color-text);z-index:9999}.grid-control-btn.active{background:var(--color-primary);color:#fff}.grid-control-btn.active:hover{background:var(--color-primary-hover)}.grid-control-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.grid-control-btn svg{flex-shrink:0}.grid-size-btn{width:auto;min-width:40px;padding:0 8px;gap:4px}.grid-size-value{font-size:11px;font-weight:600}.grid-size-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:8px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-lg);z-index:200;overflow:hidden;min-width:70px;animation:gridDropdownFadeIn .15s ease-out}@keyframes gridDropdownFadeIn{0%{opacity:0;transform:translate(-50%) translateY(-4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.grid-size-option{display:block;width:100%;padding:8px 12px;background:transparent;border:none;text-align:center;font-size:13px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.grid-size-option:hover{background:var(--color-bg-hover);color:var(--color-text)}.grid-size-option.selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:600}@media(max-width:768px){.grid-controls{padding:3px;gap:1px}.grid-controls-label{display:none}.grid-control-btn{width:36px;height:36px}.grid-size-btn{min-width:44px;padding:0 6px}.grid-size-value{font-size:10px}}@media(max-width:480px){.grid-controls{display:none}}.grid-controls-mobile{position:relative}.mobile-menu-trigger{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border:none;border-radius:8px;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.mobile-menu-trigger:hover,.mobile-menu-trigger.active{background:var(--color-primary);color:#fff}.mobile-grid-menu{position:fixed;bottom:calc(70px + env(safe-area-inset-bottom,0px));left:12px;right:12px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;box-shadow:var(--shadow-xl);z-index:1000;animation:slideUpMenu .2s ease-out;overflow:hidden}@keyframes slideUpMenu{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-menu-header{padding:12px 16px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border-light)}.mobile-menu-item{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:transparent;border:none;text-align:left;font-size:15px;color:var(--color-text);cursor:pointer;transition:background .15s ease;min-height:48px}.mobile-menu-item:hover{background:var(--color-bg-hover)}.mobile-menu-item.active{background:var(--color-primary-light);color:var(--color-primary)}.mobile-menu-item svg{flex-shrink:0;color:var(--color-text-secondary)}.mobile-menu-item.active svg{color:var(--color-primary)}.mobile-menu-item .checkmark{margin-left:auto;color:var(--color-primary);font-weight:700}.mobile-menu-divider{height:1px;background:var(--color-border-light);margin:4px 0}.mobile-menu-label{padding:10px 16px 6px;font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.mobile-grid-sizes{display:flex;gap:8px;padding:8px 16px 16px}.mobile-size-option{flex:1;padding:10px 12px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:8px;font-size:14px;font-weight:600;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease;min-height:44px}.mobile-size-option:hover{background:var(--color-bg-hover);border-color:var(--color-primary-light)}.mobile-size-option.selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.relationship-matrix{display:flex;flex-direction:column;height:100%;overflow:hidden}.matrix-controls{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap;gap:1rem}.bidirectional-toggle{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-sm);cursor:pointer}.bidirectional-toggle input{accent-color:var(--color-primary);width:18px;height:18px}.legend{display:flex;gap:1rem;flex-wrap:wrap}.legend-item{display:flex;align-items:center;gap:.375rem;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.legend-color{width:20px;height:20px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.matrix-scroll{flex:1;overflow:auto;padding:1rem}.matrix-grid{display:inline-block;min-width:100%}.matrix-header{display:flex;position:sticky;top:0;background:var(--color-bg);z-index:10}.matrix-corner{width:140px;height:40px;flex-shrink:0;background:var(--color-bg);position:sticky;left:0;z-index:11}.matrix-col-header{width:36px;height:40px;display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);flex-shrink:0}.matrix-row{display:flex}.matrix-row-header{width:140px;padding:0 .5rem;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;position:sticky;left:0;background:var(--color-bg);border-right:2px solid var(--color-border);z-index:5;flex-shrink:0;gap:.125rem}.matrix-row-header .row-name{font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;max-width:100%}.matrix-row-header .row-table{font-size:.625rem;color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.0625rem .25rem;border-radius:var(--radius-sm)}.matrix-cell{width:36px;height:36px;border:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.625rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);transition:transform .1s,box-shadow .1s;flex-shrink:0}.matrix-cell:hover:not(.disabled){transform:scale(1.15);z-index:5;box-shadow:0 2px 8px #0003}.matrix-cell.disabled{background:var(--color-bg-secondary)!important;color:var(--color-border);cursor:default}.matrix-cell.selected{outline:3px solid var(--color-primary);z-index:6}.matrix-cell.same-table{background:#8b5cf626!important}.matrix-cell.same-table:not(.disabled):empty:before{content:"·";color:#8b5cf666;font-size:1.5rem}.matrix-row.table-boundary{border-top:2px solid var(--color-primary)}.matrix-col-header.table-boundary,.matrix-cell.col-boundary{border-left:2px solid var(--color-primary)}.cell-dropdown-overlay{position:fixed;inset:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cell-dropdown{background:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:1rem;min-width:240px;animation:scaleIn .15s ease-out}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.cell-dropdown h4{margin:0 0 .75rem;font-size:var(--font-size-sm);text-align:center;color:var(--color-text-secondary)}.dropdown-options{display:flex;flex-direction:column;gap:.375rem}.dropdown-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .875rem;border:none;border-left:4px solid;background:var(--color-bg);text-align:left;cursor:pointer;font-size:var(--font-size-sm);border-radius:var(--radius-md);transition:background .15s}.dropdown-option:hover{background:var(--color-bg-secondary)}.option-indicator{width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:.625rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.matrix-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--color-text-secondary)}.matrix-empty p{margin:.25rem 0}@media(max-width:768px){.matrix-controls{flex-direction:column;align-items:flex-start;padding:.75rem}.legend{gap:.5rem}.legend-item{font-size:10px}.legend-color{width:16px;height:16px;font-size:.5rem}.matrix-scroll{padding:.5rem}.matrix-row-header{width:100px;font-size:.625rem}.matrix-corner{width:100px}.matrix-cell,.matrix-col-header{width:32px;height:32px}.cell-dropdown{min-width:200px;padding:.75rem}.dropdown-option{padding:.5rem .625rem;font-size:var(--font-size-xs)}}@media(max-width:480px){.matrix-controls{padding:.5rem;gap:.5rem}.legend{gap:.375rem}.legend-item{font-size:9px;gap:.25rem}.legend-color{width:14px;height:14px;font-size:8px}.matrix-scroll{padding:.25rem}.matrix-row-header{width:70px;font-size:9px;padding:0 .25rem}.matrix-row-header .row-table{display:none}.matrix-corner{width:70px;height:32px}.matrix-cell,.matrix-col-header{width:26px;height:26px;font-size:8px}.matrix-col-header{font-size:8px}.cell-dropdown{min-width:180px;margin:0 1rem}.cell-dropdown h4{font-size:var(--font-size-xs);margin-bottom:.5rem}.option-indicator{width:20px;height:20px;font-size:8px}}.import-wizard-overlay{z-index:10000}.import-wizard-modal{background:var(--color-bg);border-radius:var(--radius-xl);width:800px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;animation:modalSlideUp var(--duration-slow) var(--ease-spring);box-shadow:var(--shadow-lg)}.wizard-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-border)}.wizard-header h2{margin:0;font-size:1.25rem;font-weight:600}.wizard-progress{display:flex;gap:.5rem;padding:1rem 1.5rem;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.progress-step{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text-secondary);transition:all var(--duration-fast)}.progress-step.active{background:var(--color-primary);color:#fff}.progress-step.completed{color:var(--color-primary)}.step-number{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;background:var(--color-border);font-size:.75rem;font-weight:600}.progress-step.active .step-number{background:#fff3}.progress-step.completed .step-number{background:var(--color-primary);color:#fff}.step-title{display:none}@media(min-width:600px){.step-title{display:inline}}.wizard-content{flex:1;overflow-y:auto;padding:1.5rem}.wizard-footer{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border)}.footer-spacer{flex:1}.step-description{margin-bottom:1.5rem}.step-description p{margin:0;color:var(--color-text-secondary)}.step-description .hint{font-size:.875rem;margin-top:.5rem}.step-description .platforms-hint{margin-top:.25rem}.step-description .platforms-hint strong{color:var(--color-text)}.step-description .coming-soon-platforms{opacity:.7;font-style:italic}.step-description .warning{display:flex;align-items:center;gap:.5rem;color:var(--color-warning);margin-top:.75rem}.drop-zone{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:3rem;text-align:center;transition:all var(--duration-fast);cursor:pointer}.drop-zone:hover,.drop-zone.dragging{border-color:var(--color-primary);background:var(--color-primary-bg)}.drop-zone.error{border-color:var(--color-error)}.drop-zone-content{display:flex;flex-direction:column;align-items:center;gap:1rem}.drop-icon{color:var(--color-text-secondary)}.drop-text{font-size:1.125rem;font-weight:500;margin:0}.drop-or{color:var(--color-text-secondary);margin:0}.file-input-label{cursor:pointer}.file-input{display:none}.file-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.file-icon{color:var(--color-primary)}.file-details{flex:1}.file-name{font-weight:600;margin:0 0 .25rem}.file-meta{font-size:.875rem;color:var(--color-text-secondary);margin:0}.event-type-hint{font-size:.875rem;color:var(--color-text-secondary);margin:.5rem 0 0}.platform-hint{font-size:.875rem;color:var(--color-text-secondary);margin:.25rem 0 0}.platform-hint .confidence-indicator{font-size:.75rem;color:var(--color-text-tertiary)}.platform-note{display:flex;align-items:flex-start;gap:.375rem;font-size:.75rem;color:var(--color-warning);margin:.5rem 0 0;padding:.5rem .75rem;background:var(--color-warning-bg, rgba(234, 179, 8, .1));border-radius:var(--radius-sm)}.platform-note svg{flex-shrink:0;margin-top:.125rem}.help-improve-hint{display:flex;align-items:center;gap:.375rem;font-size:.75rem;color:var(--color-text-secondary);margin:.5rem 0 0}.help-improve-hint svg{flex-shrink:0;opacity:.7}.help-improve-link{color:var(--color-primary);text-decoration:none;font-weight:500}.help-improve-link:hover{text-decoration:underline}.clear-file{color:var(--color-text-secondary)}.clear-file:hover{color:var(--color-error)}.error-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--color-error-bg);color:var(--color-error);border-radius:var(--radius-md);margin-top:1rem;font-size:.875rem}.info-message{display:flex;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;background:var(--color-info-bg, var(--color-primary-bg));color:var(--color-info, var(--color-primary));border-radius:var(--radius-md);margin-top:1rem;font-size:.875rem}.mapping-table{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.mapping-header{display:grid;grid-template-columns:1fr 1fr 180px;gap:1rem;padding:.75rem 1rem;background:var(--color-bg-secondary);font-weight:600;font-size:.875rem;border-bottom:1px solid var(--color-border)}.mapping-row{display:grid;grid-template-columns:1fr 1fr 180px;gap:1rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);align-items:center}.mapping-row:last-child{border-bottom:none}.col-source{display:flex;align-items:center;gap:.5rem}.column-name{font-weight:500}.confidence-badge{font-size:.75rem;padding:.125rem .375rem;border-radius:var(--radius-sm)}.confidence-badge.high{background:var(--color-success-bg);color:var(--color-success)}.confidence-badge.medium{background:var(--color-warning-bg);color:var(--color-warning)}.confidence-badge.low{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.col-sample{display:flex;flex-direction:column;gap:.25rem}.sample-value{font-size:.875rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.sample-value .empty{color:var(--color-text-tertiary)}.col-target select{width:100%}.col-target select.unmapped{color:var(--color-text-secondary)}.preview-stats{display:flex;gap:1.5rem;margin-bottom:1rem}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:1.5rem;font-weight:700}.stat-label{font-size:.75rem;color:var(--color-text-secondary)}.stat.error .stat-value{color:var(--color-error)}.stat.warning .stat-value{color:var(--color-warning)}.stat.excluded .stat-value{color:var(--color-text-secondary)}.filter-bar{margin-bottom:1rem}.filter-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.875rem;cursor:pointer}.preview-table-container{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;font-size:.875rem}.preview-table th,.preview-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.preview-table th{background:var(--color-bg-secondary);font-weight:600}.preview-table tr:last-child td{border-bottom:none}.preview-table tr.excluded{opacity:.5;text-decoration:line-through}.preview-table tr.has-error{background:var(--color-error-bg)}.preview-table tr.has-warning{background:var(--color-warning-bg)}.col-include{width:60px;text-align:center}.col-row{width:50px;color:var(--color-text-secondary)}.col-status{min-width:150px}.issues{display:flex;flex-wrap:wrap;gap:.25rem}.issue-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-sm)}.issue-badge.error{background:var(--color-error-bg);color:var(--color-error)}.issue-badge.warning{background:var(--color-warning-bg);color:var(--color-warning)}.ok-badge{font-size:.75rem;padding:.125rem .5rem;border-radius:var(--radius-sm);background:var(--color-success-bg);color:var(--color-success)}.empty{color:var(--color-text-tertiary);font-style:italic}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem}.page-info{font-size:.875rem;color:var(--color-text-secondary)}.no-duplicates{display:flex;flex-direction:column;align-items:center;padding:3rem;text-align:center}.success-icon{color:var(--color-success);margin-bottom:1rem}.no-duplicates h3{margin:0 0 .5rem}.no-duplicates p{margin:0;color:var(--color-text-secondary)}.bulk-actions{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.bulk-actions span{font-size:.875rem;color:var(--color-text-secondary)}.btn-small{padding:.375rem .75rem;font-size:.75rem;border-radius:var(--radius-sm);background:var(--color-bg-secondary);border:1px solid var(--color-border);cursor:pointer;transition:all var(--duration-fast)}.btn-small:hover{background:var(--color-bg-tertiary)}.duplicates-list{display:flex;flex-direction:column;gap:1rem}.duplicate-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.duplicate-card.skip{opacity:.6}.duplicate-header{padding:.75rem 1rem;background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.match-info{display:flex;align-items:center;gap:1rem}.match-score{font-weight:600;color:var(--color-warning)}.match-reasons{font-size:.875rem;color:var(--color-text-secondary)}.duplicate-comparison{display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;padding:1rem}.guest-card{padding:1rem;border-radius:var(--radius-md);background:var(--color-bg-secondary)}.guest-card h4{margin:0 0 .75rem;font-size:.75rem;text-transform:uppercase;color:var(--color-text-secondary)}.guest-name{font-weight:600;margin:0 0 .5rem}.guest-detail{font-size:.875rem;color:var(--color-text-secondary);margin:.25rem 0}.guest-detail.assigned{color:var(--color-primary)}.vs-divider{display:flex;align-items:center;color:var(--color-text-tertiary);font-size:.875rem}.resolution-actions{display:flex;gap:.5rem;padding:1rem;border-top:1px solid var(--color-border);flex-wrap:wrap}.resolution-option{flex:1;min-width:120px;display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast)}.resolution-option:hover{border-color:var(--color-primary)}.resolution-option.selected{border-color:var(--color-primary);background:var(--color-primary-bg)}.resolution-option input{display:none}.option-label{font-weight:600;font-size:.875rem}.option-desc{font-size:.75rem;color:var(--color-text-secondary);text-align:center}@media(max-width:600px){.import-wizard-modal{max-height:100vh;border-radius:0}.wizard-content{padding:1rem}.mapping-header,.mapping-row{grid-template-columns:1fr;gap:.5rem}.col-sample{display:none}.duplicate-comparison{grid-template-columns:1fr}.vs-divider{justify-content:center;padding:.5rem 0}}.table-assignment-step{display:flex;flex-direction:column;gap:1.5rem}.assignment-stats{display:flex;gap:2rem;padding:1rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg)}.assignment-stats .stat{display:flex;flex-direction:column;align-items:center}.assignment-stats .stat-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.assignment-stats .stat-label{font-size:.75rem;color:var(--color-text-secondary)}.assignment-toggle{display:flex;flex-direction:column;gap:.75rem}.toggle-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast)}.toggle-option:hover{border-color:var(--color-primary-light)}.toggle-option:has(input:checked){border-color:var(--color-primary);background:var(--color-primary-bg)}.toggle-option input{margin-top:.25rem;accent-color:var(--color-primary)}.toggle-content{display:flex;flex-direction:column;gap:.25rem}.toggle-label{font-weight:600}.toggle-desc{font-size:.875rem;color:var(--color-text-secondary)}.config-section{padding:1.25rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.config-section h4{margin:0 0 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.config-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.config-field{display:flex;flex-direction:column;gap:.5rem}.config-field label{font-size:.875rem;font-weight:500}.config-field select,.config-field input{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:.875rem;color:var(--color-text)}.config-field select:focus,.config-field input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-bg)}.config-field input[type=number]{width:100%}.input-with-hint{display:flex;flex-direction:column;gap:.25rem}.field-hint{font-size:.75rem;color:var(--color-text-secondary)}.strategy-options{display:flex;flex-direction:column;gap:.5rem}.strategy-option{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast);background:var(--color-bg)}.strategy-option:hover{border-color:var(--color-primary-light)}.strategy-option.selected{border-color:var(--color-primary);background:var(--color-primary-bg)}.strategy-option input{margin-top:.125rem;accent-color:var(--color-primary)}.strategy-content{display:flex;flex-direction:column;gap:.125rem}.strategy-label{font-weight:500}.strategy-desc{font-size:.8125rem;color:var(--color-text-secondary)}.table-assignment-step .warning-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-top:.75rem;background:var(--color-warning-bg, #fef3cd);color:var(--color-warning, #856404);border-radius:var(--radius-md);font-size:.875rem}.table-assignment-step .warning-message svg{flex-shrink:0}.assignment-preview{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;max-height:280px;overflow-y:auto}.preview-table{padding:.75rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md)}.preview-table-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.preview-table-name{font-weight:600;font-size:.875rem}.preview-table-count{font-size:.75rem;color:var(--color-text-secondary);padding:.125rem .5rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm)}.preview-guests{display:flex;flex-wrap:wrap;gap:.25rem}.preview-guest{font-size:.75rem;padding:.125rem .5rem;background:var(--color-bg-secondary);border-radius:var(--radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.preview-more{font-size:.75rem;color:var(--color-text-secondary);padding:.125rem .5rem;font-style:italic}@media(max-width:600px){.config-grid{grid-template-columns:1fr}.assignment-stats{flex-direction:column;gap:1rem;align-items:center}.assignment-preview{grid-template-columns:1fr}}.canvas-container{display:flex;flex-direction:column;flex:1;min-width:0;background:var(--color-bg-secondary);position:relative}.canvas-toolbar{display:flex;justify-content:space-between;align-items:center;padding:.875rem 1.25rem;background:#fffcfae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border-light);gap:1rem;position:relative;z-index:10}[data-theme=dark] .canvas-toolbar{background:#241c18e6}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .canvas-toolbar{background:#241c18e6}}.toolbar-group{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap}.toolbar-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;padding-right:.25rem}.toolbar-group button{padding:.625rem 1rem;background:var(--color-bg);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);transition:all var(--duration-normal) var(--ease-bounce)}.toolbar-group button:hover{background:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-1px)}.toolbar-group button:active{transform:translateY(0)}.zoom-display{min-width:60px;text-align:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.375rem .75rem;border-radius:var(--radius-md)}.canvas{flex:1;position:relative;overflow:hidden;background-color:var(--color-bg-secondary)}.canvas.show-grid{background-image:radial-gradient(circle,var(--color-border) 1.5px,transparent 1.5px);background-size:24px 24px}.canvas:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 20%,rgba(249,112,102,.04) 0%,transparent 50%),radial-gradient(ellipse at 70% 80%,rgba(255,176,136,.05) 0%,transparent 50%);pointer-events:none;z-index:0}.canvas-content{position:absolute;width:100%;height:100%;will-change:transform;z-index:1}.canvas-empty{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:var(--color-text-secondary);animation:fadeIn var(--duration-slow) var(--ease-out);z-index:2}.canvas-empty p:first-child{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:.75rem;color:var(--color-text)}.canvas-empty p:last-child{font-size:var(--font-size-base)}.toolbar-divider{padding-left:.75rem;border-left:1px solid var(--color-border);margin-left:.5rem}.toolbar-group button.active{background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.toolbar-icon{font-size:1rem;line-height:1}.grid-size-dropdown{position:relative}.dropdown-menu{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:.5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;min-width:80px}.dropdown-menu button{display:block;width:100%;padding:.5rem 1rem;background:transparent;border:none;text-align:center;cursor:pointer;font-size:var(--font-size-sm);color:var(--color-text-secondary);transition:background var(--duration-fast)}.dropdown-menu button:hover{background:var(--color-bg-hover)}.dropdown-menu button.selected{background:var(--color-primary-light);color:var(--color-primary);font-weight:var(--font-weight-semibold)}.canvas-grid-overlay{position:absolute;inset:0;pointer-events:none;z-index:0;background-image:linear-gradient(to right,var(--color-border-light) 1px,transparent 1px),linear-gradient(to bottom,var(--color-border-light) 1px,transparent 1px);opacity:.6}[data-theme=dark] .canvas-grid-overlay{opacity:.3}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .canvas-grid-overlay{opacity:.3}}.alignment-guide{position:absolute;pointer-events:none;z-index:100}.alignment-guide-horizontal{height:1px;background:var(--color-primary);box-shadow:0 0 4px var(--color-primary)}.alignment-guide-vertical{width:1px;background:var(--color-primary);box-shadow:0 0 4px var(--color-primary)}.alignment-guide:before,.alignment-guide:after{content:"";position:absolute;width:6px;height:6px;background:var(--color-primary);border-radius:50%}.alignment-guide-horizontal:before{left:0;top:50%;transform:translate(-50%,-50%)}.alignment-guide-horizontal:after{right:0;top:50%;transform:translate(50%,-50%)}.alignment-guide-vertical:before{top:0;left:50%;transform:translate(-50%,-50%)}.alignment-guide-vertical:after{bottom:0;left:50%;transform:translate(-50%,50%)}.table-nav-dropdown{position:relative}.table-dropdown-menu{max-height:300px;overflow-y:auto;min-width:180px}.table-nav-item{display:flex!important;justify-content:space-between!important;align-items:center!important;text-align:left!important}.table-nav-name{font-weight:var(--font-weight-medium)}.table-nav-count{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:.125rem .375rem;border-radius:var(--radius-sm)}.table-nav-item.full .table-nav-count{background:var(--color-success-light);color:var(--color-success)}.toolbar-spacer{flex:1}.add-dropdown{position:relative}.add-button{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%)!important;color:#fff!important;border-color:var(--color-primary)!important;font-weight:var(--font-weight-bold)!important;padding:.625rem 1.25rem!important;text-shadow:0 1px 2px rgba(0,0,0,.2)}.add-button:hover{transform:translateY(-2px)!important;box-shadow:var(--shadow-lg)!important}.add-dropdown-menu{min-width:180px;left:0;transform:none}.add-dropdown-menu button{display:flex!important;align-items:center!important;gap:.75rem!important;text-align:left!important;padding:.75rem 1rem!important}.table-shape-icon{font-size:1rem;width:1.25rem;text-align:center}.zoom-controls{background:var(--color-bg);border-radius:var(--radius-lg);padding:.25rem;border:1px solid var(--color-border-light)}.zoom-controls button{padding:.5rem .75rem!important;border:none!important;background:transparent!important;font-size:var(--font-size-lg)!important;font-weight:var(--font-weight-bold)!important;color:var(--color-text)!important}.zoom-controls button:hover{background:var(--color-bg-hover)!important;transform:none!important;color:var(--color-primary)!important}.zoom-controls .recenter-btn{border-left:1px solid var(--color-border-light)!important;margin-left:.25rem;position:relative}.zoom-controls .has-tooltip:after{content:attr(data-tooltip);position:absolute;left:100%;top:50%;transform:translateY(-50%);padding:6px 10px;background:var(--color-text);color:var(--color-bg);font-size:12px;font-weight:500;white-space:nowrap;border-radius:6px;opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;margin-left:8px;z-index:10000}.zoom-controls .has-tooltip:before{content:"";position:absolute;left:100%;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:var(--color-text);opacity:0;visibility:hidden;transition:opacity .15s ease,visibility .15s ease;pointer-events:none;margin-left:-4px;z-index:10000}.zoom-controls .has-tooltip:hover:after,.zoom-controls .has-tooltip:hover:before{opacity:1;visibility:visible}.add-guest-button{padding:.625rem 1.25rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);text-shadow:0 1px 2px rgba(0,0,0,.2)}.add-guest-button:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(max-width:768px){.canvas-toolbar{padding:.625rem 1rem;gap:.75rem;flex-wrap:wrap}.toolbar-group{gap:.5rem}.toolbar-label{display:none}.toolbar-group button{padding:.5rem .75rem;min-height:40px}.zoom-display{min-width:50px;padding:.25rem .5rem;font-size:var(--font-size-xs)}.zoom-controls button{min-width:40px;min-height:40px}}@media(max-width:480px){.canvas-toolbar{padding:.5rem;justify-content:center;gap:.5rem}.toolbar-group{flex:1;justify-content:center}.toolbar-group button{padding:.625rem;min-width:44px;min-height:44px}.toolbar-divider{display:none}.add-button{padding:.625rem 1rem!important;font-size:var(--font-size-xs)!important}.add-dropdown-menu{position:fixed;left:12px!important;right:12px;top:auto;bottom:70px;width:auto;transform:none}.dropdown-menu{position:fixed;inset:auto auto 70px 50%;transform:translate(-50%)}.canvas-empty p:first-child{font-size:var(--font-size-lg)}.canvas-empty p:last-child{font-size:var(--font-size-sm)}}.relationships-panel{position:absolute;top:56px;right:0;bottom:0;background:var(--color-bg);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;z-index:250;animation:slideInRight .2s ease-out;width:auto;max-width:90%}.relationships-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-secondary)}.relationships-panel-header h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.relationships-panel-header .close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;line-height:1;border-radius:var(--radius-sm);transition:all var(--duration-fast)}.relationships-panel-header .close-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}.toolbar-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}@media(max-width:768px){.relationships-panel{max-width:100%;width:100%}.relationships-panel-header{padding:.5rem .75rem}.relationships-panel-header h3{font-size:var(--font-size-sm)}}@media(max-width:480px){.relationships-panel{position:fixed;inset:0;z-index:100}}.selection-rectangle{position:absolute;border:2px dashed var(--color-primary);background:#f970661a;pointer-events:none;z-index:50;border-radius:var(--radius-sm);animation:marching-ants .5s linear infinite}@keyframes marching-ants{0%{stroke-dashoffset:0}to{stroke-dashoffset:16}}.selection-rectangle{background-image:linear-gradient(90deg,var(--color-primary) 50%,transparent 50%),linear-gradient(90deg,var(--color-primary) 50%,transparent 50%),linear-gradient(0deg,var(--color-primary) 50%,transparent 50%),linear-gradient(0deg,var(--color-primary) 50%,transparent 50%);background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;background-size:8px 2px,8px 2px,2px 8px,2px 8px;background-position:0 0,0 100%,0 0,100% 0;animation:marching-ants-border .4s linear infinite;border:none;background-color:#f9706614}@keyframes marching-ants-border{0%{background-position:0 0,8px 100%,0 8px,100% 0}to{background-position:8px 0,0 100%,0 0,100% 8px}}.group-legend{border-top:1px solid var(--color-border-light);padding-top:.75rem;margin-top:.75rem}.group-legend-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;background:var(--color-bg-secondary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.group-legend-header:hover{background:var(--color-bg-hover)}.group-legend-header:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.group-legend-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.collapse-icon{font-size:.625rem;color:var(--color-text-secondary);transition:transform var(--duration-fast) var(--ease-out)}.collapse-icon.collapsed{transform:rotate(0)}.group-legend-content{padding-top:.5rem;animation:fadeIn var(--duration-fast) var(--ease-out)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.legend-actions{display:flex;gap:.5rem;margin-bottom:.5rem;padding:0 .25rem}.legend-action-btn{flex:1;padding:.375rem .5rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.legend-action-btn:hover:not(:disabled){background:var(--color-bg-hover);border-color:var(--color-primary);color:var(--color-text)}.legend-action-btn:disabled,.legend-action-btn.disabled{opacity:.5;cursor:not-allowed}.group-legend-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem;max-height:200px;overflow-y:auto}.group-legend-item{margin:0}.legend-item-label{display:flex;align-items:center;gap:.5rem;padding:.375rem .5rem;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.legend-item-label:hover{background:var(--color-bg-hover)}.legend-item-label.hidden-group{opacity:.5}.legend-item-label input[type=checkbox]{width:14px;height:14px;margin:0;accent-color:var(--color-primary);cursor:pointer}.legend-color{width:14px;height:14px;border-radius:50%;flex-shrink:0;border:1px solid rgba(0,0,0,.1)}.legend-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.legend-count{font-size:var(--font-size-xs);color:var(--color-text-secondary);flex-shrink:0}@media(max-width:768px){.group-legend-list{max-height:150px}.legend-item-label{padding:.5rem}}@media(max-width:480px){.group-legend{margin-top:.5rem;padding-top:.5rem}.legend-actions{flex-direction:column;gap:.375rem}.group-legend-list{max-height:120px}}.sidebar{width:420px;background:var(--color-bg);border-right:1px solid var(--color-border-light);display:flex;flex-direction:column;flex-shrink:0;position:relative;z-index:50}[data-theme=dark] .sidebar{background:var(--color-bg)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .sidebar{background:var(--color-bg)}}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;border-bottom:1px solid var(--color-border-light)}.sidebar-header h2{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.sidebar-toggle{padding:.375rem .75rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text);transition:all var(--duration-normal) var(--ease-bounce)}.sidebar-toggle:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.sidebar-toggle-collapsed{position:fixed;left:0;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border-radius:0 var(--radius-xl) var(--radius-xl) 0;background:var(--color-bg);border:2px solid var(--color-border);border-left:none;z-index:100;box-shadow:var(--shadow-lg);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.sidebar-toggle-collapsed:hover{background:var(--color-primary-light);border-color:var(--color-primary);transform:translateY(-50%) translate(4px);box-shadow:var(--shadow-xl)}.sidebar-toggle-collapsed .toggle-icon{font-size:var(--font-size-base);color:var(--color-primary)}.sidebar-toggle-collapsed .toggle-label{writing-mode:vertical-rl;text-orientation:mixed;font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);color:var(--color-text)}.sidebar-toggle-collapsed .toggle-count{writing-mode:horizontal-tb;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:#fff;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center}.sidebar-toggle-collapsed .toggle-stats{writing-mode:vertical-rl;text-orientation:mixed;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.sidebar-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;padding:1.25rem;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-secondary)}.stat{display:flex;flex-direction:column;align-items:center;text-align:center;padding:.5rem;border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out)}.stat:hover{background:var(--color-bg);transform:translateY(-2px)}.stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-extrabold);line-height:1}.stat-label{font-size:.625rem;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-semibold);margin-top:.25rem}.stat.confirmed .stat-value{color:var(--color-success)}.stat.pending .stat-value{color:var(--color-warning)}.sidebar-controls{padding:1.25rem;display:flex;flex-direction:column;gap:.875rem;border-bottom:1px solid var(--color-border-light)}.search-input{padding:.75rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-sm);background:var(--color-bg);transition:all var(--duration-normal) var(--ease-out)}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px var(--focus-ring-color)}.filter-row{display:flex;gap:.75rem}.filter-select{flex:1;padding:.625rem .875rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);background:var(--color-bg);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.filter-select:hover{border-color:var(--color-primary)}.add-guest-btn{padding:.875rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-weight:var(--font-weight-bold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce);box-shadow:0 4px 12px #f970664d}.add-guest-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #f9706666}.add-guest-btn:active{transform:translateY(0)}.guest-lists{flex:1;overflow-y:auto;padding:1.25rem}.guest-list-section{margin-bottom:1.75rem;animation:fadeIn var(--duration-normal) var(--ease-out)}.guest-list-section h3{margin:0 0 .875rem;font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);font-weight:var(--font-weight-bold)}.drag-hint{margin:0 0 .75rem;padding:.5rem .75rem;font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-primary-light);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.guest-list{display:flex;flex-direction:column;gap:.625rem}.guest-list>*{animation:staggerIn var(--duration-normal) var(--ease-out) backwards}.guest-list>*:nth-child(1){animation-delay:.02s}.guest-list>*:nth-child(2){animation-delay:.04s}.guest-list>*:nth-child(3){animation-delay:.06s}.guest-list>*:nth-child(4){animation-delay:.08s}.guest-list>*:nth-child(5){animation-delay:.1s}.guest-list>*:nth-child(6){animation-delay:.12s}.guest-list>*:nth-child(7){animation-delay:.14s}.guest-list>*:nth-child(8){animation-delay:.16s}.empty-message{color:var(--color-text-secondary);font-size:var(--font-size-sm);text-align:center;padding:1.5rem;background:var(--color-bg-secondary);border-radius:var(--radius-lg);border:2px dashed var(--color-border)}.assigned-guest-row{display:flex;align-items:center;gap:.625rem}.assigned-guest-row .guest-chip{flex:1}.table-badge{font-size:.625rem;padding:.375rem .625rem;background:var(--color-primary-light);border-radius:var(--radius-full);color:var(--color-primary);white-space:nowrap;font-weight:var(--font-weight-semibold)}.sidebar-backdrop{display:none}@media(max-width:900px){.sidebar{width:320px}.sidebar-stats{grid-template-columns:repeat(2,1fr);padding:1rem}}@media(max-width:768px){.sidebar-backdrop{display:block;position:fixed;inset:0;background-color:#00000080;z-index:199;animation:fadeInBackdrop var(--duration-normal) var(--ease-out);-webkit-tap-highlight-color:transparent}.sidebar{position:fixed;left:0;top:0;height:100%;width:85%;max-width:320px;z-index:200;transform:translate(-100%);transition:transform var(--duration-normal) var(--ease-spring);box-shadow:var(--shadow-xl)}.sidebar.open{transform:translate(0)}.sidebar-toggle{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:199;padding:1rem .75rem;min-height:60px;border-radius:0 var(--radius-lg) var(--radius-lg) 0;background:var(--color-bg);box-shadow:var(--shadow-lg);writing-mode:vertical-rl;font-size:var(--font-size-sm)}.sidebar-toggle-collapsed{left:0;padding:1rem .625rem;min-width:44px}.sidebar-toggle-collapsed .toggle-label{font-size:var(--font-size-xs)}.sidebar-header{padding:1rem}.sidebar-controls{padding:1rem;gap:.75rem}.add-guest-btn{min-height:44px}.guest-lists{padding:1rem;padding-bottom:100px}}@media(max-width:480px){.sidebar{width:100%;max-width:none}.sidebar-stats{grid-template-columns:repeat(4,1fr);padding:.75rem;gap:.5rem}.stat{min-height:44px;padding:.625rem .25rem}.stat-value{font-size:var(--font-size-lg)}.stat-label{font-size:.5rem}.filter-select{min-height:44px;padding:.75rem}.search-input{min-height:44px}.guest-chip{min-height:48px;padding:.75rem}.guest-lists{padding-bottom:calc(100px + env(safe-area-inset-bottom,0))}}.guest-management-view{display:flex;flex-direction:column;height:100%;flex:1;overflow:hidden}.gm-toolbar{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--color-bg);border-bottom:1px solid var(--color-border-light);gap:1rem;flex-wrap:wrap}.toolbar-left{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.search-input{padding:.625rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--font-size-sm);min-width:250px;background:var(--color-bg)}.search-input:focus{border-color:var(--color-primary);outline:none}.filter-select{padding:.625rem .875rem;border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg);color:var(--color-text)}.toolbar-right{display:flex;align-items:center;gap:1rem}.guest-count{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.view-toggle{display:flex;background:var(--color-bg-secondary);border-radius:var(--radius-md);padding:.25rem}.view-toggle button{padding:.5rem 1rem;border:none;background:transparent;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--duration-fast)}.view-toggle button:hover{color:var(--color-text)}.view-toggle button.active{background:var(--color-bg);color:var(--color-text);box-shadow:var(--shadow-sm)}.add-guest-btn{padding:.625rem 1.25rem;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;box-shadow:0 4px 12px #f970664d}.bulk-actions-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,var(--color-primary-light) 0%,rgba(255,176,136,.15) 100%);animation:slideDown var(--duration-normal) var(--ease-spring)}.selection-count{font-weight:var(--font-weight-semibold);color:var(--color-primary);margin-right:.5rem}.bulk-select{padding:.5rem .75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:var(--font-size-sm)}.bulk-btn{padding:.5rem .875rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);font-size:var(--font-size-sm);cursor:pointer}.bulk-btn.danger{color:var(--color-error);border-color:var(--color-error-light)}.bulk-btn.danger:hover{background:var(--color-error);color:#fff}.bulk-btn.clear{border:none;background:transparent;color:var(--color-text-secondary)}.gm-content{display:flex;flex:1;overflow:hidden}.guest-table-container{flex:1;overflow:auto;padding:1rem 1.5rem}.empty-state{text-align:center;padding:3rem;color:var(--color-text-secondary)}.empty-state h3{margin-bottom:.5rem;color:var(--color-text)}.empty-state p{margin-bottom:1rem}.guest-table{width:100%;border-collapse:separate;border-spacing:0}.guest-table th{position:sticky;top:0;background:var(--color-bg);padding:.875rem 1rem;text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);z-index:10}.guest-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.guest-table th.sortable:hover{color:var(--color-text)}.guest-table td{padding:.875rem 1rem;border-bottom:1px solid var(--color-border-light);vertical-align:middle}.guest-table tr{cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.guest-table tbody tr:hover{background:var(--color-bg-hover)}.guest-table tr.selected{background:var(--color-primary-light)}.guest-table tr.highlighted{background:var(--color-secondary-light)}.checkbox-col{width:40px}.guest-name-cell{display:flex;align-items:center;gap:.75rem}.guest-avatar{width:36px;height:36px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);color:#fff;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);flex-shrink:0}.guest-name{display:block;font-weight:var(--font-weight-semibold);color:var(--color-text)}.guest-company{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.group-chip{display:inline-block;padding:.25rem .625rem;background:var(--color-bg-secondary);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.no-group{color:var(--color-text-light)}.rsvp-badge{display:inline-block;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase}.rsvp-badge.confirmed{background:var(--color-success-light);color:#166534}.rsvp-badge.pending{background:var(--color-warning-light);color:#92400e}.rsvp-badge.declined{background:var(--color-error-light);color:#991b1b}.table-badge{display:inline-block;padding:.25rem .625rem;background:var(--color-primary-light);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-primary)}.unassigned{color:var(--color-text-light);font-style:italic;font-size:var(--font-size-sm)}.row-actions{display:flex;gap:.375rem;opacity:0;transition:opacity var(--duration-fast)}.guest-table tbody tr:hover .row-actions{opacity:1}.action-icon-btn{padding:.375rem .5rem;border:none;background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer}.action-icon-btn:hover{background:var(--color-primary-light);color:var(--color-primary)}.action-icon-btn.danger:hover{background:var(--color-error-light);color:var(--color-error)}.guest-detail-panel{width:360px;background:var(--color-bg);border-left:1px solid var(--color-border-light);display:flex;flex-direction:column;flex-shrink:0;animation:slideInRight var(--duration-normal) var(--ease-spring)}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border-light)}.detail-header h3{font-size:var(--font-size-base);font-weight:var(--font-weight-bold)}.close-btn{width:28px;height:28px;border:none;background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:18px;color:var(--color-text-secondary);cursor:pointer}.detail-content{flex:1;padding:1.25rem;overflow-y:auto;text-align:center}.detail-avatar{width:72px;height:72px;margin:0 auto 1rem;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#fff;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);box-shadow:0 4px 12px #f970664d}.detail-content h2{font-size:var(--font-size-lg);margin-bottom:.25rem}.detail-email,.detail-company{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.detail-badges{display:flex;justify-content:center;gap:.5rem;margin-top:.75rem;margin-bottom:1.25rem}.detail-section{text-align:left;margin-bottom:1.25rem;padding-top:1rem;border-top:1px solid var(--color-border-light)}.detail-section h4{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:var(--letter-spacing-wide);color:var(--color-text-secondary);margin-bottom:.5rem}.tag-list{display:flex;flex-wrap:wrap;gap:.375rem}.tag{padding:.25rem .625rem;background:var(--color-bg-secondary);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.tag.warning{background:var(--color-warning-light);color:#92400e}.relationships-list{display:flex;flex-direction:column;gap:.5rem}.relationship-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--color-bg-secondary);border-radius:var(--radius-md);border-left:3px solid var(--color-border)}.relationship-item.family{border-left-color:var(--rel-family)}.relationship-item.friend{border-left-color:var(--rel-friend)}.relationship-item.colleague{border-left-color:var(--rel-colleague)}.relationship-item.partner{border-left-color:var(--rel-partner)}.relationship-item.avoid{border-left-color:var(--rel-avoid)}.rel-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.rel-type{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.notes-text{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;margin:0}.detail-actions{padding-top:1rem;border-top:1px solid var(--color-border-light);margin-top:auto}.detail-btn{width:100%;padding:.75rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer}@media(max-width:900px){.guest-detail-panel{position:fixed;right:0;top:0;height:100%;z-index:100;box-shadow:var(--shadow-xl)}.toolbar-left{width:100%}.search-input{min-width:auto;flex:1}}@media(max-width:768px){.gm-toolbar{padding:.75rem 1rem;gap:.75rem}.guest-table-container{padding:.75rem}.guest-table th,.guest-table td{padding:.625rem .5rem;font-size:var(--font-size-xs)}.guest-avatar{width:30px;height:30px;font-size:10px}.guest-name-cell{gap:.5rem}.guest-detail-panel{width:300px}.bulk-actions-bar{padding:.5rem 1rem;gap:.5rem;flex-wrap:wrap}.bulk-select,.bulk-btn{font-size:var(--font-size-xs);padding:.375rem .5rem}}@media(max-width:480px){.gm-toolbar{padding:.5rem;gap:.5rem}.search-input{font-size:var(--font-size-xs);padding:.5rem .75rem}.filter-select{font-size:var(--font-size-xs);padding:.5rem}.guest-table-container{padding:.5rem}.guest-table th{font-size:10px;padding:.5rem .375rem}.guest-table td{padding:.5rem .375rem;font-size:11px}.checkbox-col{width:30px}.guest-avatar{width:26px;height:26px;font-size:9px}.guest-name{font-size:11px}.guest-company{display:none}.group-chip,.rsvp-badge,.table-badge{font-size:9px;padding:.125rem .375rem}.row-actions{opacity:1}.action-icon-btn{padding:.25rem .375rem;font-size:10px}.guest-detail-panel{width:100%;max-width:100%}.detail-content{padding:1rem}.detail-avatar{width:56px;height:56px;font-size:var(--font-size-lg)}.bulk-actions-bar{padding:.5rem}.selection-count{font-size:var(--font-size-xs)}.empty-state{padding:2rem 1rem}.empty-state h3{font-size:var(--font-size-base)}.empty-state p{font-size:var(--font-size-sm)}.guest-table th:nth-child(3),.guest-table td:nth-child(3){display:none}}.guest-management-view .relationships-panel{position:absolute;top:56px;right:0;bottom:0;background:var(--color-bg);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;z-index:50;animation:slideInRight .2s ease-out;width:auto;max-width:90%}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.guest-management-view .relationships-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-bottom:1px solid var(--color-border-light);background:var(--color-bg-secondary)}.guest-management-view .relationships-panel-header h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.guest-management-view .relationships-panel-header .close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-secondary);padding:.25rem;line-height:1;border-radius:var(--radius-sm);transition:all var(--duration-fast)}.guest-management-view .relationships-panel-header .close-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}@media(max-width:768px){.guest-management-view .relationships-panel{max-width:100%;width:100%}.guest-management-view .relationships-panel-header{padding:.5rem .75rem}.guest-management-view .relationships-panel-header h3{font-size:var(--font-size-sm)}}@media(max-width:480px){.guest-management-view .relationships-panel{position:fixed;inset:0}}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E"),radial-gradient(ellipse 80% 50% at 20% 10%,rgba(249,112,102,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 80% at 80% 90%,rgba(255,176,136,.1) 0%,transparent 50%),linear-gradient(160deg,var(--color-bg) 0%,var(--color-bg-warm) 50%,var(--color-bg-secondary) 100%);position:relative}.app:before{content:"";position:fixed;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(249,112,102,.06) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0}.app:after{content:"";position:fixed;bottom:-150px;left:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(255,176,136,.08) 0%,transparent 70%);border-radius:50%;pointer-events:none;z-index:0}[data-theme=dark] .app{background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.05'/%3E%3C/svg%3E"),radial-gradient(ellipse 80% 50% at 20% 10%,rgba(255,138,125,.05) 0%,transparent 50%),radial-gradient(ellipse 60% 80% at 80% 90%,rgba(255,190,152,.04) 0%,transparent 50%),linear-gradient(160deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}[data-theme=dark] .app:before{background:radial-gradient(circle,rgba(255,138,125,.04) 0%,transparent 70%)}[data-theme=dark] .app:after{background:radial-gradient(circle,rgba(255,190,152,.05) 0%,transparent 70%)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]):not([data-theme=dark]) .app{background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.05'/%3E%3C/svg%3E"),radial-gradient(ellipse 80% 50% at 20% 10%,rgba(255,138,125,.05) 0%,transparent 50%),radial-gradient(ellipse 60% 80% at 80% 90%,rgba(255,190,152,.04) 0%,transparent 50%),linear-gradient(160deg,var(--color-bg) 0%,var(--color-bg-secondary) 100%)}:root:not([data-theme=light]):not([data-theme=dark]) .app:before{background:radial-gradient(circle,rgba(255,138,125,.04) 0%,transparent 70%)}:root:not([data-theme=light]):not([data-theme=dark]) .app:after{background:radial-gradient(circle,rgba(255,190,152,.05) 0%,transparent 70%)}}.main-content{display:flex;flex:1;min-height:0;position:relative;z-index:1;transition:opacity var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.main-content.view-visible{opacity:1;transform:translateY(0)}.main-content.view-transitioning{opacity:0;transform:translateY(8px)}.view-mockups-btn{position:fixed;bottom:20px;right:20px;padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--color-warning) 0%,#f59e0b 100%);color:#1a1a1a;border:none;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);cursor:pointer;z-index:1000;box-shadow:0 4px 12px #fbbf2466;transition:all var(--duration-normal) var(--ease-bounce)}.view-mockups-btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #fbbf2480}.exit-mockups-btn{position:fixed;top:12px;right:20px;padding:.5rem 1rem;background:var(--color-text);color:var(--color-bg);border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;z-index:1000;transition:all var(--duration-normal) var(--ease-bounce)}.exit-mockups-btn:hover{opacity:.9}@media(max-width:768px){.main-content{flex-direction:column}.view-mockups-btn{bottom:80px;right:12px;padding:.5rem 1rem;font-size:var(--font-size-xs)}}@media(max-width:480px){.app:before,.app:after{display:none}.view-mockups-btn{bottom:70px;font-size:.625rem;padding:.375rem .75rem}.main-content{padding-bottom:60px}}.shortcuts-modal{background:var(--color-bg);border-radius:var(--radius-xl);padding:2rem;max-width:600px;width:100%;animation:modalSlideUp var(--duration-slow) var(--ease-spring);box-shadow:var(--shadow-xl)}.shortcuts-modal h2{margin:0 0 1.5rem;font-size:var(--font-size-xl);text-align:center}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem}.shortcut-category h3{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border-light)}.shortcut-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.shortcut-key{display:inline-block;padding:.25rem .5rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:ui-monospace,SFMono-Regular,monospace;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);min-width:100px;text-align:center;white-space:nowrap}.shortcut-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.close-shortcuts{display:block;width:100%;margin-top:1.5rem;padding:.75rem;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--duration-normal) var(--ease-bounce)}.close-shortcuts:hover{background:var(--color-primary-light);border-color:var(--color-primary)}
