:root{font-family:Inter,system-ui,-apple-system,sans-serif;color:#111827;background:#f5f7fb}*{box-sizing:border-box}body{margin:0;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;touch-action:manipulation}html{-webkit-text-size-adjust:100%}.page{min-height:100vh;display:flex;flex-direction:column}.page main{flex:1}.topbar{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#0f172a;color:#fff}.brand{display:flex;align-items:center;gap:10px}.logo{height:72px}.logo.small{height:48px}.tabs button{margin-left:8px;padding:8px 12px;border:1px solid #1f2937;background:#111827;color:#fff;cursor:pointer;border-radius:6px}.tabs button.active{background:#2563eb;border-color:#2563eb}.btn-logout{margin-left:8px;padding:8px 12px;border:1px solid #dc2626;background:#dc2626;color:#fff;cursor:pointer;border-radius:6px;font-weight:600;transition:all .2s}.btn-logout:hover{background:#b91c1c;border-color:#b91c1c}main{max-width:1100px;margin:20px auto;padding:0 16px 32px;display:grid;gap:16px}main.public-main{max-width:600px;padding:20px 16px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:24px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;transition:box-shadow .3s ease}.card:hover{box-shadow:0 8px 30px #0000001f,0 2px 6px #00000014}.public-form-card{padding:40px 32px}.public-form-header{text-align:center;margin-bottom:32px}.logo-large{height:120px;width:auto;margin:0 auto 24px;display:block}.public-form-header h1{font-size:2rem;font-weight:700;color:#0f172a;margin:0 0 12px;line-height:1.3}.public-form-header .subtitle{font-size:1.1rem;color:#64748b;margin:0 0 32px;line-height:1.6}.card-header{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:20px;border-bottom:2px solid #f1f5f9}.card-header h1,.card-header h2{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0;line-height:1.3}.card-header .btn-primary{padding:12px 24px;border:none;border-radius:8px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:600;font-size:15px;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:0 2px 8px #2563eb4d}.card-header .btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 4px 12px #2563eb66;transform:translateY(-1px)}.card-header .btn-primary:active{transform:translateY(0);box-shadow:0 2px 6px #2563eb4d}.card-header p{color:#64748b;font-size:1rem;margin:0;line-height:1.5}.form{display:grid;gap:12px}.form label{font-weight:600;display:block;margin-bottom:8px;color:#1e293b;font-size:.95rem}.form input{padding:16px;border-radius:10px;border:2px solid #e2e8f0;width:100%;font-size:16px;transition:all .2s ease;background:#fff}.form input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 4px #2563eb1a;background:#fafbfc}.form input::placeholder{color:#94a3b8}.form input:disabled{background-color:#f3f4f6;cursor:not-allowed}.form button{padding:16px 24px;border:none;border-radius:12px;background:linear-gradient(135deg,#2563eb,#1d4ed8);color:#fff;font-weight:700;font-size:16px;cursor:pointer;transition:all .3s ease;width:100%;min-height:52px;box-shadow:0 4px 12px #2563eb4d}.form button:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 6px 16px #2563eb66;transform:translateY(-1px)}.form button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #2563eb4d}.form button:disabled{background:#cbd5e1;cursor:not-allowed;opacity:.6;box-shadow:none;transform:none}.btn-primary{background:#2563eb!important;color:#fff!important}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}.field{display:grid;gap:4px}.status{padding:14px 18px;border-radius:10px;font-weight:600;margin-top:16px;word-wrap:break-word;font-size:.95rem;line-height:1.5;box-shadow:0 2px 8px #0000000d}.status.success{background:linear-gradient(135deg,#ecfdf3,#d1fae5);color:#047857;border:2px solid #86efac}.status.error{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c;border:2px solid #fca5a5}.status.info{background:linear-gradient(135deg,#e0f2fe,#dbeafe);color:#075985;border:2px solid #93c5fd}.status.warning{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:2px solid #fcd34d}.split{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.list li{border:1px solid #e5e7eb;padding:10px;border-radius:8px;background:#f9fafb}.list li.present{border-color:#bbf7d0;background:#ecfdf3}.stats{display:flex;flex-wrap:wrap;gap:8px;font-weight:600}.session-info-card{margin-top:32px;padding:28px;background:#fff;border:2px solid #e5e7eb;border-radius:16px;box-shadow:0 4px 12px #00000014}.session-type{color:#0f172a;font-size:1.5rem;font-weight:700;margin:0 0 24px;text-align:center;padding-bottom:20px;border-bottom:2px solid #f1f5f9}.session-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:20px}.session-detail-item{display:flex;flex-direction:column;gap:8px}.detail-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:1.125rem;font-weight:600;color:#0f172a;line-height:1.4}.presence-status{margin-top:20px;padding-top:20px;border-top:2px solid #f1f5f9;text-align:center}.presence-available{display:inline-block;color:#047857;background:#d1fae5;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;border:2px solid #86efac}.presence-unavailable{display:inline-block;color:#92400e;background:#fef3c7;padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;border:2px solid #fcd34d}.session-waiting{text-align:center;color:#64748b;font-size:1rem;margin:0;padding:20px}.confirmation-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.confirmation-content{background:#fff;border-radius:20px;padding:48px;max-width:700px;width:100%;box-shadow:0 20px 60px #00000026;text-align:center;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.confirmation-icon{margin-bottom:24px;animation:scaleIn .6s ease-out .2s both}@keyframes scaleIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.confirmation-title{font-size:2rem;font-weight:800;color:#0f172a;margin:0 0 12px;animation:fadeIn .5s ease-out .4s both}.confirmation-subtitle{font-size:1.1rem;color:#64748b;margin:0 0 40px;line-height:1.6;animation:fadeIn .5s ease-out .5s both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirmation-details{text-align:left;margin-bottom:32px;animation:fadeIn .5s ease-out .6s both}.detail-section{margin-bottom:28px;padding:24px;background:#f8fafc;border-radius:12px;border:2px solid #e2e8f0}.detail-section:last-child{margin-bottom:0}.detail-section h3{font-size:1.2rem;font-weight:700;color:#1e40af;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #bfdbfe}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item .detail-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.detail-item .detail-value{font-size:1.05rem;font-weight:600;color:#0f172a;line-height:1.4}.btn-back{width:100%;max-width:400px;margin:32px auto 0;padding:16px 32px;font-size:1.1rem;font-weight:600;border-radius:12px;box-shadow:0 4px 12px #00000026;transition:all .3s ease;animation:fadeIn .5s ease-out .7s both}.btn-back:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.btn-back:active{transform:translateY(0);box-shadow:0 2px 8px #00000026}@media(max-width:640px){.confirmation-content{padding:32px 24px}.confirmation-title{font-size:1.75rem}.confirmation-subtitle{font-size:1rem}.detail-grid{grid-template-columns:1fr;gap:16px}.detail-section{padding:20px}}@media(max-width:640px){.session-info-card{padding:20px;margin-top:24px}.session-type{font-size:1.25rem;margin-bottom:20px;padding-bottom:16px}.session-details-grid{grid-template-columns:1fr;gap:20px;margin-bottom:16px}.detail-value{font-size:1rem}}@media(max-width:640px){.card-header{flex-direction:column;align-items:flex-start;gap:12px}.card-header img.logo{height:60px;width:auto}.card-header h1{font-size:1.5rem;margin:0;line-height:1.3}.card-header p{font-size:.9rem;margin:4px 0}.public-form-card{padding:24px 20px}.logo-large{height:100px;margin-bottom:20px}.public-form-header h1{font-size:1.75rem}.public-form-header .subtitle{font-size:1rem}.topbar{flex-direction:column;align-items:flex-start;gap:10px;padding:12px}.tabs{width:100%;display:flex;gap:8px;flex-wrap:wrap}.tabs button{flex:1;min-width:120px;font-size:14px;padding:10px 12px}main{padding:12px;margin:0}.card{padding:16px;border-radius:12px}.form{gap:16px}.form label{font-size:14px;margin-bottom:4px}.form input{padding:16px;font-size:16px}.form button{padding:16px;font-size:16px;min-height:52px}.grid{grid-template-columns:1fr;gap:12px}.split{grid-template-columns:1fr}.stats{flex-direction:column;gap:8px}.stats span{padding:8px;background:#f3f4f6;border-radius:6px;text-align:center}}@media(max-width:375px){.card-header h1{font-size:1.25rem}.card{padding:12px}.form input,.form button{padding:14px}}.visitor-form-wrapper{width:100%}.visitor-form-header{text-align:center;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid #e5e7eb}.visitor-form-header h2{font-size:1.75rem;font-weight:700;color:#0f172a;margin:0 0 8px}.visitor-form-header p{font-size:1rem;color:#64748b;margin:0}.visitor-form{display:grid;gap:32px}.form-section{border:2px solid #e5e7eb;border-radius:12px;padding:28px;background:#fff;box-shadow:0 2px 8px #0000000f;margin-bottom:20px}.form-section-location{margin-top:24px;padding:24px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px}.form-section-location h4{margin:0 0 20px;color:#1e40af;font-size:1.1rem;font-weight:700;border-bottom:2px solid #bfdbfe;padding-bottom:12px}.form-section h3{margin:0 0 24px;color:#1e40af;font-size:1.3rem;font-weight:700;border-bottom:2px solid #bfdbfe;padding-bottom:12px}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.form-group{display:grid;gap:12px}.form-group label{font-weight:600;color:#1e293b;font-size:1rem;margin-bottom:6px;line-height:1.4}.visitor-form input,.visitor-form select{padding:14px 16px;border-radius:10px;border:2px solid #64748b;width:100%;font-size:17px;background:#fff;transition:all .2s ease;min-height:52px;box-sizing:border-box;color:#0f172a;font-weight:500;line-height:1.5}.visitor-form input:focus,.visitor-form select:focus{outline:none;border-color:#2563eb;border-width:2px;box-shadow:0 0 0 4px #2563eb1f;background:#fff}.visitor-form input::placeholder{color:#94a3b8;font-size:16px;font-weight:400}.visitor-form input:disabled{background-color:#f1f5f9;cursor:not-allowed;opacity:.7;border-color:#cbd5e1}.visitor-form select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:45px}.required{color:#dc2626;font-weight:700;font-size:1.1em;margin-left:3px}.error-text{color:#dc2626;font-size:.9rem;margin-top:6px;font-weight:600;padding:6px 10px;background:#fef2f2;border:1px solid #fca5a5;border-radius:6px}.field-instructions{font-size:.9rem;color:#64748b;margin-top:8px;font-weight:500;line-height:1.5;padding:10px 12px;background:#f8fafc;border-left:3px solid #3b82f6;border-radius:6px}.phone-label{color:#1e40af;font-weight:700;font-size:1.05rem}.to-uppercase{text-transform:uppercase}.form-actions{display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px;border-top:2px solid #e5e7eb}.btn-secondary{padding:16px 28px;border:2px solid #6b7280;border-radius:12px;background:#fff;color:#6b7280;font-weight:700;font-size:17px;cursor:pointer;transition:all .2s ease;min-height:56px;box-shadow:0 2px 4px #00000014}.btn-secondary:hover:not(:disabled){background:#f3f4f6;border-color:#4b5563;box-shadow:0 4px 8px #0000001a;transform:translateY(-1px)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.visitor-form .btn-primary{padding:16px 28px;border-radius:12px;font-size:17px;font-weight:700;min-height:56px;box-shadow:0 4px 12px #2563eb4d;white-space:nowrap}.visitor-form .btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 16px #2563eb66}.help-button{position:fixed;bottom:20px;right:20px;width:50px;height:50px;border-radius:50%;background:#2563eb;color:#fff;border:none;font-size:1.5rem;cursor:pointer;box-shadow:0 4px 12px #00000026;z-index:1000;display:flex;align-items:center;justify-content:center;transition:transform .2s}.help-button:hover{transform:scale(1.1)}.help-text{background:#fef3c7;border:1px solid #fde68a;border-radius:8px;padding:16px;margin-bottom:20px;font-size:.9rem;color:#92400e}.help-text p{margin:8px 0}.help-text strong{display:block;margin-bottom:8px;font-size:1rem}select{padding:14px;border-radius:8px;border:2px solid #d1d5db;width:100%;font-size:16px;background:#fff;transition:border-color .2s}select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}input[type=checkbox]{width:22px;height:22px;cursor:pointer;margin:0;flex-shrink:0}.checkbox-group{margin-bottom:8px}.checkbox-label{display:flex!important;align-items:center!important;gap:12px!important;cursor:pointer;font-weight:600;color:#1e293b;font-size:1rem;margin-bottom:0!important;line-height:1.5}.checkbox-label span{-webkit-user-select:none;user-select:none;line-height:1.5}@media(max-width:640px){.form-row{grid-template-columns:1fr}.form-section{padding:16px}.form-actions{flex-direction:column}.form-actions button{width:100%}.help-button{width:45px;height:45px;bottom:15px;right:15px;font-size:1.3rem}}.sessions-table{overflow-x:auto;margin-top:16px}.sessions-table table{width:100%;border-collapse:collapse}.sessions-table th,.sessions-table td{padding:12px;text-align:left;border-bottom:1px solid #e5e7eb}.sessions-table th{background:#f3f4f6;font-weight:600;color:#374151}.sessions-table tr:hover{background:#f9fafb}.sessions-table tr.active{background:#eff6ff}.status-badge{padding:4px 12px;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.scheduled{background:#dbeafe;color:#1e40af}.status-badge.completed{background:#e5e7eb;color:#374151}.status-badge.inactive{background:#fee2e2;color:#991b1b}.action-buttons{display:flex;gap:8px;flex-wrap:wrap}.btn-small{padding:6px 12px;font-size:.85rem;border-radius:6px;border:1px solid #d1d5db;background:#fff;color:#374151;cursor:pointer;transition:all .2s}.btn-small:hover{background:#f3f4f6;border-color:#9ca3af}.btn-activate{background:#2563eb;color:#fff;border-color:#2563eb}.btn-activate:hover{background:#1d4ed8;border-color:#1d4ed8}.session-meta{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px;font-size:.9rem;color:#6b7280}.session-meta span{display:flex;align-items:center;gap:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin:20px 0}.stat-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;text-align:center}.stat-card h4{margin:0 0 8px;font-size:.9rem;color:#6b7280;font-weight:600}.stat-card p{margin:0;font-size:2rem;font-weight:700;color:#111827}.stat-card.total{background:#eff6ff;border-color:#bfdbfe}.stat-card.total h4,.stat-card.total p{color:#1e40af}.attendance-list{max-height:500px;overflow-y:auto;margin-top:12px}.attendance-item{padding:12px;border:1px solid #e5e7eb;border-radius:6px;margin-bottom:8px;background:#fff}.attendance-item.present{background:#ecfdf3;border-color:#bbf7d0}.attendance-item.visitor{background:#fef3c7;border-color:#fde68a}.attendance-item strong{display:block;margin-bottom:4px;color:#111827}.attendance-item small{display:block;color:#6b7280;font-size:.85rem;margin-top:4px}.attendance-time{color:#9ca3af!important;font-size:.75rem!important}.auto-refresh-toggle{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#6b7280}.auto-refresh-toggle input[type=checkbox]{width:18px;height:18px}@media(max-width:640px){.sessions-table{font-size:.85rem}.sessions-table th,.sessions-table td{padding:8px}.stats-grid{grid-template-columns:1fr}.session-meta{flex-direction:column;gap:8px}.action-buttons{flex-direction:column}.action-buttons button{width:100%}}.admin-nav-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:2px solid #e2e8f0;padding-bottom:0}.admin-nav-tabs button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#64748b;font-weight:500;cursor:pointer;transition:all .2s;font-size:1rem}.admin-nav-tabs button:hover{color:#2563eb;background:#f1f5f9}.admin-nav-tabs button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.grand-master-badge{display:inline-block;margin-left:8px;padding:4px 8px;background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#78350f;font-size:.75rem;font-weight:600;border-radius:6px;box-shadow:0 2px 4px #0000001a}.attendance-item.grand-master{background:linear-gradient(135deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.attendance-section{margin-top:24px;margin-bottom:32px}.attendance-section:first-of-type{margin-top:0}.section-header{margin-bottom:16px;padding-bottom:12px;border-bottom:2px solid #e5e7eb}.section-header h4{margin:0;font-size:1.25rem;font-weight:600;color:#111827}.attendance-item-content{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.attendance-item-content>div{flex:1}.btn-remove{padding:6px 10px;border:1px solid #dc2626;background:#fff;color:#dc2626;border-radius:6px;cursor:pointer;font-size:1.2rem;font-weight:700;line-height:1;transition:all .2s;flex-shrink:0;min-width:32px;height:32px;display:flex;align-items:center;justify-content:center}.btn-remove:hover{background:#dc2626;color:#fff;transform:scale(1.05)}.btn-remove:active{transform:scale(.95)}.empty-message{padding:24px;text-align:center;color:#9ca3af;font-style:italic;background:#f9fafb;border:1px dashed #e5e7eb;border-radius:6px}.table-container{overflow-x:auto;margin-top:20px}table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #0000001a}table thead{background:#f8fafc}table th{padding:12px 16px;text-align:left;font-weight:600;color:#475569;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}table td{padding:12px 16px;border-top:1px solid #e2e8f0;color:#1e293b}table tbody tr:hover{background:#f8fafc}.btn-small{padding:6px 12px;font-size:.875rem}.btn-danger{background:#ef4444;color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.info-text{color:#64748b;font-size:.9rem;margin-bottom:20px;padding:12px;background:#f1f5f9;border-radius:8px;border-left:4px solid #3b82f6}.grand-master-value{color:#78350f;font-weight:600}
