:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #1a1625;--bg-secondary: #251f3a;--bg-tertiary: #342b4f;--text-primary: #e8e3ff;--text-secondary: #b8a9ff;--accent-green: #4ade80;--accent-red: #f87171;--accent-gold: #fbbf24;--accent-blue: #60a5fa;--border-color: #4a3f6b;--shadow: 0 4px 6px -1px rgba(0, 0, 0, .3)}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);color:var(--text-primary);min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:var(--bg-tertiary);padding:1.5rem 2rem;box-shadow:var(--shadow);border-bottom:2px solid var(--accent-gold)}.header-content{max-width:1400px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;text-align:left}.header-left h1{margin:0}.header-left .subtitle{margin:.2rem 0 0}.header-right,.user-controls{display:flex;align-items:center;gap:1rem}.game-selector{background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-primary);padding:.5rem;border-radius:6px;min-width:200px}.user-email{color:var(--text-secondary);font-size:.85rem}.auth-buttons{display:flex;gap:.5rem}.login-btn,.register-btn,.logout-btn{background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;cursor:pointer;transition:all .2s ease}.register-btn{background:linear-gradient(135deg,indigo,#639);border-color:var(--accent-gold);color:var(--accent-gold)}.login-btn:hover,.logout-btn:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.register-btn:hover{background:linear-gradient(135deg,#6a0d83,#7a3d9a);transform:translateY(-1px)}.app-header h1{font-size:2rem;color:var(--accent-gold);text-shadow:2px 2px 4px rgba(0,0,0,.5);margin-bottom:.3rem}.subtitle{font-size:.95rem;color:var(--text-secondary)}.app-main{flex:1;max-width:1600px;margin:0 auto;padding:1.5rem;width:100%}.controls-section{display:flex;gap:2rem;margin-bottom:1.5rem;flex-wrap:wrap;align-items:center}.dm-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.dm-name-input{display:flex;align-items:center;gap:.5rem}.dm-name-input label{font-weight:600;color:var(--text-secondary);font-size:.9rem}.dm-name-field{padding:.4rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem;min-width:150px}.dm-logo-upload{display:flex;align-items:center;margin-right:1rem;flex-shrink:0}.logo-upload-area{position:relative}.logo-preview{position:relative;display:inline-block}.logo-image{width:210px;height:210px;border-radius:12px;object-fit:cover;border:3px solid var(--border-color);cursor:pointer}.remove-logo-btn{position:absolute;top:-8px;right:-8px;width:20px;height:20px;border-radius:50%;background:var(--accent-red);border:none;color:#fff;font-size:.8rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.remove-logo-btn:hover{background:#dc2626;transform:scale(1.1)}.upload-placeholder{display:flex;align-items:center;justify-content:center;width:210px;height:210px;border:3px dashed var(--border-color);border-radius:12px;background:var(--bg-tertiary);color:var(--text-secondary);font-size:4rem;cursor:pointer;transition:all .2s;text-align:center}.upload-placeholder:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:var(--bg-secondary)}.dm-timezone-selector{display:flex;align-items:center;gap:.5rem}.dm-timezone-selector label{font-weight:600;color:var(--text-secondary);font-size:.9rem}.dm-timezone-select{padding:.4rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem}.toggle-editor-btn{padding:.4rem .8rem;border-radius:4px;border:1px solid var(--accent-gold);background:var(--bg-tertiary);color:var(--accent-gold);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.toggle-editor-btn:hover{background:var(--accent-gold);color:var(--bg-primary)}.clear-all-btn{padding:.4rem .8rem;border-radius:4px;border:1px solid var(--accent-red);background:var(--bg-tertiary);color:var(--accent-red);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s}.clear-all-btn:hover{background:var(--accent-red);color:#fff}.day-selector{display:flex;align-items:center;gap:.5rem}.day-selector label{font-weight:600;color:var(--text-secondary);font-size:.9rem}.day-buttons{display:flex;gap:.3rem}.day-btn{padding:.3rem .6rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-size:.85rem;transition:all .2s}.day-btn:hover{background:var(--bg-secondary)}.day-btn.selected{background:var(--accent-blue);border-color:var(--accent-blue);color:#fff}.schedule-editor-container{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow)}.schedule-editor h3{color:var(--accent-gold);margin-bottom:1rem}.schedule-controls{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.schedule-controls button{padding:.4rem .8rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s;font-size:.85rem}.schedule-controls button:hover{background:var(--accent-blue);border-color:var(--accent-blue)}.schedule-grid{background:var(--bg-primary);border-radius:4px;padding:1rem;overflow-x:auto}.schedule-header{display:grid;grid-template-columns:60px repeat(7,1fr);gap:4px;margin-bottom:4px}.day-header{text-align:center;font-weight:600;color:var(--text-secondary);padding:.5rem;font-size:.85rem}.schedule-body{display:flex;flex-direction:column;gap:2px}.schedule-row{display:grid;grid-template-columns:60px repeat(7,1fr);gap:4px}.hour-header{text-align:right;padding-right:.5rem;color:var(--text-secondary);font-size:.8rem;display:flex;align-items:center;justify-content:flex-end}.schedule-slot{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:2px;min-height:25px;cursor:pointer;transition:all .2s}.schedule-slot:hover{border-color:var(--accent-blue)}.schedule-slot.selected{background:var(--accent-green);border-color:var(--accent-green)}.timezones-container{background:var(--bg-secondary);border-radius:8px;padding:1.5rem;box-shadow:var(--shadow)}.timezones-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.timezones-header h2{color:var(--accent-gold);font-size:1.3rem}.week-controls{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.week-date-selector{display:flex;gap:.5rem;align-items:center}.week-date-selector label{font-weight:600;color:var(--text-secondary);font-size:.9rem}.week-date-input{padding:.4rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem}.snap-to-now-btn{padding:.4rem .8rem;border-radius:4px;border:1px solid var(--accent-blue);background:var(--bg-tertiary);color:var(--accent-blue);cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s}.snap-to-now-btn:hover{background:var(--accent-blue);color:#fff}.day-navigation{display:flex;gap:.2rem}.day-nav-btn{padding:.3rem .6rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s;min-width:40px}.day-nav-btn:hover{background:var(--bg-secondary);border-color:var(--accent-gold)}.day-nav-btn.active{background:var(--accent-gold);border-color:var(--accent-gold);color:var(--bg-primary)}.legend{display:flex;gap:1rem;font-size:.85rem}.legend-item{display:flex;align-items:center;gap:.3rem;color:var(--text-secondary)}.legend-item:before{content:"";width:16px;height:16px;border-radius:3px;border:1px solid var(--border-color)}.legend-item.available:before{background:var(--accent-green)}.legend-item.unavailable:before{background:var(--accent-red)}.legend-item.current:before{background:var(--accent-blue)}.timezones-list{display:flex;flex-direction:column;background:var(--bg-primary);border-radius:8px;overflow:hidden}.timezone-row-compact{display:flex;border-bottom:1px solid var(--border-color);min-height:80px}.timezone-row-compact:last-child{border-bottom:none}.timezone-label-compact{width:200px;min-width:200px;padding:1rem;background:var(--bg-tertiary);border-right:2px solid var(--border-color);display:flex;flex-direction:column;justify-content:center;position:relative}.timezone-header-row{display:flex;align-items:center;gap:.75rem;width:100%}.timezone-logo{width:40px;height:40px;border-radius:6px;object-fit:cover;border:2px solid var(--border-color);flex-shrink:0}.timezone-info{flex:1;min-width:0}.timezone-name{font-weight:600;font-size:.95rem;color:var(--text-primary);margin-bottom:.3rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%;padding-right:2rem}.dm-badge{background:var(--accent-gold);color:var(--bg-primary);padding:.1rem .3rem;border-radius:3px;font-size:.7rem;margin-right:.3rem;font-weight:700}.you-badge{background:var(--accent-blue);color:#fff;padding:.1rem .3rem;border-radius:3px;font-size:.7rem;margin-left:.3rem}.timezone-offset-compact{color:var(--text-secondary);font-size:.75rem;margin-bottom:.2rem}.timezone-name-small{color:#9370db;font-size:.75rem;margin-top:2px;opacity:.8}.timezone-current-time{color:var(--accent-blue);font-size:.85rem;font-weight:500}.remove-btn-compact{position:absolute;top:.5rem;right:.5rem;background:transparent;border:none;color:var(--accent-red);cursor:pointer;font-size:1.2rem;padding:0;width:20px;height:20px;line-height:1;opacity:.6;transition:opacity .2s}.remove-btn-compact:hover{opacity:1}.hours-row{display:flex;align-items:center;padding:.5rem;gap:1px;overflow-x:auto;width:1400px;scrollbar-width:thin;scrollbar-color:var(--accent-blue) var(--bg-tertiary)}.hours-row::-webkit-scrollbar{height:8px}.hours-row::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:4px}.hours-row::-webkit-scrollbar-thumb{background:var(--accent-blue);border-radius:4px}.hours-row::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.hour-block-wrapper{position:relative}.hour-block{width:55px;height:70px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;display:flex;flex-direction:column;justify-content:center;align-items:center;cursor:pointer;transition:all .2s}.hour-block.prev-day,.hour-block.next-day{opacity:.6;background:var(--bg-secondary);border-style:dashed}.hour-block.prev-day:before,.hour-block.next-day:before{content:"";position:absolute;top:-12px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--text-secondary);font-weight:700}.hour-block.prev-day:first-of-type:before{content:"PREV";left:0;transform:none}.hour-block.next-day:first-of-type:before{content:"NEXT";left:0;transform:none}.hour-block:hover{transform:translateY(-2px);box-shadow:0 2px 4px #0000004d}.hour-block.available{background:var(--accent-green);border-color:var(--accent-green);color:var(--bg-primary)}.hour-block.unavailable{background:var(--accent-red);border-color:var(--accent-red);color:#fff}.hour-block.game-available{background:var(--accent-green);border-color:var(--accent-green);box-shadow:0 0 8px #57fa5766;color:#fff}.hour-block.game-unavailable{background:var(--accent-red);border-color:var(--accent-red);opacity:.8;color:#fff}.hour-block.current-hour{border:2px solid var(--accent-blue);box-shadow:0 0 0 2px #60a5fa4d}.hour-block.selecting-available{background:var(--accent-green)!important;border-color:var(--accent-green)!important;opacity:.7;transform:scale(1.05)}.hour-block.selecting-unavailable{background:var(--accent-red)!important;border-color:var(--accent-red)!important;opacity:.7;transform:scale(1.05)}.hour-block.selecting-clear{background:var(--bg-tertiary)!important;border-color:var(--border-color)!important;opacity:.5;transform:scale(.95)}.hours-row{-webkit-user-select:none;user-select:none}.hour-number{font-size:1.2rem;font-weight:600;line-height:1}.hour-period{font-size:.65rem;opacity:.8;margin-top:.1rem}.day-marker{position:absolute;top:-18px;left:0;font-size:.65rem;color:var(--accent-gold);font-weight:600;white-space:nowrap;z-index:1}.date-marker{opacity:.7;margin-left:.3rem;font-weight:400}.timezone-selector{display:flex;gap:.5rem;align-items:center;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color);flex-wrap:wrap}.custom-label-input{padding:.4rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);min-width:150px;font-size:.9rem}.timezone-select{flex:1;min-width:250px;padding:.4rem;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-size:.9rem}.add-timezone-btn{padding:.4rem .8rem;border-radius:4px;border:1px solid var(--accent-blue);background:var(--bg-tertiary);color:var(--accent-blue);cursor:pointer;font-weight:600;font-size:.9rem;transition:all .2s}.add-timezone-btn:hover:not(:disabled){background:var(--accent-blue);color:#fff}.add-timezone-btn:disabled{opacity:.5;cursor:not-allowed}.auth-modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.auth-modal{background:linear-gradient(135deg,#1a0033,#2d0040);border:2px solid #ffd700;border-radius:16px;padding:0;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #ffd7004d}.auth-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #ffd700}.auth-modal-header h3{margin:0;color:gold;font-size:1.5rem}.close-modal-btn{background:none;border:none;color:gold;font-size:2rem;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-modal-btn:hover{background:#ffd7001a;transform:scale(1.1)}.auth-modal-content{padding:1.5rem}.auth-modal-content p{color:#e6e6fa;margin-bottom:1rem;line-height:1.5}.auth-email-input{width:100%;padding:.75rem;border:2px solid #4b0082;border-radius:8px;background:#4b00821a;color:#e6e6fa;font-size:1rem;margin-bottom:1rem;box-sizing:border-box;transition:border-color .2s ease}.auth-email-input:focus{outline:none;border-color:gold;background:#ffd7000d}.auth-email-input::placeholder{color:#9370db}.auth-login-btn{background:linear-gradient(135deg,indigo,#639);border:2px solid #ffd700;color:gold;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:700;width:100%;transition:all .2s ease}.auth-login-btn:hover:not(:disabled){background:linear-gradient(135deg,#6a0d83,#7a3d9a);transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.auth-login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-message{margin-top:1rem;padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center}.auth-message.success{background:#00800033;border:1px solid #00ff00;color:#90ee90}.auth-message.error{background:#dc143c33;border:1px solid #ff6b6b;color:#f99}.game-share-info{margin-top:1.5rem;padding:1rem;background:#ffd7001a;border:1px solid #ffd700;border-radius:8px}.game-share-info h4{margin:0 0 1rem;color:gold}.share-code-display{margin-bottom:1rem}.share-code-display label{display:block;color:#e6e6fa;margin-bottom:.5rem;font-weight:700}.share-code-value{display:flex;align-items:center;gap:.5rem}.share-code-value code{background:#4b00824d;color:gold;padding:.5rem;border-radius:4px;font-family:Courier New,monospace;font-size:1.2rem;font-weight:700;letter-spacing:2px;flex:1}.copy-link-btn{background:indigo;border:1px solid #ffd700;color:gold;padding:.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:all .2s ease}.copy-link-btn:hover{background:#6a0d83;transform:scale(1.05)}.share-instructions{color:#e6e6fa;font-size:.9rem;line-height:1.4;margin:0}.share-instructions code{background:#4b00824d;color:gold;padding:.2rem .4rem;border-radius:4px;font-family:Courier New,monospace;word-break:break-all}.instructions{margin-top:1.5rem;background:var(--bg-secondary);border-radius:8px;padding:1.2rem;box-shadow:var(--shadow)}.instructions h3{color:var(--accent-gold);margin-bottom:.8rem;font-size:1.1rem}.instructions ol{margin-left:1.5rem;color:var(--text-secondary);font-size:.9rem}.instructions li{margin-bottom:.4rem;line-height:1.4}.front-page{min-height:100vh;background:linear-gradient(135deg,#1a0033,#2d0040)}.hero-section{padding:4rem 2rem;text-align:center;background:linear-gradient(135deg,#1a0033,#2d0040);border-bottom:2px solid var(--accent-gold)}.hero-content{max-width:800px;margin:0 auto}.hero-title{font-size:3rem;color:var(--accent-gold);margin-bottom:1rem}.hero-subtitle{font-size:1.5rem;color:var(--text-secondary);margin-bottom:2rem}.hero-description{font-size:1.1rem;color:var(--text-primary);margin-bottom:3rem;line-height:1.6}.hero-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta-register,.cta-login,.cta-demo{padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s ease;border:2px solid}.cta-register{background:linear-gradient(135deg,indigo,#639);border-color:var(--accent-gold);color:var(--accent-gold)}.cta-demo{background:linear-gradient(135deg,#06c,#0080ff);border-color:#6cf;color:#fff}.cta-login{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.cta-register:hover{background:linear-gradient(135deg,#6a0d83,#7a3d9a);transform:translateY(-2px);box-shadow:0 8px 20px #ffd7004d}.cta-demo:hover{background:linear-gradient(135deg,#0080ff,#0af);transform:translateY(-2px);box-shadow:0 8px 20px #66ccff4d}.cta-login:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.features-section{padding:4rem 2rem;background:var(--bg-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;max-width:1000px;margin:0 auto}.feature{text-align:center;padding:2rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature h3{color:var(--accent-gold);margin-bottom:1rem}.feature p{color:var(--text-secondary);line-height:1.5}.dm-dashboard{min-height:100vh;background:var(--bg-primary);padding:2rem}.dm-dashboard.loading{display:flex;align-items:center;justify-content:center}.loading-spinner{font-size:1.5rem;color:var(--text-secondary)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:3rem;padding-bottom:1rem;border-bottom:2px solid var(--accent-gold)}.dashboard-title h1{color:var(--accent-gold);margin:0}.dashboard-title p{color:var(--text-secondary);margin:.5rem 0 0}.dashboard-actions{display:flex;gap:1rem}.create-game-btn,.create-first-game-btn{background:linear-gradient(135deg,indigo,#639);border:2px solid var(--accent-gold);color:var(--accent-gold);padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-weight:700;transition:all .2s ease}.create-game-btn:hover,.create-first-game-btn:hover{background:linear-gradient(135deg,#6a0d83,#7a3d9a);transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:5rem;margin-bottom:2rem}.empty-state h2{color:var(--text-primary);margin-bottom:1rem}.empty-state p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem}.games-list{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:1rem}.game-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:1.5rem;transition:all .2s ease;width:100%}.game-card:hover{border-color:var(--accent-gold);transform:translateY(-2px);box-shadow:0 8px 20px #ffd7001a}.game-main{width:100%}.game-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:.75rem;flex-wrap:nowrap;min-width:0}.game-header h3{color:var(--accent-gold);margin:0;font-size:1.5rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0}.game-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;flex-shrink:0}.share-code{background:#ffd70026;color:var(--accent-gold);padding:.375rem .75rem;border-radius:6px;font-size:.875rem;font-family:SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-weight:500;border:1px solid rgba(255,215,0,.3);flex-shrink:0}.game-info{color:var(--text-secondary);display:flex;gap:1.5rem;align-items:center;font-size:.875rem;flex-wrap:wrap}.game-info p{margin:0;display:flex;align-items:center;gap:.375rem}.game-actions{display:flex;gap:.5rem;flex-shrink:0}.edit-game-btn,.share-game-btn,.delete-game-btn,.upload-logo-header-btn{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s ease;text-decoration:none;display:flex;align-items:center;gap:.25rem;white-space:nowrap}.edit-game-btn:hover{border-color:var(--accent-blue);background:#0064ff0d;color:var(--accent-blue)}.share-game-btn:hover{border-color:var(--accent-gold);background:#ffd7000d;color:var(--accent-gold)}.delete-game-btn:hover:not(:disabled){border-color:#ef4444;background:#ef44440d;color:#ef4444}.delete-game-btn:disabled{opacity:.6;cursor:not-allowed}.game-logo{margin:.75rem 0;text-align:center}.game-logo img{max-width:150px;max-height:80px;border-radius:8px;object-fit:cover;box-shadow:0 2px 8px #0000001a}.game-logo-upload{margin:.75rem 0}.logo-upload-input{display:none}.logo-upload-btn{display:inline-block;padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);cursor:pointer;font-size:.85rem;transition:all .2s ease;text-align:center}.logo-upload-btn:hover{background:var(--bg-primary);border-color:var(--accent-gold);color:var(--accent-gold)}.edit-game-btn,.share-game-btn{border-color:var(--accent-gold);background:var(--bg-primary)}.demo-schedule{min-height:100vh;background:var(--bg-primary)}.demo-header{background:linear-gradient(135deg,#06c,#0080ff);border-bottom:2px solid #66ccff;padding:1.5rem 2rem}.demo-header-content{max-width:1400px;margin:0 auto}.demo-info h1{color:#fff;margin:0}.demo-description{color:#e6f3ff;margin:.5rem 0 0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.demo-badge{background:#fff3;color:#fff;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:700;border:1px solid rgba(255,255,255,.3)}.demo-main{padding:2rem;max-width:1400px;margin:0 auto}.demo-instructions{background:linear-gradient(135deg,#0064c81a,#0078ff0d);border:1px solid #0066cc;border-radius:12px;padding:1.5rem;margin-top:2rem}.demo-instructions h3{color:#6cf;margin-top:0}.demo-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:1.5rem}.demo-feature{background:#0050a01a;border:1px solid rgba(102,204,255,.3);border-radius:8px;padding:1rem}.demo-feature strong{color:#6cf;display:block;margin-bottom:.5rem}.demo-feature ul{margin:0;padding-left:1.2rem;color:var(--text-secondary)}.demo-feature li{margin-bottom:.3rem;font-size:.9rem}.demo-notice{background:#0078ff1a;border:1px solid #66ccff;border-radius:8px;padding:1rem;text-align:center}.demo-notice p{margin:0;color:#e6f3ff}.game-schedule{min-height:100vh;background:var(--bg-primary)}.game-schedule.loading{display:flex;align-items:center;justify-content:center}.game-header{background:linear-gradient(135deg,#1a0033,#2d0040);border-bottom:2px solid var(--accent-gold);padding:1.5rem 2rem}.game-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.game-info h1{color:var(--accent-gold);margin:0;display:flex;align-items:center;gap:.5rem}.dm-logo-header{width:2rem;height:2rem;border-radius:6px;object-fit:cover;flex-shrink:0}.share-info{color:var(--text-secondary);margin:.5rem 0 0;display:flex;align-items:center;gap:.5rem}.share-info span{display:flex;align-items:center;gap:.5rem}.share-info code{background:var(--bg-secondary);padding:.25rem .5rem;border-radius:4px;color:var(--accent-gold);font-family:monospace}.share-link-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:.25rem .5rem;cursor:pointer;font-size:1rem;transition:all .2s ease}.share-link-btn:hover{background:var(--bg-secondary);transform:scale(1.1)}.back-btn,.copy-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary);padding:.5rem 1rem;border-radius:6px;cursor:pointer;margin-bottom:1rem;transition:all .2s ease}.back-btn:hover,.copy-btn:hover{border-color:var(--accent-blue);background:var(--bg-tertiary)}.save-status{color:var(--text-secondary);font-size:.9rem}.saving{color:var(--accent-gold)}@media(max-width:768px){.app-header h1{font-size:1.5rem}.controls-section,.dm-controls{flex-direction:column;align-items:stretch}.timezone-label-compact{width:120px;min-width:120px;padding:.8rem .5rem}.hour-block{width:40px;height:50px}.hour-number{font-size:.95rem}.schedule-header,.schedule-row{grid-template-columns:50px repeat(7,50px)}.hero-title{font-size:2rem}.hero-buttons{flex-direction:column;align-items:center}.features-grid{grid-template-columns:1fr}.dashboard-header{flex-direction:column;gap:1rem;text-align:center}.games-list{max-width:100%}}.modal-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.settings-modal{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;max-width:900px;width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 40px #00000080}.settings-header{background:linear-gradient(135deg,var(--accent-purple),#8b5cf6);border-bottom:2px solid var(--border-color);padding:1.5rem 2rem;display:flex;justify-content:space-between;align-items:center;border-radius:10px 10px 0 0}.settings-header h2{color:#fff;margin:0}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:0;width:2rem;height:2rem;border-radius:4px;transition:background-color .2s}.close-btn:hover{background:#ffffff1a}.settings-content{padding:2rem}.settings-section{margin-bottom:2rem}.settings-section h3{color:var(--accent-gold);margin-bottom:1rem}.profile-section{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{color:var(--text-primary);font-weight:700}.dm-name-input,.timezone-select{padding:.75rem;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary);font-size:1rem}.dm-name-input:focus,.timezone-select:focus{outline:none;border-color:var(--accent-purple)}.logo-upload{display:flex;flex-direction:column;gap:.5rem}.logo-input{padding:.5rem;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-secondary);color:var(--text-primary)}.logo-preview{max-width:80px;height:80px;border:2px solid var(--border-color);border-radius:8px;overflow:hidden}.logo-preview img{width:100%;height:100%;object-fit:cover}.schedule-help{color:var(--text-secondary);margin-bottom:1rem;font-size:.9rem}.schedule-grid{display:grid;grid-template-columns:80px repeat(7,1fr);gap:1px;background:var(--border-color);border-radius:6px;overflow:hidden}.schedule-header{display:contents}.schedule-header .time-label,.schedule-header .day-header{background:var(--bg-tertiary);padding:.75rem .5rem;text-align:center;font-weight:700;color:var(--text-primary);font-size:.8rem}.schedule-row{display:contents}.time-label{background:var(--bg-tertiary);padding:.5rem;text-align:center;font-size:.75rem;color:var(--text-secondary);display:flex;align-items:center;justify-content:center}.schedule-slot{background:var(--bg-secondary);border:none;cursor:pointer;transition:all .2s ease;height:32px;position:relative}.schedule-slot.available{background:#22c55e}.schedule-slot.unavailable{background:#ef4444}.schedule-slot:hover{opacity:.8;transform:scale(.95)}.settings-footer{background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:1.5rem 2rem;display:flex;justify-content:flex-end;gap:1rem;border-radius:0 0 10px 10px}.cancel-btn,.save-btn{padding:.75rem 1.5rem;border-radius:6px;cursor:pointer;font-weight:700;transition:all .2s ease;border:2px solid}.cancel-btn{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.cancel-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.save-btn{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.save-btn:hover:not(:disabled){background:#8b5cf6;border-color:#8b5cf6}.save-btn:disabled{opacity:.6;cursor:not-allowed}.settings-btn{background:var(--accent-purple);border:2px solid var(--accent-purple);color:#fff;padding:.75rem 1.5rem;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s ease}.settings-btn:hover{background:#8b5cf6;border-color:#8b5cf6}@media(max-width:768px){.profile-section{grid-template-columns:1fr}.schedule-grid{font-size:.7rem}.schedule-slot{height:28px}}
