.admin-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf50,#45a049);padding:20px}.admin-login-box{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;padding:40px}.admin-login-header{text-align:center;margin-bottom:32px}.admin-login-header h1{font-size:2rem;color:#333;margin-bottom:8px}.admin-login-header p{font-size:1rem;color:#666}.admin-login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:.95rem;font-weight:600;color:#333}.form-group input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#4caf50}.error-message{padding:12px;background:#ffebee;border:1px solid #f44336;border-radius:8px;color:#c62828;font-size:.9rem;text-align:center}.login-button{padding:14px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:8px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:8px}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #4caf5066}.login-button:disabled{opacity:.6;cursor:not-allowed}.admin-login-footer{margin-top:24px;text-align:center}.back-button{background:none;border:none;color:#4caf50;font-size:.9rem;cursor:pointer;text-decoration:underline}.back-button:hover{color:#45a049}.admin-dashboard{min-height:100vh;background:#f5f7fa}.logout-button{padding:10px 20px;background:#fff3;border:2px solid white;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.logout-button:hover{background:#ffffff4d}.stats-section{margin-bottom:48px}.stats-section h2{font-size:1.5rem;color:#333;margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.stat-card{background:#fff;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #0000001f}.stat-card.highlight{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.stat-icon{font-size:3rem;width:70px;height:70px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:#4caf501a}.stat-card.highlight .stat-icon{background:#fff3}.stat-content{flex:1}.stat-content h3{font-size:.95rem;color:#666;margin:0 0 8px;font-weight:600}.stat-card.highlight .stat-content h3{color:#ffffffe6}.stat-number{font-size:2rem;font-weight:700;color:#333;margin:0}.stat-card.highlight .stat-number{color:#fff}.quick-actions{margin-top:48px}.quick-actions h2{font-size:1.5rem;color:#333;margin-bottom:24px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.action-button{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:24px;display:flex;flex-direction:column;align-items:center;gap:12px;cursor:pointer;transition:all .2s;font-size:1.05rem;font-weight:600;color:#333}.action-button:hover{transform:translateY(-4px);border-color:#4caf50;box-shadow:0 4px 16px #4caf5033;color:#4caf50}.action-icon{font-size:2.5rem}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #4CAF50;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.retry-button{padding:12px 24px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer}.retry-button:hover{background:#45a049}@media (min-width: 1200px){.stats-grid,.actions-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width: 768px) and (max-width: 1199px){.stats-grid,.actions-grid{grid-template-columns:repeat(3,1fr)}}.admin-management{min-height:100vh;background:#f5f7fa}.admin-header{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;padding:24px 0;box-shadow:0 2px 8px #0000001a}.admin-header-content{max-width:1400px;margin:0 auto;padding:0 24px;display:flex;justify-content:space-between;align-items:center}.admin-header h1{font-size:1.8rem;margin:0}.back-button{padding:10px 20px;background:#fff3;border:2px solid white;border-radius:8px;color:#fff;font-weight:600;cursor:pointer;transition:background .2s}.back-button:hover{background:#ffffff4d}.admin-main{max-width:1400px;margin:0 auto;padding:32px 24px}.tabs{display:flex;gap:8px;margin-bottom:24px}.tab{padding:12px 24px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.tab:hover{border-color:#4caf50;color:#4caf50}.tab.active{background:linear-gradient(135deg,#4caf50,#45a049);border-color:#4caf50;color:#fff}.actions-bar{display:flex;gap:12px;margin-bottom:24px;align-items:center}.search-input{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;width:300px;flex-shrink:0}.search-input:focus{outline:none;border-color:#4caf50}.filter-select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;width:180px;flex-shrink:0}.filter-select:focus{outline:none;border-color:#4caf50}.filter-select:disabled{background-color:#f5f5f5;cursor:not-allowed;opacity:.6}.create-button{padding:12px 24px;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:transform .2s;white-space:nowrap}.create-button:hover{transform:translateY(-2px)}.table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;min-height:400px}.data-table{width:100%;border-collapse:collapse;table-layout:fixed}.data-table thead{background:#f8f9fa}.data-table th{padding:16px;text-align:left;font-weight:700;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.data-table td{padding:16px;border-bottom:1px solid #f0f0f0;color:#555;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table tbody tr:hover{background:#f8f9fa}.data-table tbody tr:last-child td{border-bottom:none}.data-table th:last-child,.data-table td:last-child{width:180px;text-align:center}.btn-edit,.btn-delete,.btn-close,.btn-reopen{padding:6px 12px;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s;margin-right:8px}.btn-edit{background:#4caf50;color:#fff}.btn-edit:hover{opacity:.8}.btn-delete{background:#f44336;color:#fff}.btn-delete:hover{opacity:.8}.btn-close{background:#ff9800;color:#fff}.btn-close:hover{opacity:.8}.btn-reopen{background:#2196f3;color:#fff}.btn-reopen:hover{opacity:.8}.status-badge{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.status-active{background:#e8f5e9;color:#2e7d32}.status-closed{background:#ffebee;color:#c62828}.closed-theme{opacity:.6}.closed-theme:hover{opacity:.8}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:16px;padding:32px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h2{margin-top:0;margin-bottom:24px;color:#333}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;color:#333;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#4caf50}.form-group select{cursor:pointer}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:32px}.btn-cancel,.btn-submit{padding:12px 24px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-cancel{background:#e0e0e0;color:#666}.btn-cancel:hover{opacity:.8}.btn-submit{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-submit:hover{opacity:.9}.loading{text-align:center;padding:40px;color:#666;font-size:1.1rem}.region-tree-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.region-group{border-bottom:1px solid #f0f0f0}.region-group:last-child{border-bottom:none}.region-row{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;transition:background .2s}.region-row:hover{background:#f8f9fa}.region-row.large-region{background:#fafafa;border-left:4px solid #4CAF50;font-weight:600}.region-row.small-region{padding-left:60px;background:#fff;border-left:4px solid transparent;font-weight:400}.region-info{display:flex;align-items:center;gap:12px;flex:1}.expand-button{background:none;border:none;font-size:1rem;color:#4caf50;cursor:pointer;padding:4px 8px;transition:transform .2s;width:24px;text-align:center}.expand-button:hover{transform:scale(1.2)}.region-name{font-size:1rem;color:#333}.region-row.large-region .region-name{font-size:1.1rem;font-weight:700}.region-count{font-size:.9rem;color:#999;font-weight:400}.region-actions{display:flex;gap:8px;align-items:center}.btn-add-small{padding:6px 12px;background:#2196f3;color:#fff;border:none;border-radius:6px;font-size:.85rem;font-weight:600;cursor:pointer;transition:opacity .2s}.btn-add-small:hover{opacity:.8}.small-regions{background:#fcfcfc}.empty-message{padding:20px 20px 20px 60px;color:#999;font-style:italic;background:#fcfcfc}.pagination{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:24px;border-top:1px solid #f0f0f0;flex-wrap:wrap}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:12px;flex:1}.pagination-btn{padding:8px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.pagination-btn:hover:not(:disabled){border-color:#4caf50;color:#4caf50;background:#f0f9f0}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-numbers{display:flex;gap:4px;flex-wrap:wrap}.pagination-number{min-width:36px;height:36px;padding:0 8px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;font-weight:600;cursor:pointer;transition:all .2s;color:#666}.pagination-number:hover{border-color:#4caf50;color:#4caf50;background:#f0f9f0}.pagination-number.active{background:linear-gradient(135deg,#4caf50,#45a049);border-color:#4caf50;color:#fff}.pagination-ellipsis{min-width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:#999;font-weight:600;padding:0 8px}.pagination-info{display:flex;align-items:center;gap:12px}.items-per-page{padding:8px 12px;border:2px solid #e0e0e0;border-radius:6px;background:#fff;font-weight:600;cursor:pointer;color:#666}.items-per-page:focus{outline:none;border-color:#4caf50}.total-count{font-weight:600;color:#666;white-space:nowrap}@media (max-width: 768px){.actions-bar{flex-direction:column;align-items:stretch}.filter-select{width:100%}.table-container{overflow-x:auto}.data-table{min-width:800px}.region-row{flex-direction:column;align-items:flex-start;gap:12px}.region-actions{width:100%;justify-content:flex-end}.pagination{flex-direction:column;gap:16px}.pagination-info{margin-left:0;width:100%;justify-content:space-between}.pagination-numbers{justify-content:center}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:#f5f5f5}.app{min-height:100vh}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:100}.nav-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;position:relative}.nav-logo{font-size:1.5rem;font-weight:700;color:#333;text-decoration:none}.hamburger-btn{display:none;flex-direction:column;gap:4px;background:none;border:none;cursor:pointer;padding:.5rem;z-index:101}.hamburger-btn span{width:25px;height:3px;background:#333;border-radius:2px;transition:all .3s}.nav-menu{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#666;text-decoration:none;font-weight:500;transition:color .2s;position:relative}.nav-link:hover{color:#333}.user-menu{display:flex;align-items:center;gap:1rem}.logout-btn,.login-btn{padding:.5rem 1rem;background:#ff6b6b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem}.login-btn{background:#4caf50}@media (max-width: 768px){.hamburger-btn{display:flex}.nav-menu.with-user{position:fixed;top:0;right:-100%;width:70%;max-width:300px;height:100vh;background:#fff;flex-direction:column;align-items:flex-start;gap:0;padding:5rem 2rem 2rem;box-shadow:-2px 0 10px #0000001a;transition:right .3s ease}.nav-menu.with-user.open{right:0}.nav-menu.with-user .nav-link{width:100%;padding:1rem 0;border-bottom:1px solid #f0f0f0}.nav-menu.with-user .user-menu{width:100%;flex-direction:column;align-items:flex-start;gap:0;margin-top:1rem;padding-top:1rem;border-top:2px solid #f0f0f0}.nav-menu.with-user .user-menu .nav-link{border-bottom:1px solid #f0f0f0}.nav-menu.with-user .logout-btn{width:100%;margin-top:.5rem;text-align:center}.nav-menu.with-user .notification-link{position:relative;display:inline-flex;align-items:center;gap:.5rem}.nav-menu.with-user .notification-badge{position:static;margin-left:.5rem}}.container{max-width:1200px;margin:0 auto;padding:2rem}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h1{font-size:2rem;color:#333}.filter-buttons button,.tab-buttons button{padding:.5rem 1rem;margin-left:.5rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s}.filter-buttons button.active,.tab-buttons button.active{background:#4caf50;color:#fff;border-color:#4caf50}.my-events-header{margin-bottom:2rem}.my-events-header h1{font-size:2rem;color:#333;margin-bottom:1.5rem}.tab-buttons{margin-bottom:2rem}.tab-buttons button{margin-left:0;margin-right:.5rem}.events-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.event-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;position:relative}.event-status,.detail-status{position:absolute;top:1rem;right:1rem;padding:.25rem .75rem;background:#4caf50;color:#fff;border-radius:12px;font-size:.8rem}.event-card h3{margin-bottom:.5rem;color:#333}.theme-name{color:#666;font-weight:500;margin-bottom:.5rem}.location,.datetime{color:#999;font-size:.9rem;margin-bottom:.5rem}.participants{margin:1rem 0;color:#666;font-weight:500}.organizer{margin:1rem 0;color:#666;font-size:.9rem}.event-actions,.detail-actions,.form-actions{display:flex;gap:.5rem;margin-top:1rem}.event-actions button,.detail-actions button,.form-actions button{flex:1;padding:.75rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;transition:all .2s}.event-actions button:first-child,.form-actions button:first-child{background:#f0f0f0;color:#333}.join-btn,.submit-btn{background:#4caf50!important;color:#fff!important}.leave-btn,.delete-btn{background:#ff6b6b!important;color:#fff!important}.close-btn{background:#ff9800!important;color:#fff!important}button:hover{opacity:.9}.no-events{text-align:center;color:#999;padding:3rem;grid-column:1 / -1}.event-detail{background:#fff;border-radius:8px;padding:2rem;max-width:800px;margin:0 auto}.detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.back-btn{padding:.5rem 1rem;background:#f0f0f0;border:none;border-radius:4px;cursor:pointer}.event-detail h1{margin-bottom:2rem;color:#333}.detail-info{margin-bottom:2rem}.info-row{display:flex;align-items:center;padding:1rem 0;border-bottom:1px solid #f0f0f0}.info-row strong{width:120px;color:#666}.detail-description{margin:2rem 0;padding:1.5rem;background:#f9f9f9;border-radius:8px}.detail-description h3{margin-bottom:1rem;color:#333}.form-container{background:#fff;border-radius:8px;padding:2rem;max-width:600px;margin:0 auto}.form-container h1{margin-bottom:2rem;color:#333}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#666;font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background-color:#fff}.form-group textarea{resize:vertical;font-family:inherit}.theme-selection-section{background:#f9f9f9;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.section-label{display:block;margin-bottom:1rem;color:#333;font-weight:600;font-size:1.1rem}.field-note{color:#666;font-size:.9rem;margin-bottom:1.5rem;line-height:1.5}.multi-theme-item-readonly{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1rem;margin-bottom:1rem}.multi-theme-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.5rem}.multi-theme-info{flex:1}.theme-name-readonly{font-size:1rem;font-weight:600;color:#333;margin-bottom:.25rem}.theme-details-readonly{font-size:.875rem;color:#666}.readonly-field{background:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1rem}.readonly-field .theme-name{font-size:1rem;font-weight:600;color:#333;margin-bottom:.5rem}.readonly-field .theme-details{font-size:.875rem;color:#666}.mobile-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem}.login-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px)}.login-box{background:#fff;border-radius:8px;padding:3rem;text-align:center;box-shadow:0 4px 6px #0000001a}.login-box h1{margin-bottom:1rem;color:#333}.login-box p{margin-bottom:2rem;color:#666}.kakao-login-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 2rem;background:#fee500;color:#3c1e1e;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.kakao-login-btn:hover{background:#fdd835}.kakao-login-btn svg{width:20px;height:20px}.complete-profile-container{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 200px);padding:2rem}.complete-profile-card{background:#fff;border-radius:8px;padding:3rem;max-width:500px;width:100%;box-shadow:0 4px 6px #0000001a}.complete-profile-card h2{margin-bottom:.5rem;color:#333;text-align:center}.complete-profile-card .subtitle{margin-bottom:2rem;color:#666;text-align:center;font-size:.9rem}.complete-profile-card .submit-btn{width:100%;margin-top:1rem;padding:.75rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.complete-profile-card .submit-btn:hover:not(:disabled){background:#45a049}.complete-profile-card .submit-btn:disabled{background:#ccc;cursor:not-allowed}.error-message{padding:.75rem;background:#ffebee;color:#c62828;border-radius:4px;margin-bottom:1rem;font-size:.9rem}@media (max-width: 768px){.nav-container{padding:1rem}.nav-logo{font-size:1.2rem}.nav-menu{gap:.75rem}.nav-link{font-size:.9rem}.logout-btn,.login-btn{padding:.4rem .8rem;font-size:.85rem}.container{padding:.75rem}.header{flex-direction:column;align-items:flex-start;gap:1rem}.header h1{font-size:1.5rem}.my-events-header h1{font-size:1.5rem;margin-bottom:1rem}.filter-buttons{width:100%;display:flex;flex-wrap:wrap}.filter-buttons button,.tab-buttons button{flex:1;margin:.25rem;padding:.6rem;font-size:.85rem}.tab-buttons{width:100%}.events-grid{grid-template-columns:1fr;gap:1rem}.event-card{padding:1rem}.event-card h3{font-size:1.1rem;padding-right:80px}.event-detail{padding:1.5rem}.event-detail h1{font-size:1.5rem}.info-row{flex-direction:column;align-items:flex-start;gap:.25rem;padding:.75rem 0}.info-row strong{width:100%}.detail-actions{flex-direction:column}.detail-actions button{width:100%}.form-container{padding:1.5rem 1rem}.form-container h1{font-size:1.5rem}.form-group label{font-size:.95rem}.form-group input,.form-group textarea,.form-group select{font-size:16px;padding:.875rem}.theme-selection-section{padding:1rem}.section-label{font-size:1rem}.form-actions{flex-direction:column}.form-actions button{width:100%}.login-box{padding:2rem 1.5rem;margin:1rem}.login-box h1{font-size:1.5rem}.complete-profile-card{padding:2rem 1.5rem;margin:1rem}}@media (max-width: 480px){.nav-container{padding:.75rem}.nav-logo{font-size:1.1rem}.nav-menu{gap:.5rem}.nav-link{font-size:.85rem}.logout-btn,.login-btn{padding:.35rem .7rem;font-size:.8rem}.container{padding:.75rem}.header h1{font-size:1.3rem}.event-card{padding:.875rem}.event-status,.detail-status{font-size:.75rem;padding:.2rem .6rem}.form-container,.event-detail{padding:1rem}.form-container h1,.event-detail h1{font-size:1.3rem}.theme-selection-section{padding:.875rem}}.notification-link{position:relative}.notification-badge{position:absolute;top:-8px;right:-10px;background:#ff6b6b;color:#fff;font-size:.7rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.notifications-container{max-width:800px;margin:0 auto;background:#fff;border-radius:8px;padding:2rem}.notifications-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.notifications-header h1{margin:0;color:#333}.mark-all-read-btn{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.mark-all-read-btn:hover{background:#45a049}.notifications-actions{display:flex;gap:.5rem}.delete-all-btn{padding:.5rem 1rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.delete-all-btn:hover{background:#da190b}.no-notifications{text-align:center;padding:3rem;color:#999}.notifications-list{display:flex;flex-direction:column;gap:.5rem}.notification-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f9f9f9;border-radius:8px;cursor:pointer;transition:all .2s;position:relative}.notification-item:hover{background:#f0f0f0}.notification-item.unread{background:#e3f2fd;border-left:4px solid #2196F3}.notification-icon{font-size:1.5rem}.notification-content{flex:1}.notification-message{color:#333;font-weight:500;margin-bottom:.25rem}.notification-meta{display:flex;gap:1rem;font-size:.85rem;color:#666}.notification-event{font-weight:500}.notification-time{color:#999}.unread-indicator{width:8px;height:8px;background:#2196f3;border-radius:50%;position:absolute;right:1rem}.delete-notification-btn{width:28px;height:28px;padding:0;background:transparent;border:none;color:#999;font-size:1.5rem;line-height:1;cursor:pointer;transition:all .2s;border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.delete-notification-btn:hover{background:#ffebee;color:#f44336}.participants-management{margin:2rem 0;padding:1.5rem;background:#f9f9f9;border-radius:8px}.participants-management h3{margin-bottom:1.5rem;color:#333}.participants-display{margin:2rem 0;padding:1.5rem;background:#f9f9f9;border-radius:8px}.participants-display h3{margin-bottom:1rem;color:#333;font-size:1.1rem}.participants-grid{display:flex;flex-wrap:wrap;gap:.75rem}.participant-chip{padding:.75rem 1rem .75rem .75rem;background:#fff;color:#333;border-radius:12px;font-size:.9rem;font-weight:500;box-shadow:0 2px 4px #00000014;border-left:4px solid #4CAF50;position:relative}.participants-list{display:flex;flex-direction:column;gap:1.5rem}.participant-section h4{margin-bottom:1rem;color:#666;font-size:.9rem;font-weight:600}.participant-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#fff;border-radius:6px;border-left:4px solid transparent}.participant-item.pending{border-left-color:#ff9800}.participant-item.confirmed{border-left-color:#4caf50}.participant-item.rejected{border-left-color:#f44336;opacity:.7}.participant-info{display:flex;align-items:center;gap:1rem}.participant-name{font-weight:500;color:#333}.participant-time{font-size:.85rem;color:#999}.participant-badge{font-size:.85rem;padding:.25rem .75rem;border-radius:12px;background:#e0e0e0;color:#666}.participant-item.confirmed .participant-badge{background:#c8e6c9;color:#2e7d32}.participant-item.rejected .participant-badge{background:#ffcdd2;color:#c62828}.participant-actions{display:flex;gap:.5rem}.approve-btn,.reject-btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.approve-btn{background:#4caf50;color:#fff}.approve-btn:hover{background:#45a049}.reject-btn{background:#f44336;color:#fff}.reject-btn:hover{background:#da190b}@media (hover: none) and (pointer: coarse){button,.nav-link,select,input{min-height:44px}.event-card{cursor:pointer}}@media (max-width: 768px){.notifications-container{padding:1rem}.notifications-header{flex-direction:column;align-items:flex-start;gap:1rem}.notifications-actions{width:100%;display:flex;gap:.5rem}.mark-all-read-btn,.delete-all-btn{flex:1}.notification-item{padding:.75rem}.notification-meta{flex-direction:column;gap:.25rem}.participants-management,.participants-display{padding:1rem}.participant-item{flex-direction:column;align-items:flex-start;gap:1rem}.participant-actions{width:100%}.approve-btn,.reject-btn{flex:1}.participants-grid{gap:.5rem}.participant-chip{font-size:.85rem;padding:.6rem .8rem}.participant-chip .participant-themes-inline{margin-top:.4rem;padding:.4rem}.participant-chip .participant-theme-badge-detail{font-size:.7rem;padding:.25rem .5rem}.participant-themes-simple{margin-top:.4rem;padding-top:.4rem;gap:.3rem}.participant-theme-badge-simple{font-size:.7rem;padding:.25rem .5rem;max-width:150px}.participant-chip .played-count-badge-small{font-size:.7rem;padding:.1rem .35rem}}.calendar-page{max-width:800px;margin:0 auto}.calendar-header{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.calendar-header h1{font-size:1.5rem;margin-bottom:1.5rem;color:#333}.month-summary{display:flex;gap:1rem;margin-bottom:1.5rem}.summary-item{flex:1;background:#f8f9fa;padding:1rem;border-radius:8px;text-align:center}.summary-label{display:block;font-size:.9rem;color:#666;margin-bottom:.5rem}.summary-value{display:block;font-size:1.5rem;font-weight:700;color:#333}.summary-value.spending{color:#ff6b6b}.month-navigation{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.month-navigation button{background:#4caf50;color:#fff;border:none;border-radius:50%;width:40px;height:40px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.month-navigation button:hover{background:#45a049}.current-month{font-size:1.2rem;font-weight:700;color:#333}.today-btn{width:100%;padding:.75rem;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.today-btn:hover{background:#e9ecef}.calendar-grid{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:1.5rem}.weekday-header{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-bottom:1rem}.weekday{text-align:center;font-weight:700;color:#666;font-size:.9rem;padding:.5rem 0}.weekday.sun{color:#ff6b6b}.weekday.sat{color:#4caf50}.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem}.calendar-day{aspect-ratio:1;padding:.5rem;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60px}.calendar-day:not(.empty){border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.calendar-day:not(.empty):hover{background:#f8f9fa;border-color:#4caf50}.calendar-day.today{background:#e3f2fd;border-color:#2196f3}.calendar-day.selected{background:#4caf50;color:#fff;border-color:#4caf50}.calendar-day.selected .event-indicator{background:#fff;color:#4caf50}.calendar-day.has-events{font-weight:700}.day-number{font-size:1rem;margin-bottom:.25rem}.event-indicator{background:#ff6b6b;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.selected-date-events{background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.selected-date-events h3{font-size:1.2rem;color:#333;margin-bottom:1rem}.events-list{display:flex;flex-direction:column;gap:1rem}.event-item{display:flex;gap:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.event-item:hover{background:#e9ecef;border-color:#4caf50}.event-time{font-weight:700;color:#4caf50;font-size:1.1rem;min-width:80px}.event-details{flex:1}.event-title{font-weight:700;color:#333;margin-bottom:.25rem;font-size:1.1rem}.event-theme{color:#666;font-size:.9rem;margin-bottom:.25rem}.event-price{color:#ff6b6b;font-weight:700;font-size:.95rem}@media (max-width: 768px){.calendar-page{max-width:100%;padding:0}.calendar-header{padding:1rem;margin-bottom:1rem}.calendar-header h1{font-size:1.3rem;margin-bottom:1rem}.month-summary{flex-direction:column;gap:.5rem}.summary-item{padding:.75rem .5rem}.summary-label{font-size:.75rem}.summary-value{font-size:1.1rem}.current-month{font-size:1rem}.month-navigation button{width:35px;height:35px;font-size:1.3rem}.calendar-grid{padding:.75rem;margin-bottom:1rem}.weekday-header{gap:.25rem}.weekday{font-size:.75rem;padding:.25rem 0}.calendar-days{gap:.25rem}.calendar-day{min-height:45px;padding:.2rem}.day-number{font-size:.85rem}.event-indicator{width:20px;height:20px;font-size:.7rem}.selected-date-events{padding:1rem}.selected-date-events h3{font-size:1.1rem}.event-item{flex-direction:column;gap:.5rem;padding:.75rem}.event-time{min-width:auto;font-size:1rem}.event-title{font-size:1rem}.event-theme,.event-price{font-size:.85rem}}.records-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.record-card{background:#fff;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.record-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.record-card.simple h3{font-size:1.2rem;color:#333;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.record-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;gap:1rem}.record-header h3{font-size:1.3rem;color:#333;flex:1}.record-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;white-space:nowrap}.record-badge.success{background:#e8f5e9;color:#2e7d32}.record-badge.fail{background:#ffebee;color:#c62828}.record-info{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.record-memo{margin-top:.5rem;padding-top:.5rem;border-top:1px solid #eee}.record-memo p{margin-top:.25rem;color:#666;line-height:1.5}.record-actions{display:flex;gap:.5rem;margin-top:1rem}.record-actions button{flex:1;padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .2s}.record-actions button:hover{background:#45a049}.record-actions button.delete-btn{background:#f44336}.record-actions button.delete-btn:hover{background:#da190b}.no-records-placeholder{grid-column:1 / -1;text-align:center;padding:4rem 2rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.no-records-placeholder p{font-size:1.1rem;color:#333}.records-filter{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1.5rem;background:#f9f9f9;border-radius:8px;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:200px}.filter-group label{font-size:.9rem;font-weight:500;color:#666}.filter-select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background:#fff;cursor:pointer;transition:border-color .2s}.filter-select:hover{border-color:#4caf50}.filter-select:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.records-summary{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.summary-item{flex:1;min-width:200px;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:.5rem}.summary-label{font-size:.9rem;color:#666}.summary-value{font-size:1.8rem;font-weight:700;color:#333}.summary-value.highlight{color:#4caf50}.records-simple-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.record-simple-card{background:#fff;padding:1.25rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s;cursor:default}.record-simple-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.record-simple-name{font-size:1rem;font-weight:600;color:#333;margin-bottom:.5rem}.record-simple-info{font-size:.85rem;color:#666}.tree-controls{display:flex;gap:1rem;align-items:center;margin-bottom:1.5rem;padding:1rem;background:#f9f9f9;border-radius:8px;flex-wrap:wrap}.tree-control-btn{padding:.5rem 1rem;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.tree-control-btn:hover{background:#4caf50;color:#fff;border-color:#4caf50}.theme-tree{display:flex;flex-direction:column;gap:.5rem}.tree-large-region{background:#fff;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden}.tree-large-region-header{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#f5f5f5;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.tree-large-region-header:hover{background:#eee}.tree-toggle{font-size:.9rem;color:#666;width:20px;flex-shrink:0}.tree-region-name{flex:1;font-size:1.1rem;font-weight:600;color:#333}.tree-region-stats{font-size:.95rem;color:#4caf50;font-weight:500;background:#e8f5e9;padding:.25rem .75rem;border-radius:12px}.tree-small-regions{padding:.5rem 0;background:#fafafa}.tree-small-region{margin:0 .5rem .5rem;border:1px solid #e0e0e0;border-radius:6px;overflow:hidden;background:#fff}.tree-small-region-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f9f9f9;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.tree-small-region-header:hover{background:#f0f0f0}.tree-small-region-header .tree-region-name{font-size:1rem;font-weight:500}.tree-small-region-header .tree-region-stats{font-size:.85rem;padding:.2rem .6rem}.tree-stores{padding:.5rem;background:#fff}.tree-store{margin-bottom:.5rem;border:1px solid #e8e8e8;border-radius:6px;overflow:hidden;background:#fcfcfc}.tree-store:last-child{margin-bottom:0}.tree-store-header{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;background:#f5f5f5;cursor:pointer;transition:background .2s;-webkit-user-select:none;user-select:none}.tree-store-header:hover{background:#ececec}.tree-store-name{flex:1;font-size:.95rem;font-weight:500;color:#444}.tree-store-header .tree-region-stats{font-size:.8rem;padding:.15rem .5rem}.tree-themes{padding:.5rem;background:#fff}.tree-theme-item{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;margin-bottom:.5rem;border-radius:6px;border:1px solid #e0e0e0;transition:all .2s}.tree-theme-item:last-child{margin-bottom:0}.tree-theme-item.played{background:#f1f8f4;border-color:#4caf50}.tree-theme-item.unplayed{background:#fff;border-color:#e0e0e0}.tree-theme-item:hover{box-shadow:0 2px 4px #0000001a}.theme-check-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.tree-theme-item.played .theme-check-icon{color:#4caf50;font-weight:700}.tree-theme-item.unplayed .theme-check-icon{color:#ccc}.tree-theme-content{flex:1}.tree-theme-name{font-size:.95rem;font-weight:600;color:#333;margin-bottom:.25rem}.tree-theme-item.unplayed .tree-theme-name{color:#666}.tree-theme-info{font-size:.85rem;color:#666}.tree-theme-checkbox{display:flex;align-items:flex-start;gap:.75rem;padding:.75rem;margin-bottom:.5rem;border-radius:6px;border:1px solid #e0e0e0;transition:all .2s;cursor:pointer;background:#fff}.tree-theme-checkbox:last-child{margin-bottom:0}.tree-theme-checkbox:hover{background:#f9f9f9;border-color:#4caf50;box-shadow:0 2px 4px #0000000d}.tree-theme-checkbox.selected{background:#f1f8f4;border-color:#4caf50}.tree-theme-checkbox.already-played{background:#f5f5f5;border-color:#d0d0d0;opacity:.7;cursor:not-allowed}.tree-theme-checkbox.already-played:hover{background:#f5f5f5;border-color:#d0d0d0;box-shadow:none}.tree-theme-checkbox.already-played .tree-theme-name,.tree-theme-checkbox.already-played .tree-theme-info{color:#999}.tree-theme-checkbox input[type=checkbox]{width:18px;height:18px;margin-top:.15rem;cursor:pointer;flex-shrink:0}.tree-theme-checkbox input[type=checkbox]:disabled{cursor:not-allowed}.already-played-badge{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;background:#e0e0e0;color:#666;font-size:.75rem;border-radius:12px;font-weight:400}.played-count-badge{display:inline-block;margin-left:.5rem;padding:.2rem .6rem;background:#e8f5e9;color:#2e7d32;font-size:.85rem;border-radius:12px;font-weight:500}.played-count-badge-small{display:inline-block;margin-left:.4rem;padding:.15rem .45rem;background:#e8f5e9;color:#2e7d32;font-size:.75rem;border-radius:10px;font-weight:500}.record-form{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a;max-width:600px;margin:0 auto}.record-form h1{margin-bottom:1.5rem;color:#333}.record-form .form-group{margin-bottom:1.5rem}.record-form label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.record-form input,.record-form select,.record-form textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.record-form textarea{resize:vertical;min-height:100px}.checkbox-group{display:flex;align-items:center;gap:.5rem}.checkbox-group input[type=checkbox]{width:auto;cursor:pointer}.checkbox-group label{margin-bottom:0;cursor:pointer}.form-actions{display:flex;gap:1rem;margin-top:2rem}.form-actions button{flex:1;padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.form-actions button:hover{background:#45a049}.form-actions button[type=button]{background:#999}.form-actions button[type=button]:hover{background:#777}.create-btn{padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;transition:background .2s}.create-btn:hover{background:#45a049}.theme-selection-group{margin-bottom:1.5rem}.region-selects{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.theme-grid{display:grid;grid-template-columns:1fr;gap:.5rem;max-height:300px;overflow-y:auto;padding:1rem;border:1px solid #ddd;border-radius:4px;background:#f9f9f9}.theme-option{padding:1rem;background:#fff;border:2px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s}.theme-option:hover{border-color:#4caf50}.theme-option.selected{border-color:#4caf50;background:#e8f5e9}.theme-option h4{margin-bottom:.5rem;color:#333}.theme-option p{font-size:.9rem;color:#666;margin:.25rem 0}.theme-grid.simple{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.theme-option-simple{padding:1rem;background:#fff;border:2px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s;text-align:center}.theme-option-simple:hover{border-color:#4caf50;transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.theme-option-simple.selected{border-color:#4caf50;background:#e8f5e9}.theme-option-simple .theme-name{font-weight:600;font-size:1rem;color:#333;margin-bottom:.5rem}.theme-option-simple .theme-store{font-size:.85rem;color:#666}.no-played-themes{padding:2rem;text-align:center;background:#f9f9f9;border:1px solid #ddd;border-radius:4px;margin-top:1rem}.no-played-themes p{color:#666;margin:.5rem 0}.no-played-themes p:first-child{font-weight:600;color:#333}.bulk-theme-grid{display:grid;grid-template-columns:1fr;gap:.75rem;max-height:400px;overflow-y:auto;padding:1rem;border:1px solid #ddd;border-radius:4px;background:#f9f9f9}.bulk-theme-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border:2px solid #ddd;border-radius:4px;cursor:pointer;transition:all .2s}.bulk-theme-item:hover{border-color:#4caf50}.bulk-theme-item input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0}.bulk-theme-item input[type=checkbox]:checked{accent-color:#4CAF50}.bulk-theme-item .theme-info{flex:1}.bulk-theme-item .theme-info h4{margin:0 0 .25rem;color:#333;font-size:1rem}.bulk-theme-item .theme-info p{margin:0;color:#666;font-size:.9rem}.selected-themes-container{background:#f0f8ff;border:2px solid #4CAF50;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.selected-themes-container h3{margin:0 0 1rem;color:#333;font-size:1rem}.selected-themes-list{display:flex;flex-wrap:wrap;gap:.5rem}.selected-theme-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#fff;border:1px solid #4CAF50;border-radius:20px;font-size:.9rem;color:#333}.remove-chip-btn{background:none;border:none;color:#f44336;font-size:1.5rem;line-height:1;cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .2s}.remove-chip-btn:hover{background:#ffebee}.form-actions button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.form-actions button:disabled:hover{background:#ccc}.comments-section{background:#fff;padding:1.5rem;border-radius:8px;margin-top:2rem}.comments-section h3{margin-bottom:1rem;color:#333;font-size:1.2rem}.comments-list{margin-bottom:1.5rem}.no-comments{text-align:center;color:#999;padding:2rem;background:#f9f9f9;border-radius:4px}.comment-item{background:#f9f9f9;padding:1rem;border-radius:8px;margin-bottom:1rem;position:relative}.comment-item:last-child{margin-bottom:0}.comment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.comment-author{font-weight:700;color:#333;font-size:.95rem}.comment-time{color:#999;font-size:.85rem}.comment-content{color:#555;line-height:1.6;margin-bottom:.5rem;white-space:pre-wrap;word-break:break-word}.comment-delete-btn{background:none;border:none;color:#f44336;font-size:.85rem;cursor:pointer;padding:.25rem .5rem;transition:color .2s}.comment-delete-btn:hover{color:#d32f2f;text-decoration:underline}.comment-form{display:flex;flex-direction:column;gap:.75rem}.comment-form textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;font-family:inherit;resize:vertical;min-height:80px}.comment-form textarea:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.comment-form .submit-btn{align-self:flex-end;padding:.6rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:.95rem;cursor:pointer;transition:background .2s}.comment-form .submit-btn:hover{background:#45a049}@media (max-width: 768px){.comments-section{padding:1rem}.comment-header{flex-direction:column;align-items:flex-start;gap:.25rem}.comment-time{font-size:.8rem}.records-filter{padding:1rem;gap:.75rem}.filter-group{min-width:100%}.tree-controls{padding:.75rem;gap:.5rem}.tree-control-btn{font-size:.85rem;padding:.4rem .75rem}.tree-large-region-header,.tree-small-region-header,.tree-store-header{padding:.65rem .75rem}.tree-region-name{font-size:1rem}.tree-small-region-header .tree-region-name{font-size:.95rem}.tree-store-name{font-size:.9rem}.tree-region-stats{font-size:.85rem;padding:.2rem .5rem}.tree-store-header .tree-region-stats{font-size:.75rem;padding:.15rem .4rem}.tree-stores{padding:.4rem}.tree-theme-item{padding:.6rem;gap:.5rem}.theme-check-icon{width:20px;height:20px;font-size:1rem}.tree-theme-name{font-size:.9rem}.tree-theme-info{font-size:.8rem}.tree-theme-checkbox{padding:.6rem;gap:.5rem}.tree-theme-checkbox input[type=checkbox]{width:16px;height:16px}.already-played-badge{font-size:.7rem;padding:.1rem .4rem;margin-left:.35rem}.played-count-badge{font-size:.75rem;padding:.15rem .45rem;margin-left:.35rem}.played-count-badge-small{font-size:.7rem;padding:.1rem .35rem;margin-left:.3rem}}.schedule-options{margin-bottom:.75rem}.checkbox-label{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:16px;height:16px;margin:0 .5rem 0 0;cursor:pointer;flex-shrink:0}.schedule-tbd-note{padding:.75rem;background:#fff3cd;border:1px solid #ffc107;border-radius:4px;color:#856404;font-size:.9rem;line-height:1.5;margin-top:.5rem}.schedule-tbd{color:#ff9800;font-weight:500}button:disabled{opacity:.5;cursor:not-allowed}.search-container{display:flex;gap:.75rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem}.search-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.search-btn{padding:.75rem 1.5rem;background:#4caf50;color:#fff;border:none;border-radius:4px;font-size:.95rem;cursor:pointer;white-space:nowrap;transition:background .2s}.search-btn:hover:not(:disabled){background:#45a049}.search-btn:disabled{opacity:.6;cursor:not-allowed}.no-results{text-align:center;padding:2rem;color:#999;background:#f9f9f9;border-radius:4px;margin-top:1rem}.theme-region{font-size:.85rem;color:#666;margin-top:.25rem}.multi-theme-note{font-size:.9rem;color:#666;margin-top:.5rem;padding:.75rem;background:#f0f7ff;border-left:3px solid #2196F3;border-radius:4px}.theme-list-multi{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem;margin-top:1rem}.theme-option-card{padding:1rem;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s;background:#fff;position:relative}.theme-option-card:hover{border-color:#4caf50;box-shadow:0 2px 8px #0000001a}.theme-option-card.added{border-color:#4caf50;background:#f1f8f4}.theme-option-card .theme-name{font-weight:500;font-size:1rem;margin-bottom:.5rem;color:#333}.theme-option-card .theme-details{font-size:.85rem;color:#666}.added-badge{position:absolute;top:.5rem;right:.5rem;background:#4caf50;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.selected-themes-section{margin-top:2rem;padding:1.5rem;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0}.selected-themes-section h3{margin-top:0;margin-bottom:1rem;color:#333;font-size:1.1rem}.selected-themes-list{display:flex;flex-direction:column;gap:1rem}.selected-theme-item{display:flex;gap:1rem;align-items:flex-start;background:#fff;padding:1rem;border-radius:8px;border:1px solid #ddd;transition:box-shadow .2s}.selected-theme-item:hover{box-shadow:0 2px 8px #0000001a}.theme-order{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:60px}.order-number{font-size:1.5rem;font-weight:700;color:#4caf50;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#e8f5e9;border-radius:50%}.order-controls{display:flex;flex-direction:column;gap:.25rem}.order-btn{padding:.25rem .5rem;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:.75rem;transition:all .2s}.order-btn:hover:not(:disabled){background:#e0e0e0}.order-btn:disabled{opacity:.3;cursor:not-allowed}.theme-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.theme-name-display{font-weight:500;font-size:1rem;color:#333}.theme-store-display{font-size:.9rem;color:#666}.theme-time-input{margin-top:.5rem}.theme-time-input label{display:block;font-size:.85rem;color:#666;margin-bottom:.25rem}.theme-time-input input[type=datetime-local]{width:100%;max-width:300px;padding:.5rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.remove-theme-btn{padding:.5rem;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:background .2s}.remove-theme-btn:hover{background:#d32f2f}.badge-icon{font-size:1rem}.themes-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.theme-card{position:relative;display:flex;gap:1rem;background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:1.5rem;transition:all .3s}.theme-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.theme-order-badge{flex-shrink:0;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;font-size:1.5rem;font-weight:700;box-shadow:0 2px 8px #667eea4d}.theme-card-content{flex:1}.theme-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.theme-card-header h3{margin:0;font-size:1.3rem;color:#333}.theme-start-time{display:flex;align-items:center;gap:.5rem;padding:.4rem .8rem;background:#e8f5e9;color:#2e7d32;border-radius:16px;font-size:.9rem;font-weight:500}.theme-card-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.75rem}.detail-item{display:flex;gap:.5rem;font-size:.95rem}.detail-label{font-weight:600;color:#666;min-width:80px}.detail-item span:last-child{color:#333}@media (max-width: 768px){.theme-card{flex-direction:column;align-items:flex-start}.theme-order-badge{align-self:flex-start}.theme-card-header{flex-direction:column;align-items:flex-start;gap:.5rem}.theme-card-details{grid-template-columns:1fr}}.multi-theme-indicator{display:inline-block;padding:.4rem .8rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px;font-size:.85rem;font-weight:500;margin-bottom:.75rem}.theme-list-compact{margin:.5rem 0}.theme-name-compact{font-size:.9rem;color:#555;margin:.25rem 0;font-weight:500}.theme-more{font-size:.85rem;color:#888;font-style:italic;margin:.25rem 0}.required-mark{color:#f44336;font-weight:700;margin-left:.25rem}.time-disabled-note{font-size:.85rem;color:#999;margin-top:.5rem;font-style:italic}.theme-time-input input[type=datetime-local]:disabled{background:#f5f5f5;color:#999;cursor:not-allowed}.multi-theme-time-note{font-size:.9rem;color:#666;margin-top:.5rem;padding:.75rem;background:#fff3e0;border-left:3px solid #ff9800;border-radius:4px}.theme-time-input input.error{border-color:#f44336;background:#fff5f5}.time-error-message{font-size:.85rem;color:#f44336;margin-top:.5rem;padding:.5rem;background:#ffebee;border-left:3px solid #f44336;border-radius:4px;font-weight:500}.time-helper-message{font-size:.85rem;color:#1976d2;margin-top:.5rem;padding:.5rem;background:#e3f2fd;border-left:3px solid #1976d2;border-radius:4px;font-weight:500}.date-label{display:block;font-weight:500;margin-bottom:.5rem;margin-top:1rem;color:#333}.date-input{width:100%;max-width:300px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.95rem;transition:border-color .2s}.date-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.theme-time-input input[type=time]{width:100%;max-width:200px;padding:.75rem 1rem;font-size:1.1rem;border:2px solid #ddd;border-radius:6px;transition:all .2s;font-weight:500}.theme-time-input input[type=time]:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf5026}.theme-time-input input[type=time].error{border-color:#f44336;background:#fff5f5;border-width:2px}.theme-time-input input[type=time]{width:100%;max-width:160px;padding:.6rem .8rem;font-size:1rem;border:1.5px solid #ddd;border-radius:4px;transition:all .2s;font-weight:400}.theme-time-input input[type=time]:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 2px #4caf501a}.theme-time-input input[type=time].error{border-color:#f44336;background:#fff5f5;border-width:1.5px}.schedule-tbd-badge{background:#fff3e0!important;color:#f57c00!important;border:1px solid #ffb74d}.multi-theme-indicator{display:inline-block;padding:.4rem .8rem;background:#e8f5e9;color:#2e7d32;border:1px solid #4CAF50;border-radius:16px;font-size:.85rem;font-weight:500;margin-bottom:.75rem}.multi-theme-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;background:#e8f5e9;color:#2e7d32;border:1.5px solid #4CAF50;border-radius:16px;margin-bottom:1rem;font-weight:500;font-size:.85rem}.theme-order-badge{flex-shrink:0;width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:50%;font-size:1.5rem;font-weight:700;box-shadow:0 2px 8px #4caf504d}.theme-card:hover{border-color:#4caf50;box-shadow:0 4px 12px #4caf5026;transform:translateY(-2px)}.theme-order-badge{flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:50%;font-size:1.1rem;font-weight:700;box-shadow:0 2px 6px #4caf5040}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;padding:2rem;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0003}.modal-content h2{margin-top:0;margin-bottom:.5rem;color:#333;font-size:1.5rem}.modal-description{color:#666;margin-bottom:1.5rem;font-size:.95rem}.theme-selection-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.theme-selection-item{display:flex;align-items:flex-start;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease}.theme-selection-item:hover{border-color:#4caf50;background:#f9fef9}.theme-selection-item.selected{border-color:#4caf50;background:#f1f8f1}.theme-selection-item input[type=checkbox]{margin-right:.75rem;margin-top:.25rem;cursor:pointer;width:18px;height:18px;flex-shrink:0}.theme-selection-content{flex:1}.theme-selection-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.theme-selection-name{font-weight:600;color:#333;font-size:1rem}.theme-selection-details{display:flex;gap:1rem;color:#666;font-size:.9rem;flex-wrap:wrap}.theme-selection-details span{display:inline-block}.theme-selection-time{margin-top:.5rem;color:#4caf50;font-size:.85rem;font-weight:500}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.modal-actions button{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;border:none}.modal-actions .cancel-btn{background:#f5f5f5;color:#666}.modal-actions .cancel-btn:hover{background:#e0e0e0}.modal-actions .confirm-btn{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.modal-actions .confirm-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #4caf504d}.modal-actions .confirm-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.participant-chip{display:flex;flex-direction:column;gap:.5rem}.participant-chip-header{display:flex;align-items:center;gap:.5rem}.participant-chip .played-count-badge-small{background:#e8f5e9;color:#2e7d32}.participant-chip .participant-themes-inline{background:#f5f5f5;border:1px solid #e0e0e0;margin-top:.5rem;padding:.5rem}.participant-chip .themes-label{color:#666;font-size:.8rem}.participant-chip .participant-theme-badge-detail{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;font-size:.75rem;padding:.3rem .65rem;border-radius:12px}.participant-themes-simple{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e8e8e8}.participant-theme-badge-simple{display:inline-block;padding:.3rem .65rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:12px;font-size:.75rem;font-weight:600;box-shadow:0 1px 3px #4caf504d;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.participant-themes{display:flex;gap:.25rem;flex-wrap:wrap}.participant-theme-badge{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 .5rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:12px;font-size:.75rem;font-weight:700}.participant-info-content{display:flex;flex-direction:column;gap:.25rem}.participant-themes-inline{display:flex;flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.5rem;background:#f9fef9;border-radius:6px;border:1px solid #e8f5e9}.themes-label{font-size:.85rem;font-weight:600;color:#4caf50}.participant-themes-badges{display:flex;flex-wrap:wrap;gap:.5rem}.participant-theme-badge-detail{display:inline-flex;align-items:center;padding:.35rem .75rem;background:linear-gradient(135deg,#4caf50,#45a049);color:#fff;border-radius:16px;font-size:.8rem;font-weight:600;box-shadow:0 2px 4px #4caf5033;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.modal-content{padding:1.5rem;max-height:85vh}.modal-content h2{font-size:1.25rem}.theme-selection-item{padding:.875rem}.theme-selection-name{font-size:.95rem}.theme-selection-details{font-size:.85rem;gap:.75rem}.modal-actions{flex-direction:column}.modal-actions button{width:100%}.participant-info{flex-direction:column;align-items:flex-start;gap:.5rem}.participant-time{align-self:flex-start;font-size:.8rem}.participant-theme-badge-detail{font-size:.75rem;padding:.3rem .6rem;max-width:180px}}
