*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;line-height:1.6;color:#333}#app{width:100%;min-height:100vh}:root{--color-primary: #43a047;--color-primary-hover: #66bb6a;--color-accent: #81c784;--color-danger: #e74c3c;--color-success: #27ae60;--color-warning: #ffeb3b;--color-bg-primary: #ffffff;--color-bg-secondary: #e8f5e9;--color-bg-tertiary: #efefef;--color-text-primary: #1b5e20;--color-text-secondary: #555555;--color-text-tertiary: #999999;--color-text-light: #ffffff;--color-border: #c8e6c9;--color-border-light: #eeeeee;--color-input-bg: #ffffff;--color-input-border: #c8e6c9;--color-input-focus: #43a047;--color-card-bg: #ffffff;--color-card-shadow: rgba(0, 0, 0, .1);--color-shadow-light: rgba(0, 0, 0, .05);--gradient-primary: linear-gradient(135deg, #81c784 0%, #a5d6a7 100%);--gradient-light: linear-gradient(135deg, #e8f5e9 0%, #f1f8f6 100%);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}@media(prefers-color-scheme:dark){:root{--color-primary: #66bb6a;--color-primary-hover: #7ec876;--color-accent: #81c784;--color-danger: #ff6b6b;--color-success: #51cf66;--color-warning: #ffd93d;--color-bg-primary: #0a0e12;--color-bg-secondary: #1a1e24;--color-bg-tertiary: #2a2e36;--color-text-primary: #d8e0e8;--color-text-secondary: #b8c0c8;--color-text-tertiary: #888f99;--color-text-light: #e8f0f8;--color-border: #3a4048;--color-border-light: #2a2e36;--color-input-bg: #151a20;--color-input-border: #3a4048;--color-input-focus: #66bb6a;--color-card-bg: #1a1e24;--color-card-shadow: rgba(0, 0, 0, .8);--color-shadow-light: rgba(0, 0, 0, .4);--gradient-primary: linear-gradient(135deg, #0a0e12 0%, #151a20 100%);--gradient-light: linear-gradient(135deg, #0f1319 0%, #080a0e 100%)}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{margin:0;padding:0;background-color:var(--color-bg-primary);color:var(--color-text-primary);transition:background-color .3s ease,color .3s ease}body{min-height:100vh}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);margin-top:0;margin-bottom:.5rem;font-weight:600;line-height:1.2}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:var(--color-text-secondary);margin:0 0 1rem;line-height:1.6}a{font-weight:500;color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-hover);text-decoration:underline}a:visited{color:var(--color-accent)}#app{max-width:1600px;margin:0 auto;padding:2rem;min-height:100vh}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media(max-width:768px){.container{padding:0 .5rem}}.page-wrapper{min-height:100vh;background:var(--color-bg-primary)}.content-wrapper{max-width:1200px;margin:0 auto;padding:2rem 1rem}.section{margin-bottom:2rem}.section-header{margin-bottom:1.5rem}.section-header h2{margin:0;color:var(--color-text-primary);border-bottom:2px solid var(--color-border);padding-bottom:.75rem}@media(max-width:1024px){#app{padding:1.5rem}.content-wrapper{padding:1.5rem 1rem}h1{font-size:2rem}h2{font-size:1.75rem}}@media(max-width:768px){#app{padding:.5rem}.content-wrapper{padding:1rem .5rem}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media(max-width:480px){#app{padding:.5rem}.container{padding:0 .5rem}h1{font-size:1.5rem}h2{font-size:1.25rem}}.btn{display:inline-block;padding:.625rem 1.25rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-decoration:none;text-align:center}.btn:hover:not(:disabled){opacity:.9}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-success{background:var(--color-success);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-warning{background:var(--color-warning);color:#333}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}a.btn,a.btn:hover,a.btn:visited,a.btn:active{text-decoration:none}a.btn-primary,a.btn-primary:hover,a.btn-primary:visited,a.btn-primary:active,a.btn-success,a.btn-success:hover,a.btn-success:visited,a.btn-success:active,a.btn-danger,a.btn-danger:hover,a.btn-danger:visited,a.btn-danger:active{color:#fff}a.btn-warning,a.btn-warning:hover,a.btn-warning:visited,a.btn-warning:active{color:#333}a.btn-secondary,a.btn-secondary:hover,a.btn-secondary:visited,a.btn-secondary:active{color:var(--color-text-primary)}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-full{width:100%}.btn-lg{padding:.75rem 1.5rem;font-size:1.125rem}.btn-loading{position:relative;color:transparent;pointer-events:none}.btn-loading:after{content:"";position:absolute;width:16px;height:16px;top:50%;left:50%;margin-left:-8px;margin-top:-8px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .6s linear infinite}.card{background:var(--color-card-bg);border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000001a}.card-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.card-header h2,.card-header h3{margin:0;color:var(--color-text-primary)}.card-title{margin:0;color:var(--color-text-primary);font-size:1.25rem;font-weight:600}.card-body{color:var(--color-text-secondary)}.card-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);display:flex;gap:.5rem}.card-hover{transition:transform .2s,box-shadow .2s}.card-hover:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.card-clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.card-compact{padding:1rem}.card-bordered{border:1px solid var(--color-border)}.button-group{display:flex;gap:.75rem;align-items:center;margin-top:1rem}.user-info{margin-bottom:1rem}.user-info h4{margin:0 0 .5rem;color:var(--color-text-primary)}.user-info p{margin:.25rem 0;color:var(--color-text-secondary)}.user-actions{display:flex;gap:.5rem;flex-wrap:wrap}.badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-primary{background:#43a0471a;color:var(--color-primary)}.badge-success{background:#27ae601a;color:var(--color-success)}.badge-danger{background:#e74c3c1a;color:var(--color-danger)}.badge-warning{background:#f39c121a;color:#856404}.badge-status{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#43a0471a;color:var(--color-primary)}.table{width:100%;border-collapse:collapse;background:var(--color-card-bg);border-radius:8px;overflow:hidden}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--color-border)}.table th{background:var(--color-bg-secondary);font-weight:600;color:var(--color-text-primary)}.table tr:hover{background:var(--color-bg-secondary)}.table-striped tbody tr:nth-child(2n){background:var(--color-bg-secondary)}.table-bordered,.table-bordered th,.table-bordered td{border:1px solid var(--color-border)}.table-compact th,.table-compact td{padding:.5rem}.table-overflow{overflow-x:auto;margin:1rem 0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--color-card-bg);border-radius:8px;padding:2rem;max-width:600px;width:90%;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.modal-header h2{margin:0}.modal-close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--color-text-tertiary)}.modal-close-btn:hover{color:var(--color-text-primary)}.modal-body{margin-bottom:1.5rem}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--color-border)}.modal-wide{max-width:900px}.modal-full{max-width:95vw;max-height:95vh}.modal-content{background:var(--color-card-bg);border-radius:8px;max-width:800px;width:90%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-content .modal-header{flex-shrink:0}.modal-content .modal-header h2,.modal-content .modal-header h3{margin:0}.modal-title{color:var(--color-text-primary);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.modal-content .modal-body{flex:1;overflow-y:auto;margin-bottom:0;padding:1.5rem}.modal-content .modal-footer{flex-shrink:0;padding:1rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.terms-content{margin-bottom:1.5rem}.terms-info{background:var(--color-bg-secondary);padding:1rem;border-radius:4px;margin-bottom:1rem}.terms-info p{margin:.5rem 0;color:var(--color-text-primary)}.pdf-viewer{width:100%;height:500px;border:1px solid var(--color-border);border-radius:4px;background:#f9f9f9}.pdf-note{margin-top:.5rem;font-size:.875rem;color:var(--color-text-secondary);text-align:center}.mobile-pdf-view{text-align:center;padding:1.5rem;background:var(--color-bg-secondary);border-radius:6px;margin-bottom:1.5rem}.mobile-pdf-notice{margin-bottom:1.5rem}.mobile-pdf-notice p{margin:.5rem 0;color:var(--color-text-secondary)}.mobile-pdf-notice strong{color:var(--color-text-primary);font-size:1.1rem}.legal-content{margin-bottom:1.5rem}.legal-content h3{margin-bottom:1rem;color:var(--color-text-primary)}.legal-content .no-pdf{padding:2rem;text-align:center;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:4px}.accept-checkbox{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-bg-secondary);border-radius:4px;cursor:pointer;margin-bottom:1rem;-webkit-user-select:none;user-select:none}.accept-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0}.accept-checkbox span{font-size:1rem;color:var(--color-text-primary)}.accept-checkbox:hover{background:var(--color-bg-tertiary)}.acceptance-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.checkbox-label{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-bg-secondary);border-radius:4px;cursor:pointer;margin-bottom:1rem;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;flex-shrink:0}.checkbox-label span{font-size:1rem;color:var(--color-text-primary)}.checkbox-label:hover{background:var(--color-bg-tertiary)}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}@media(max-width:768px){.modal-content{width:95%;max-height:95vh}.pdf-viewer{height:400px}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.alert{padding:1rem;border-radius:4px;margin:1rem 0}.alert-success{background:#27ae601a;color:var(--color-success);border:1px solid var(--color-success)}.alert-danger{background:#e74c3c1a;color:var(--color-danger);border:1px solid var(--color-danger)}.alert-warning{background:#f39c121a;color:var(--color-warning);border:1px solid var(--color-warning)}.navbar{background:var(--color-card-bg);padding:1rem 2rem;box-shadow:0 2px 4px var(--color-card-shadow);display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--color-border)}.navbar-brand{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.navbar-menu{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.navbar-menu a{color:var(--color-text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.navbar-menu a:hover{color:var(--color-primary)}.navbar-item{color:var(--color-text-secondary);font-weight:500}.user-info{color:var(--color-text-primary);font-weight:600}.user-dashboard,.admin-dashboard,.vendor-dashboard{min-height:100vh;background:var(--gradient-primary)}.dashboard-content{padding:2rem;max-width:1200px;margin:0 auto}.dashboard-content h1{color:#fff;font-size:2rem;margin-bottom:2rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:2rem}.dashboard-card:hover{transform:translateY(-4px)}.card-icon{font-size:2.5rem;margin-bottom:1rem}@media(max-width:768px){.dashboard-content{padding:1rem .5rem}.dashboard-content h1{font-size:1.5rem;margin-bottom:1rem}.dashboard-grid{gap:1rem;grid-template-columns:1fr}}.warning-banner{background:#ffc1071a;color:var(--color-warning);padding:1rem;border-radius:4px;margin-bottom:2rem;border:1px solid var(--color-warning)}.filter-section{margin-bottom:2rem;padding:1rem;background:var(--color-card-bg);border-radius:8px}.filter-controls{display:flex;gap:1rem;align-items:end;flex-wrap:wrap}.filter-field{flex:1;min-width:200px}.filter-field label{display:block;margin-bottom:.5rem;font-weight:500}.date-input{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px}.filter-actions{display:flex;gap:.5rem;align-items:center}.card-with-image{overflow:hidden;padding:0}.card-image{width:100%;height:180px;overflow:hidden;background:var(--color-bg-secondary)}.card-image img{width:100%;height:100%;object-fit:cover}.card-with-image .card-content{padding:1.5rem}.vendor-name,.event-vendor{color:var(--color-text-secondary);font-size:.875rem;margin:0 0 .75rem}.introduction,.description{color:var(--color-text-secondary);margin:0 0 1rem;font-size:.875rem;line-height:1.5}.event-details,.vendor-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.event-details .detail,.vendor-details .detail{color:var(--color-text-secondary);font-size:.875rem}.load-more-container{text-align:center;margin-top:2rem}.event-info{background:var(--color-bg-secondary);padding:1rem;border-radius:6px;margin-bottom:1.5rem}.event-info h4{margin:0 0 .5rem;color:var(--color-text-primary)}.event-info p{margin:.25rem 0;color:var(--color-text-secondary)}.event-date{font-size:.875rem;color:var(--color-text-secondary)}.notes-input-container{margin-top:1.5rem}.notes-label{display:block;font-weight:600;margin-bottom:.5rem}.notes-textarea{width:100%;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;font-family:inherit;resize:vertical}.character-count{display:block;text-align:right;color:var(--color-text-tertiary);margin-top:.25rem;font-size:.875rem}.modal-content-wide{max-width:900px;max-height:80vh;overflow-y:auto}.table-overflow{overflow-x:auto}.table td.notes-column{max-width:250px;word-wrap:break-word}.loading-state,.loading,.empty-state,.error-state{padding:3rem 2rem;text-align:center;color:var(--color-text-secondary)}.spinner{width:40px;height:40px;border:4px solid var(--color-bg-secondary);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}@keyframes spin{to{transform:rotate(360deg)}}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.header h1,.header h2{margin:0;color:var(--color-text-primary)}.subtitle{color:var(--color-text-secondary);font-size:1rem;margin:.5rem 0 1rem}.instructions{background:var(--color-bg-secondary);padding:2rem;border-radius:8px;margin:2rem 0}.instructions h3{margin:0 0 1rem;color:var(--color-text-primary)}.instructions p,.instructions ul{color:var(--color-text-secondary);margin:.5rem 0}.instructions ul{padding-left:1.5rem}.load-more{text-align:center;margin:2rem 0;padding:1rem}.vendor-header,.term-header,.tc-viewer-header,.session-header,.picker-modal-header{margin-bottom:1.5rem}.vendor-header h2,.vendor-header h3,.term-header h2,.term-header h3,.tc-viewer-header h2,.tc-viewer-header h3,.session-header h2,.session-header h3,.picker-modal-header h2,.picker-modal-header h3{margin:0;color:var(--color-text-primary)}.list-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.pagination-controls{display:flex;align-items:center;gap:1rem}.page-info{color:var(--color-text-secondary);font-size:.95rem}.content-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:1.5rem}.cta-buttons{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center;margin-top:2rem}.login-container{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.login-card{background:var(--color-card-bg);border-radius:8px;padding:2rem;box-shadow:0 2px 8px var(--color-card-shadow);width:100%;max-width:450px}.login-card h1{margin-bottom:1.5rem;text-align:center;color:var(--color-text-primary)}.login-card p{text-align:center;margin-top:1rem;color:var(--color-text-secondary)}.login-card .error{color:var(--color-danger);text-align:center;margin-top:1rem}.register-container{min-height:80vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem}.register-card{background:var(--color-card-bg);border-radius:8px;padding:2rem;box-shadow:0 2px 8px var(--color-card-shadow);width:100%;max-width:500px}.register-card h1{margin-bottom:1.5rem;text-align:center;color:var(--color-text-primary)}.register-card p{text-align:center;margin-top:1rem;color:var(--color-text-secondary)}.register-card .error{color:var(--color-danger);text-align:center;margin-top:1rem}.register-card .required{color:var(--color-danger)}@media(max-width:768px){.card,.card-with-image .card-content{padding:.75rem}.card-footer{flex-direction:column}.btn-full-mobile{width:100%}.login-container{padding:1rem}.login-card{padding:1.5rem}}.form{width:100%}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:var(--color-text-primary);font-weight:500;font-size:.95rem}.form-group label .required{color:var(--color-danger);font-weight:700;margin-left:2px}.form-hint{display:block;margin-top:.25rem;color:var(--color-text-tertiary);font-size:.875rem}.form-wrapper{background:var(--color-card-bg);padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px var(--color-card-shadow);margin-bottom:1.5rem}.form-section{margin-bottom:1.5rem}.form-section:last-child{margin-bottom:0}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.input-group{display:flex;gap:.5rem}.input-group>*{flex:1}.form-control,.form-group input:not([type=checkbox]):not([type=radio]),.form-group select,.form-group textarea{width:100%;padding:.75rem;border:1px solid var(--color-input-border);border-radius:4px;font-size:1rem;background-color:var(--color-input-bg);color:var(--color-text-primary);transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit}.form-control:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-input-focus);box-shadow:0 0 0 3px #43a0471a}.form-control:disabled,.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7}.form-control::placeholder,.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-tertiary);opacity:.7}.form-textarea,.form-group textarea{min-height:100px;resize:vertical}.form-select,.form-group select{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='%23666' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem;cursor:pointer}.form-group input[type=checkbox],.form-group input[type=radio]{width:auto;margin-right:.5rem;cursor:pointer}.form-check{display:flex;align-items:center;margin-bottom:.5rem}.form-check label{margin-bottom:0;cursor:pointer}.form-control.is-invalid,.form-group input.is-invalid,.form-group select.is-invalid,.form-group textarea.is-invalid{border-color:var(--color-danger)}.form-control.is-valid,.form-group input.is-valid,.form-group select.is-valid,.form-group textarea.is-valid{border-color:var(--color-success)}.error-message{color:var(--color-danger);font-size:.875rem;margin-top:.25rem;display:block}.success-message{color:var(--color-success);font-size:.875rem;margin-top:.25rem;display:block}.search-wrapper{width:100%;max-width:500px}.search-input{width:100%;padding:.75rem;border:1px solid var(--color-input-border);border-radius:4px;font-size:1rem;background-color:var(--color-input-bg);color:var(--color-text-primary);transition:border-color .2s ease,box-shadow .2s ease;font-family:inherit}.search-input:focus{outline:none;border-color:var(--color-input-focus);box-shadow:0 0 0 3px #43a0471a}.search-input::placeholder{color:var(--color-text-tertiary);opacity:.7}.readonly-field{background-color:var(--color-bg-tertiary);cursor:not-allowed;opacity:.7;border:1px solid var(--color-input-border);padding:.75rem;border-radius:4px;width:100%;font-size:1rem;color:var(--color-text-primary)}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.search-section,.user-selector,.user-selector-section{margin:2rem 0;padding:1.5rem;background:var(--color-card-bg);border-radius:8px;box-shadow:0 2px 4px var(--color-card-shadow)}.search-result{margin:2rem 0;padding:1.5rem;background:var(--color-card-bg);border:2px solid var(--color-primary);border-radius:8px;box-shadow:0 2px 4px var(--color-card-shadow)}.search-result .user-info{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.search-form{display:flex;gap:.75rem;align-items:stretch}.search-form input{flex:1}.search-form button{flex-shrink:0;min-width:100px;max-width:150px}.status-filter{padding:.625rem 1.25rem;border:1px solid var(--color-input-border);border-radius:4px;font-size:1rem;background-color:var(--color-input-bg);color:var(--color-text-primary);cursor:pointer;transition:border-color .2s ease}.status-filter:focus{outline:none;border-color:var(--color-input-focus);box-shadow:0 0 0 3px #43a0471a}.field-hint{display:block;margin-top:.25rem;color:var(--color-text-tertiary);font-size:.875rem;font-style:italic}@media(max-width:768px){.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--color-border)}.page-header h1{margin:0;font-size:2rem;color:var(--color-text-primary)}.page-content{padding:2rem 0}.page-section{margin-bottom:2rem}.page-section h2{margin:0 0 1rem;font-size:1.5rem;color:var(--color-text-primary)}.hero{text-align:center;padding:4rem 2rem;background:var(--color-bg-secondary);border-radius:8px;margin-bottom:2rem}.hero h1{margin:0 0 1rem;font-size:2.5rem;color:var(--color-text-primary)}.hero p{font-size:1.25rem;color:var(--color-text-secondary);margin:0 0 2rem}.grid{display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.card-grid-sm{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.card-grid-lg{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2rem}.flex-container{display:flex;gap:1rem}.flex-row{display:flex;gap:1rem;align-items:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-item{background:var(--color-card-bg);padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.stat-label{display:block;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--color-text-primary);line-height:1}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-header{flex-direction:column;align-items:flex-start;gap:1rem}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.flex-container,.flex-row{flex-direction:column}.stats-grid{grid-template-columns:1fr}}@media(max-width:480px){.page-header h1,.stat-value{font-size:1.5rem}}.item-list,.data-list{display:flex;flex-direction:column;gap:.5rem}.item-list .list-item,.data-list .data-item{display:grid;grid-template-columns:1fr;gap:.75rem;padding:1rem;background:var(--color-card-bg);border:1px solid var(--color-border);border-radius:8px}.item-list .item-label,.data-list .item-label{display:inline-block;font-weight:600;margin-right:.5rem;color:var(--color-text-secondary)}.item-list .item-value,.data-list .item-value{display:inline}.item-list .primary-field,.data-list .primary-field{font-weight:600;color:var(--color-text-primary)}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.detail-row,.item-details{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.detail-row{flex-direction:row}.detail-row .detail-label{font-weight:600;color:var(--color-text-secondary)}.detail-row .detail-value{color:var(--color-text-primary)}.item-details{padding-top:.5rem;border-top:1px solid var(--color-border)}@media(min-width:768px){.item-list,.data-list{gap:0}.item-list .list-item,.data-list .data-item{border-radius:0;border-top:none}.item-list .list-item:first-child,.data-list .data-item:first-child{border-radius:8px 8px 0 0;border-top:1px solid var(--color-border)}.item-list .list-item:last-child,.data-list .data-item:last-child{border-radius:0 0 8px 8px}.item-list .item-label,.data-list .item-label{display:none}.action-buttons{margin-top:0;justify-content:flex-end}.item-details{grid-column:1 / -1;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;border-top:1px solid rgba(0,0,0,.05)}}.data-list-3col .data-item,.data-list-3col .list-item{grid-template-columns:1fr}@media(min-width:768px){.data-list-3col .data-item,.data-list-3col .list-item{grid-template-columns:2fr 1fr 1.5fr}}.data-list-4col .data-item,.data-list-4col .list-item{grid-template-columns:1fr}@media(min-width:768px){.data-list-4col .data-item,.data-list-4col .list-item{grid-template-columns:2fr 1.5fr 1fr 1.5fr}}.data-list-5col .data-item,.data-list-5col .list-item{grid-template-columns:1fr}@media(min-width:768px){.data-list-5col .data-item,.data-list-5col .list-item{grid-template-columns:2fr 1.5fr 1fr 1.5fr 2fr}}.data-list-6col .data-item,.data-list-6col .list-item{grid-template-columns:1fr}@media(min-width:768px){.data-list-6col .data-item,.data-list-6col .list-item{grid-template-columns:2fr 1.5fr 1.5fr 1fr 1.5fr 1.5fr}}.data-list-with-header:before{content:"";display:none}@media(min-width:768px){.data-list-with-header{position:relative}.data-list-with-header:before{content:"";display:grid;gap:1rem;padding:.75rem 1rem;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-bottom:2px solid var(--color-border);font-weight:600;border-radius:8px 8px 0 0;position:sticky;top:0;z-index:1}.data-list-with-header.data-list-6col:before{grid-template-columns:2fr 1.5fr 1.5fr 1fr 1.5fr 1.5fr}.data-list-with-header.data-list-5col:before{grid-template-columns:2fr 1.5fr 1fr 1.5fr 2fr}}.data-list-expandable .data-item,.data-list-expandable .list-item{grid-template-columns:1fr}.m-0{margin:0}.m-1{margin:.5rem}.m-2{margin:1rem}.m-3{margin:1.5rem}.m-4{margin:2rem}.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mx-auto{margin-left:auto;margin-right:auto}.my-2{margin-top:1rem;margin-bottom:1rem}.p-0{padding:0}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.px-2{padding-left:1rem;padding-right:1rem}.py-2{padding-top:1rem;padding-bottom:1rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.text-muted{color:var(--color-text-tertiary)}.text-bold{font-weight:700}.text-semibold{font-weight:600}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.banner{padding:1rem 1.5rem;border-radius:4px;margin-bottom:1rem;font-size:.95rem}.banner-error{background-color:#e74c3c1a;color:var(--color-danger);border-left:4px solid var(--color-danger)}.banner-success{background-color:#27ae601a;color:var(--color-success);border-left:4px solid var(--color-success)}.banner-warning{background-color:#ffeb3b1a;color:#856404;border-left:4px solid var(--color-warning)}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-grid{display:grid}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-center{align-items:center}.flex-start{align-items:flex-start}.flex-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.w-full{width:100%}.w-auto{width:auto}.h-full{height:100%}.min-h-screen{min-height:100vh}.border{border:1px solid var(--color-border)}.border-none{border:none}.rounded{border-radius:4px}.rounded-lg{border-radius:8px}.bg-primary{background-color:var(--color-primary)}.bg-secondary{background-color:var(--color-bg-secondary)}.bg-white{background-color:#fff}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.session-stage{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);padding:0;position:relative}.session-stage .session-header{background:var(--color-card-bg);box-shadow:0 2px 8px var(--color-card-shadow);border-bottom:1px solid var(--color-border);padding:15px 30px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:500;margin-bottom:0}.session-header .nav-left{flex:1}.session-header .title{flex:2;text-align:center;font-size:1.5rem;font-weight:600;color:var(--color-text-primary)}.session-header .session-tag{flex:1;text-align:right;font-size:.9rem;color:var(--color-text-secondary);background:var(--color-bg-tertiary);padding:5px 15px;border-radius:20px}.card-stage{position:relative;min-height:400px;background:linear-gradient(135deg,#fff9e6,#ffe5b4);border:2px dashed var(--color-border);border-radius:10px;margin:20px;padding:20px;overflow:hidden}.draggable-card{position:absolute;width:180px;cursor:grab;-webkit-user-select:none;user-select:none;touch-action:none;z-index:500;text-align:center;transition:filter .2s}.draggable-card:active{cursor:grabbing}.draggable-card .card-image{width:auto;height:auto;border-radius:12px;box-shadow:0 10px 20px #0000002e;pointer-events:none}.draggable-card .card-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#9cff9a,#faeac4);color:#222;font-weight:600;font-size:.9rem;padding:4px 10px;border-radius:20px;box-shadow:0 2px 6px #00000040;white-space:nowrap;pointer-events:none;transition:all .3s ease}.draggable-card:hover .card-label{background:linear-gradient(135deg,#a1c4fd,#c2e9fb);color:#111;transform:translate(-50%) scale(1.05)}.draggable-card .card-prompt{margin-top:6px;font-size:.8em;background:#e8f5e9;border-radius:8px;padding:4px 6px;color:#1b5e20;box-shadow:0 2px 4px #0000001a}.guidance{background:var(--color-card-bg);margin:20px;padding:30px;border-radius:10px;box-shadow:0 4px 12px var(--color-card-shadow)}.guidance h3{color:var(--color-text-primary);margin-bottom:20px;font-size:1.3rem}.qa{margin-bottom:30px}.qa-row{display:flex;gap:16px;align-items:flex-start}.qa-content{flex:1;display:flex;flex-direction:column;gap:8px}.card-picker{flex:0 0 160px;margin-top:10px}.q{background:var(--color-bg-tertiary);padding:20px;border-left:4px solid var(--color-primary);margin:15px 0;border-radius:5px;font-size:1.1rem;line-height:1.6;color:var(--color-text-primary)}.guidance textarea,.qa textarea{width:100%;min-height:200px;padding:15px;border:2px solid var(--color-input-border);border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;margin:15px 0;transition:border-color .2s;background:var(--color-input-bg);color:var(--color-text-primary)}.guidance textarea:focus,.qa textarea:focus{outline:none;border-color:var(--color-input-focus)}.rating-section{margin:20px 0;padding:20px;background:#fff9e6;border:2px solid #ffd700;border-radius:8px}.rating-section label{display:block;font-weight:600;color:var(--color-text-primary);margin-bottom:10px;font-size:1.05rem}.star-rating{display:flex;gap:8px;justify-content:flex-start}.star-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#ccc;transition:all .2s;padding:0;line-height:1}.star-btn.active{color:gold;transform:scale(1.1)}.star-btn:hover{transform:scale(1.2)}.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:15px}.log-area{margin-top:30px;padding-top:30px;border-top:2px solid var(--color-border)}.log-area h4{color:var(--color-text-secondary);margin-bottom:15px;font-size:1.1rem}.log{background:var(--color-bg-tertiary);padding:20px;border-radius:8px;max-height:400px;overflow-y:auto}.log-entry{margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--color-border)}.log-entry:last-child{border-bottom:none}.log-entry .log-question{font-weight:600;color:var(--color-primary);margin-bottom:8px}.log-entry .log-answer{color:var(--color-text-secondary);line-height:1.6;white-space:pre-wrap}.picker-modal,.premium-lock{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.premium-lock{background:#000000e6;z-index:2000}.picker-modal{padding:20px}.picker-modal-content,.premium-lock-content{background:var(--color-card-bg);border-radius:10px;box-shadow:0 10px 40px #0000004d}.picker-modal-content{width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column}.premium-lock-content{padding:40px;border-radius:15px;text-align:center;max-width:500px}.picker-modal-header{padding:20px 30px;border-bottom:2px solid var(--color-border);display:flex;align-items:center;gap:15px}.picker-modal-header strong{flex:1;font-size:1.2rem;color:var(--color-text-primary)}.view-mode-toolbar{display:flex;gap:10px}.picker-modal-body{flex:1;overflow:hidden;position:relative;padding:20px}.spread-pane{width:100%;height:100%;position:relative}.arc-container{width:100%;height:100%;position:relative;min-height:500px}.arc-container .back{position:absolute;width:100px;height:auto;cursor:pointer;transition:transform .3s ease,filter .3s ease}.arc-container .back:hover:not(.picked){transform:scale(1.2)}.arc-container .back.picked{filter:brightness(1.2) drop-shadow(0 8px 16px rgba(76,175,80,.6))}.grid-pane,.grid-fronts{width:100%;height:100%;max-height:70vh;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;padding:12px}.grid-pane img,.grid-fronts img,.grid-card{width:100%;height:auto;border-radius:8px;cursor:pointer;box-shadow:0 4px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease,outline-color .3s,filter .3s ease}.grid-pane img:hover,.grid-fronts img:hover,.grid-card:hover{transform:scale(1.05)}.grid-picked{outline:3px solid #4CAF50;outline-offset:-2px;box-shadow:0 0 16px #4caf5099;filter:brightness(1.15);z-index:100;position:relative}.toolbar{display:flex;flex-wrap:wrap;gap:10px;margin:20px 0}.premium-lock-content h2{color:var(--color-warning);margin-bottom:20px}.premium-lock-content p{color:var(--color-text-secondary);line-height:1.6;margin-bottom:25px}.premium-lock-content .btn{margin:0 10px}@media(prefers-color-scheme:dark){.session-stage{background:linear-gradient(135deg,#0a0e12,#1a1e24)}.card-stage{background:linear-gradient(135deg,#1a1e24,#2a2e36)}.rating-section{background:var(--color-bg-tertiary);border-color:#b8860b}.picker-modal{background:#000000e6}.draggable-card .card-label{background:linear-gradient(135deg,#66bb6a,#fdd835);color:#111}.draggable-card:hover .card-label{background:linear-gradient(135deg,#42a5f5,#26c6da);color:#fff}.draggable-card .card-prompt{background:var(--color-bg-tertiary);color:var(--color-success)}.grid-card{box-shadow:0 2px 4px #00000080}.grid-card:hover{box-shadow:0 4px 12px #000000b3}.grid-picked{box-shadow:0 4px 12px #66bb6a99}}@media(max-width:768px){.session-header{flex-direction:column;gap:10px;text-align:center}.session-header .nav-left,.session-header .title,.session-header .session-tag{flex:none;text-align:center}.card-stage{min-height:250px;margin:10px}.guidance{margin:10px;padding:12px}.draggable-card{width:140px}.grid-pane,.grid-fronts{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px}.log{height:200px}}@media(max-width:600px){.arc-container .back{width:60px}}@media(max-width:400px){.arc-container .back{width:40px}}*{box-sizing:border-box}body{display:flex;place-items:center;min-height:100vh}#app{width:100%}
