:root{--bg: #0c0c0f;--surface: #16161a;--surface-2: #1e1e24;--surface-3: #26262e;--border: #2e2e38;--border-2: #3a3a48;--primary: #7c6cf9;--primary-d: #6558e0;--success: #22c55e;--error: #ef4444;--warn: #f59e0b;--text: #e2e2e8;--text-2: #a0a0b0;--text-3: #66667a;--radius: 10px;--radius-sm: 6px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh}.app-loading{display:flex;align-items:center;justify-content:center;gap:12px;height:100vh;color:var(--text-2);font-size:15px}.spinner,.spinner-sm{display:inline-block;border-radius:50%;border-style:solid;border-color:transparent;border-top-color:currentColor;animation:spin .7s linear infinite;flex-shrink:0}.spinner{width:18px;height:18px;border-width:2.5px}.spinner-sm{width:12px;height:12px;border-width:2px}@keyframes spin{to{transform:rotate(360deg)}}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);gap:16px}.app-brand{display:flex;align-items:center;gap:10px}.brand-icon{font-size:20px}.brand-text{display:flex;flex-direction:column}.brand-name{font-size:15px;font-weight:700;letter-spacing:-.3px;color:var(--text)}.brand-sub{font-size:11px;color:var(--text-3)}.header-right{display:flex;align-items:center;gap:12px}.header-stat{font-size:12px;color:var(--text-2);background:var(--surface-2);padding:4px 10px;border-radius:20px;border:1px solid var(--border)}.btn-book-all{display:flex;align-items:center;gap:6px;padding:8px 20px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s;white-space:nowrap}.btn-book-all:hover:not(:disabled){background:var(--primary-d)}.btn-book-all:disabled{opacity:.4;cursor:not-allowed}@media(max-width:760px){.header-stat{display:none}}.app-main{flex:1;display:flex;flex-direction:column;gap:32px;padding:24px;max-width:1400px;margin:0 auto;width:100%}.cards-area{display:flex;flex-direction:column;gap:16px}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(520px,1fr));gap:16px}@media(max-width:580px){.cards-grid{grid-template-columns:1fr}}.add-card-btn{display:flex;align-items:center;gap:8px;width:fit-content;padding:8px 18px;background:transparent;border:1.5px dashed var(--border-2);border-radius:var(--radius);color:var(--text-2);font-size:13px;cursor:pointer;transition:border-color .15s,color .15s}.add-card-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.add-card-btn:disabled{opacity:.4;cursor:not-allowed}.add-card-plus{font-size:18px;line-height:1}.user-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}.user-card.run-running{border-color:var(--primary)}.user-card.run-done{border-color:var(--success)}.user-card.run-failed{border-color:var(--error)}.uc-header{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:var(--surface-2);border-bottom:1px solid var(--border)}.uc-title{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.uc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.dot-green{background:var(--success);box-shadow:0 0 6px var(--success)}.dot-muted{background:var(--text-3)}.uc-label{font-size:13px;font-weight:600;color:var(--text)}.uc-token{font-size:11px;font-variant-numeric:tabular-nums;color:var(--text-2);background:var(--surface-3);padding:2px 7px;border-radius:20px}.uc-token.token-warn{color:var(--warn);background:#f59e0b1a}.uc-ready-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--success);background:#22c55e1a;padding:2px 8px;border-radius:20px}.uc-remove-btn{background:transparent;border:1px solid var(--border);color:var(--text-3);width:26px;height:26px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;transition:border-color .15s,color .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.uc-remove-btn:hover:not(:disabled){border-color:var(--error);color:var(--error)}.uc-remove-btn:disabled{opacity:.4;cursor:not-allowed}.uc-section{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.uc-section:last-child{border-bottom:none}.uc-section-header{display:flex;align-items:center;justify-content:space-between}.uc-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);display:flex;align-items:center;gap:6px}.pilgrim-count{font-size:10px;font-weight:600;color:var(--text-2);background:var(--surface-3);padding:1px 6px;border-radius:10px}.darshan-pills{display:flex;gap:8px;flex-wrap:wrap}.darshan-pill{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:transparent;color:var(--text-2);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s}.darshan-pill:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}.darshan-pill.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.darshan-pill:disabled{opacity:.5;cursor:not-allowed}.auth-row{display:flex;gap:8px;align-items:center}.auth-done{display:flex;align-items:center;gap:8px;background:#22c55e0f;border:1px solid rgba(34,197,94,.2);border-radius:var(--radius-sm);padding:8px 12px}.auth-check{color:var(--success);font-weight:700;font-size:15px}.auth-mobile{font-size:13px;color:var(--text);font-weight:500;flex:1}.field-error{font-size:12px;color:var(--error)}.field{flex:1;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:13px;padding:7px 10px;outline:none;transition:border-color .15s;min-width:0}.field:focus{border-color:var(--primary)}.field:disabled{opacity:.5;cursor:not-allowed}.field::placeholder{color:var(--text-3)}.field-otp{max-width:150px;letter-spacing:5px;font-size:16px;font-weight:600;text-align:center}.btn{padding:7px 14px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;display:inline-flex;align-items:center;gap:5px}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-d)}.btn-ghost{background:transparent;color:var(--text-2);border-color:var(--border)}.btn-ghost:hover:not(:disabled){border-color:var(--border-2);color:var(--text)}.btn-xs{padding:4px 9px;font-size:11px}.slot-loading{display:flex;align-items:center;gap:8px;color:var(--text-2);font-size:13px}.slot-empty{font-size:12px;color:var(--text-3)}.date-chips{display:flex;flex-wrap:wrap;gap:6px}.date-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 11px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s;font-size:12px}.date-chip:hover:not(:disabled){border-color:var(--primary)}.date-chip.selected{background:var(--primary);border-color:var(--primary);color:#fff}.date-chip:disabled{opacity:.5;cursor:not-allowed}.chip-date{font-weight:500}.chip-avl{font-size:10px;opacity:.7}.time-chips{display:flex;flex-wrap:wrap;gap:6px}.time-chip{display:flex;align-items:center;gap:6px;padding:6px 10px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;transition:all .15s}.time-chip:hover:not(:disabled){border-color:var(--primary)}.time-chip.selected{background:var(--primary);border-color:var(--primary);color:#fff}.time-chip:disabled{opacity:.5;cursor:not-allowed}.chip-time{font-weight:500}.slot-selected{font-size:12px;font-weight:600;color:var(--primary);background:#7c6cf914;border:1px solid rgba(124,108,249,.2);border-radius:var(--radius-sm);padding:6px 12px}.pilgrim-table-wrap{overflow-x:auto}.pilgrim-table{display:flex;flex-direction:column;gap:4px;min-width:510px}.pt-head{display:grid;grid-template-columns:1fr 55px 88px 108px 1fr 28px;gap:4px;padding-bottom:4px}.pt-head span{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);padding:0 2px}.pt-row{display:grid;grid-template-columns:1fr 55px 88px 108px 1fr 28px;gap:4px;align-items:center}.pt-input,.pt-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-size:12px;padding:6px 8px;outline:none;width:100%;transition:border-color .15s}.pt-input:focus,.pt-select:focus{border-color:var(--primary)}.pt-input:disabled,.pt-select:disabled{opacity:.5;cursor:not-allowed}.pt-input::placeholder{color:var(--text-3)}.pt-age{text-align:center;padding:6px 4px}.pt-remove{width:28px;height:28px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-3);font-size:11px;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.pt-remove:hover:not(:disabled){border-color:var(--error);color:var(--error)}.pt-remove:disabled{opacity:.4;cursor:not-allowed}.uc-run-status{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;border-top:1px solid var(--border)}.uc-run-status.run-running{background:#7c6cf90d}.uc-run-status.run-done{background:#22c55e0d}.uc-run-status.run-failed{background:#ef44440d}.run-icon{font-size:15px;line-height:1.5;flex-shrink:0}.run-running .run-icon{color:var(--primary)}.run-done .run-icon{color:var(--success)}.run-failed .run-icon{color:var(--error)}.run-body{flex:1;min-width:0}.run-phase{font-size:13px;color:var(--text);font-weight:500}.run-meta{font-size:11px;color:var(--text-2);margin-top:3px}.run-error{font-size:11px;color:var(--error);margin-top:3px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}.badge-success{background:#22c55e1f;color:var(--success)}.badge-error{background:#ef44441f;color:var(--error)}.badge-warn{background:#f59e0b1f;color:var(--warn)}.badge-muted{background:var(--surface-3);color:var(--text-2)}.history-section{border-top:1px solid var(--border);padding-top:24px}.history-header{display:flex;align-items:center;gap:10px;margin-bottom:14px}.history-header h2{font-size:15px;font-weight:600}.history-count{font-size:11px;color:var(--text-3);background:var(--surface-2);padding:2px 8px;border-radius:20px;border:1px solid var(--border)}.history-empty{font-size:13px;color:var(--text-3)}.history-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.history-booking-card{display:flex;flex-direction:column;gap:12px;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px;transition:border-color .15s}.history-booking-card:hover{border-color:var(--border-2)}.history-booking-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.history-booking-status{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.history-booking-mobile{color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;font-weight:700;white-space:nowrap}.history-booking-main{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.history-booking-main h3{margin:0;color:var(--text);font-size:15px;font-weight:700;line-height:1.25}.history-booking-main p{margin:3px 0 0;color:var(--text-3);font-size:12px}.history-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.history-detail{min-width:0;padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.history-detail span{display:block;margin-bottom:3px;color:var(--text-3);font-size:11px;font-weight:600}.history-detail strong{display:block;overflow:hidden;color:var(--text-2);font-size:12px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.history-read-section,.history-empty-detail{color:var(--text-2);font-size:12px;line-height:1.4}.history-read-section{display:flex;flex-direction:column;gap:7px}.history-read-section h4{margin:0;color:var(--text-3);font-size:11px;font-weight:700;text-transform:uppercase}.history-pilgrim-list{display:flex;flex-direction:column;gap:6px}.history-pilgrim-card{display:flex;align-items:center;gap:8px;min-width:0;padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.history-pilgrim-name{flex-shrink:0;overflow:hidden;color:var(--text);font-size:12px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.history-pilgrim-meta{display:flex;flex-wrap:wrap;gap:5px 8px;min-width:0;color:var(--text-3);font-size:11px}.history-pilgrim-meta span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-empty-detail{padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}@media(max-width:980px){.history-card-grid{grid-template-columns:1fr}}@media(max-width:520px){.history-booking-header,.history-booking-main{align-items:flex-start;flex-direction:column}.history-detail-grid{grid-template-columns:1fr}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-2)}.app-tabs{display:flex;gap:8px;padding:0 24px;border-bottom:1px solid var(--border);background:var(--bg-2)}.app-tab{padding:10px 16px;background:transparent;border:none;color:var(--text-2);cursor:pointer;font-size:14px;border-bottom:2px solid transparent;margin-bottom:-1px}.app-tab.active{color:var(--text-1);border-bottom-color:var(--primary)}.app-tab:hover:not(.active){color:var(--text-1)}.app-header{position:relative}.header-tabs{background:transparent;border-bottom:none;padding:0;position:absolute;left:50%;top:0;transform:translate(-50%);height:100%;align-items:stretch}.header-tabs .app-tab{padding:0 16px;margin-bottom:0;display:flex;align-items:center;border-bottom-width:2px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 16px;padding:16px 0}.form-field{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--text-2)}.form-field input,.form-field select{padding:8px 10px;background:var(--bg-3);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-1);font-size:13px}.panel-sub{margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}.panel-sub-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.panel-sub h3{margin:0;font-size:13px;color:var(--text-2);font-weight:600}.panel-sub .muted{color:var(--text-3);font-weight:400}.form-error{color:var(--error);background:#ef444414;padding:8px 12px;border-radius:var(--radius-sm);margin-top:8px;font-size:13px}.form-ok{color:var(--success);background:#22c55e14;padding:8px 12px;border-radius:var(--radius-sm);margin-top:8px;font-size:13px}.schedule-card-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.schedule-booking-card{display:flex;flex-direction:column;gap:12px;min-width:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.schedule-booking-card.is-editing{border-color:var(--primary)}.schedule-booking-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}.schedule-booking-status{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.schedule-booking-mobile{color:var(--text);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;font-weight:700;white-space:nowrap}.schedule-countdown{flex-shrink:0;padding:4px 8px;border:1px solid var(--border);border-radius:999px;color:var(--text-2);background:var(--surface-2);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:12px;font-weight:700}.schedule-countdown.is-live{color:var(--primary);border-color:#7c6cf973}.schedule-booking-main{display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}.schedule-title-line{display:flex;align-items:center;gap:8px;min-width:0;flex-wrap:wrap}.schedule-booking-main h3{margin:0;color:var(--text);font-size:15px;font-weight:700;line-height:1.25}.schedule-booking-main p{margin:3px 0 0;color:var(--text-3);font-size:12px}.schedule-otp-card{display:flex;align-items:center;gap:8px;flex-shrink:0;min-width:min(100%,250px);padding:7px 8px;background:#7c6cf912;border:1px solid rgba(124,108,249,.26);border-radius:var(--radius-sm)}.schedule-otp-label{color:var(--primary);font-size:11px;font-weight:800;text-transform:uppercase}.schedule-otp-controls{display:flex;align-items:center;gap:6px;min-width:0}.schedule-otp-controls input{width:92px;min-width:0;height:30px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:14px;font-weight:700;text-align:center}.schedule-detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.schedule-detail-grid.compact{gap:6px}.schedule-detail{min-width:0;padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.schedule-detail span{display:block;margin-bottom:3px;color:var(--text-3);font-size:11px;font-weight:600}.schedule-detail strong{display:block;overflow:hidden;color:var(--text-2);font-size:12px;font-weight:600;text-overflow:ellipsis;white-space:nowrap}.schedule-read-section,.schedule-empty-detail,.schedule-status-detail{color:var(--text-2);font-size:12px;line-height:1.4}.schedule-read-section{display:flex;flex-direction:column;gap:7px}.schedule-read-section h4{margin:0;color:var(--text-3);font-size:11px;font-weight:700;text-transform:uppercase}.schedule-pilgrim-list{display:flex;flex-direction:column;gap:6px}.schedule-general-card,.schedule-pilgrim-card{display:flex;align-items:center;gap:8px;min-width:0;padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.schedule-general-email,.schedule-pilgrim-name{flex-shrink:0;overflow:hidden;color:var(--text);font-size:12px;font-weight:700;text-overflow:ellipsis;white-space:nowrap}.schedule-general-meta,.schedule-pilgrim-meta{display:flex;flex-wrap:wrap;gap:5px 8px;min-width:0;margin-top:0;color:var(--text-3);font-size:11px}.schedule-pilgrim-meta span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.schedule-empty-detail{padding:7px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm)}.schedule-status-detail{padding:8px;background:#ffffff06;border-radius:var(--radius-sm);font-style:italic}.schedule-booking-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.schedule-booking-actions{justify-content:flex-end;flex-shrink:0}.btn-sm{padding:4px 10px;font-size:12px}@media(max-width:980px){.schedule-card-grid{grid-template-columns:1fr}}@media(max-width:520px){.schedule-booking-header,.schedule-booking-main{align-items:flex-start;flex-direction:column}.schedule-otp-card{width:100%;justify-content:space-between}.schedule-detail-grid{grid-template-columns:1fr}}.schedule-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 0;gap:12px}.schedule-card .card-section{padding:12px 0;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.schedule-card .card-section:first-of-type{border-top:none}.schedule-card .form-field small{margin-top:2px;font-size:11px}.schedule-card .auth-inline{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.schedule-card .auth-ok{display:flex;gap:10px;align-items:center;font-size:12px}.schedule-card .token-countdown{color:var(--text-2);font-family:monospace}.card-title-meta{display:flex;gap:8px;align-items:center}.schedule-form-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}.sf-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 16px;margin-bottom:12px}.sf-field{display:flex;flex-direction:column;gap:4px}.sf-label{font-size:12px;color:var(--text-2);font-weight:600}.sf-hint{font-size:11px;color:var(--text-3);margin-top:4px}.sf-field-wide{grid-column:1 / -1}
