:root{--color-bg-primary: #000000;--color-bg-secondary: #0a0a0a;--color-bg-surface: #141414;--color-bg-surface-hover: #1f1f1f;--color-gold: #E8BF5F;--color-gold-light: #f4d588;--color-gold-dim: #a6853a;--color-wine-red: #722f37;--color-wine-red-light: #9b4049;--color-text-primary: #f0ede6;--color-text-secondary: #9d9a91;--color-text-muted: #5c5a54;--color-success: #4caf50;--color-warning: #ff9800;--color-error: #ef5350;--font-display: "Tenor Sans", sans-serif;--font-ui: "Outfit", sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 0px;--radius-md: 0px;--radius-lg: 0px;--radius-xl: 0px;--radius-full: 0px;--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--shadow-glow-gold: 0 0 20px rgba(201, 165, 78, .15);--shadow-glow-gold-strong: 0 0 30px rgba(201, 165, 78, .3);--shadow-elevated: 0 8px 32px rgba(0, 0, 0, .4)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-ui);font-size:16px;line-height:1.5;color:var(--color-text-primary);background:var(--color-bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;position:relative;overflow:hidden;background:linear-gradient(#00000080,#000000b3),url(/winery-bg.png);background-size:cover;background-position:center}.app__header{display:flex;align-items:center;justify-content:center;padding:var(--space-md) var(--space-lg);z-index:10;flex-shrink:0}.app__brand{font-family:var(--font-display);font-size:1.1rem;font-weight:400;color:var(--color-gold);letter-spacing:.15em;text-transform:uppercase;opacity:.7}.app__avatar-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;min-height:0}.app__avatar-container{width:100%;flex:1;position:relative;min-height:0}.app__avatar-container canvas{width:100%!important;height:100%!important;display:block}.app__footer{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-lg) var(--space-lg) var(--space-2xl);z-index:10;flex-shrink:0}.app__avatar-area:before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(201,165,78,.06) 0%,transparent 70%);pointer-events:none;animation:ambient-pulse 6s ease-in-out infinite}@keyframes ambient-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.status{display:flex;align-items:center;gap:var(--space-sm);font-size:.8rem;color:var(--color-text-secondary);letter-spacing:.05em;text-transform:uppercase}.status__dot{width:8px;height:8px;border-radius:50%;background:var(--color-text-muted);transition:background var(--transition-base)}.status__dot--disconnected{background:var(--color-text-muted)}.status__dot--connecting{background:var(--color-warning);animation:status-pulse 1s ease-in-out infinite}.status__dot--connected{background:var(--color-success);animation:status-pulse 2s ease-in-out infinite}@keyframes status-pulse{0%,to{opacity:1;box-shadow:0 0 0 0 currentColor}50%{opacity:.7;box-shadow:0 0 8px 2px currentColor}}.controls{display:flex;align-items:center;gap:var(--space-md)}.controls__button{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);border:none;cursor:pointer;font-family:var(--font-ui);font-weight:500;font-size:.95rem;letter-spacing:.03em;transition:all var(--transition-base);-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.controls__button--primary{min-width:220px;min-height:52px;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-sm);background:var(--color-gold);color:#000;border:1px solid rgba(255,255,255,.1);box-shadow:0 4px 15px #0006;text-transform:uppercase;letter-spacing:.15em;font-family:var(--font-display)}.controls__button--primary:hover{background:var(--color-gold-light);transform:translateY(-2px);box-shadow:0 6px 20px #0009}.controls__button--primary:active{transform:translateY(0);box-shadow:var(--shadow-glow-gold)}.controls__button--danger{min-width:180px;min-height:56px;padding:var(--space-md) var(--space-xl);border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-wine-red) 0%,#5a242b 100%);color:var(--color-text-primary);box-shadow:0 0 20px #722f3733}.controls__button--danger:hover{background:linear-gradient(135deg,var(--color-wine-red-light) 0%,var(--color-wine-red) 100%);box-shadow:0 0 30px #722f3766;transform:translateY(-1px)}.controls__button--danger:active{transform:translateY(0)}.controls__button--icon{width:56px;height:56px;border-radius:50%;background:var(--color-bg-surface);color:var(--color-text-secondary);border:1px solid rgba(255,255,255,.06)}.controls__button--icon:hover{background:var(--color-bg-surface-hover);color:var(--color-text-primary);border-color:#ffffff1a}.controls__button--icon--active{background:var(--color-wine-red);color:var(--color-text-primary);border-color:var(--color-wine-red)}.controls__button:disabled{opacity:.4;cursor:not-allowed;transform:none!important}.idle-text{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);flex-shrink:0;z-index:10;background:radial-gradient(ellipse at center,rgba(0,0,0,.6) 0%,transparent 70%);width:100%}.idle-text__title{font-family:var(--font-display);font-size:2rem;font-weight:400;color:var(--color-gold);letter-spacing:.05em;text-align:center;opacity:0;animation:idle-fade-in 1s ease .3s forwards}.idle-text__subtitle{font-size:.9rem;color:var(--color-text-secondary);text-align:center;opacity:0;animation:idle-fade-in 1s ease .6s forwards}@keyframes idle-fade-in{to{opacity:1}}.access-gate{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.access-gate__card{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-xl) var(--space-lg);max-width:420px;width:100%;background:#0a0a0ad9;border:1px solid rgba(232,191,95,.15);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);animation:gate-fade-in .6s ease forwards}.access-gate__brand{font-family:var(--font-display);font-size:.85rem;color:var(--color-gold);letter-spacing:.2em;text-transform:uppercase;opacity:.7}.access-gate__title{font-family:var(--font-display);font-size:2.2rem;font-weight:400;color:var(--color-gold);letter-spacing:.05em;text-align:center;margin-top:calc(-1 * var(--space-sm))}.access-gate__subtitle{font-size:1rem;color:var(--color-text-secondary);text-align:center;line-height:1.5;margin-top:calc(-1 * var(--space-sm))}.access-gate__form{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.access-gate__input{width:100%;padding:1rem 1.25rem;background:#ffffff0d;border:1px solid rgba(232,191,95,.25);color:var(--color-text-primary);font-family:var(--font-display);font-size:1.1rem;letter-spacing:.15em;text-align:center;text-transform:uppercase;outline:none;transition:border-color var(--transition-base)}.access-gate__input::placeholder{color:var(--color-text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:.9rem}.access-gate__input:focus{border-color:var(--color-gold)}.access-gate__error{color:var(--color-error);font-size:.85rem;text-align:center}.access-gate__button{width:100%;padding:1rem;background:var(--color-gold);color:#000;border:none;cursor:pointer;font-family:var(--font-display);font-size:.95rem;text-transform:uppercase;letter-spacing:.15em;transition:all var(--transition-base);box-shadow:0 4px 15px #0006}.access-gate__button:hover:not(:disabled){background:var(--color-gold-light);transform:translateY(-2px);box-shadow:0 6px 20px #0009}.access-gate__button:disabled{opacity:.4;cursor:not-allowed}@keyframes gate-fade-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app__loading{flex:1;display:flex;align-items:center;justify-content:center}@media(max-width:768px){.app__footer{padding:var(--space-md) var(--space-md) calc(var(--space-lg) + env(safe-area-inset-bottom))}.app__avatar-container{max-width:100vw;max-height:60vh}.app__avatar-container canvas{transform:scale(2) translateY(10%);transform-origin:center top}.idle-text{display:none}.controls__button--primary{min-width:80vw}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
