/* Triton Booking v4.1 — Premium Public Frontend */
*{box-sizing:border-box}
:root{
    --triton-primary:#7c3aed;
    --triton-primary-dark:#6d28d9;
    --triton-primary-light:#ede9fe;
    --triton-surface:#f8f7ff;
    --triton-text:#1a1a2e;
    --triton-muted:#666;
    --triton-border:#f0f0f0;
    --triton-card-shadow:0 2px 12px rgba(0,0,0,.06);
    --triton-card-hover:0 8px 24px rgba(0,0,0,.1);
    --triton-radius:16px;
    --triton-radius-sm:10px;
    --triton-urgent:#ef4444;
    --triton-low:#f59e0b;
    --triton-success:#22c55e;
}

.triton-booking,.triton-services{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;color:var(--triton-text);max-width:960px;margin:0 auto}

/* Spinner */
.triton-loading{text-align:center;padding:40px;color:#999;font-size:15px;display:flex;flex-direction:column;align-items:center;gap:12px}
.triton-spinner{width:32px;height:32px;border:3px solid var(--triton-border);border-top-color:var(--triton-primary);border-radius:50%;animation:triton-spin .7s linear infinite}
@keyframes triton-spin{to{transform:rotate(360deg)}}
.triton-empty{text-align:center;padding:40px;color:#999}

/* Group headings */
.triton-group{margin-bottom:32px}
.triton-group-title{font-size:22px;font-weight:700;color:var(--triton-text);margin:0 0 16px;padding-bottom:8px;border-bottom:2px solid var(--triton-primary-light)}

/* Service cards grid */
.triton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:20px}
.triton-card{background:#fff;border-radius:var(--triton-radius);overflow:hidden;box-shadow:var(--triton-card-shadow);transition:transform .2s,box-shadow .2s;border:1px solid var(--triton-border);position:relative;max-width:420px}
.triton-card:hover{transform:translateY(-3px);box-shadow:var(--triton-card-hover)}
.triton-card.featured{border:2px solid var(--triton-primary)}
.triton-card-featured-tag{position:absolute;top:12px;left:12px;z-index:2;background:var(--triton-primary);color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;letter-spacing:.5px}
.triton-card-img{height:200px;background-size:cover;background-position:center;background-color:#f0f0f5}
.triton-card-img-placeholder{display:flex;align-items:center;justify-content:center;font-size:48px;background:linear-gradient(135deg,#667eea,#764ba2);color:rgba(255,255,255,.6)}
.triton-card-body{padding:20px}
.triton-card-cat{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--triton-primary);font-weight:600;margin-bottom:4px}
.triton-card-title{margin:0 0 8px;font-size:18px;font-weight:700;color:var(--triton-text)}
.triton-card-desc{font-size:14px;color:var(--triton-muted);line-height:1.6;margin:0 0 12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.triton-card-desc p{margin:0 0 6px}.triton-card-desc p:last-child{margin-bottom:0}
.triton-card-desc ul{margin:4px 0;padding-left:18px}.triton-card-desc li{margin-bottom:2px}
.triton-card-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.triton-card-price{font-size:22px;font-weight:700;color:var(--triton-text)}.triton-card-price small{font-size:13px;color:#999;font-weight:400}
.triton-card-duration{font-size:13px;color:#999;background:#f5f5f7;padding:4px 10px;border-radius:20px}
.triton-card-deposit{display:inline-block;font-size:12px;color:var(--triton-primary);background:var(--triton-primary-light);padding:3px 10px;border-radius:20px;margin-bottom:8px;font-weight:500}
.triton-card-info{font-size:12px;color:#888;margin-bottom:8px}
.triton-card-next{font-size:13px;color:var(--triton-muted);margin-bottom:12px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.triton-card-next strong{color:var(--triton-text)}

/* Urgency badges */
.triton-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:700;letter-spacing:.3px}
.triton-badge-urgent{background:#fef2f2;color:var(--triton-urgent);border:1px solid #fecaca}
.triton-badge-low{background:#fffbeb;color:#b45309;border:1px solid #fed7aa}
.triton-badge-full{background:#f3f4f6;color:#9ca3af;border:1px solid #e5e7eb}

/* Buttons */
.triton-btn{display:inline-block;padding:12px 24px;background:var(--triton-primary);color:#fff;border:none;border-radius:var(--triton-radius-sm);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;text-align:center;transition:.2s;width:100%}
.triton-btn:hover{background:var(--triton-primary-dark);transform:translateY(-1px)}
.triton-btn-cta{background:linear-gradient(135deg,var(--triton-primary),#5b21b6);font-size:15px;padding:14px 24px;box-shadow:0 4px 14px rgba(124,58,237,.3)}
.triton-btn-cta:hover{box-shadow:0 6px 20px rgba(124,58,237,.4);transform:translateY(-2px)}
.triton-btn-ghost{background:transparent;color:var(--triton-primary);border:1px solid #e5e5e5;width:auto}
.triton-btn-ghost:hover{background:var(--triton-primary-light)}
.triton-btn-sm{padding:8px 16px;font-size:13px;width:auto;margin-bottom:12px}

/* ═══ Wizard ═══ */
.triton-wizard{max-width:700px;margin:0 auto}
.triton-wizard-hero{position:relative;border-radius:var(--triton-radius);overflow:hidden;margin-bottom:20px}
.triton-wizard-hero-img{height:320px;background-size:cover;background-position:center;background-color:#f0f0f5}
.triton-wizard-hero-overlay{position:absolute;bottom:0;left:0;right:0;padding:28px 24px;background:linear-gradient(transparent,rgba(0,0,0,.78));color:#fff}
.triton-wizard-hero-cat{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;opacity:.85;margin-bottom:6px}
.triton-wizard-hero-title{margin:0 0 10px;font-size:28px;font-weight:700;line-height:1.2;text-shadow:0 1px 4px rgba(0,0,0,.3)}
.triton-wizard-hero-meta{display:flex;gap:8px;font-size:14px;opacity:.9;flex-wrap:wrap}

.triton-wizard-info{background:#fff;border:1px solid var(--triton-border);border-radius:var(--triton-radius);padding:28px;margin-bottom:20px;box-shadow:var(--triton-card-shadow);text-align:center}
.triton-wizard-desc{font-size:15px;color:#444;line-height:1.7;margin:0 0 20px;max-width:580px;margin-left:auto;margin-right:auto;text-align:center}
.triton-wizard-desc p{margin:0 0 12px}.triton-wizard-desc p:last-child{margin-bottom:0}
.triton-wizard-desc ul{text-align:left;display:inline-block;margin:8px 0;padding-left:20px}.triton-wizard-desc li{margin-bottom:4px}
.triton-wizard-desc h4{font-size:16px;color:var(--triton-text);margin:16px 0 8px}
.triton-wizard-desc hr{border:none;border-top:1px solid #eee;margin:16px 0}
.triton-wizard-desc strong{color:var(--triton-text)}
.triton-wizard-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;text-align:left;border-top:1px solid var(--triton-border);padding-top:20px}
.triton-wizard-detail{display:flex;gap:10px;align-items:flex-start}
.triton-detail-icon{font-size:20px;flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--triton-surface);border-radius:8px}
.triton-wizard-detail strong{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--triton-primary);display:block;margin-bottom:2px}
.triton-wizard-detail div{font-size:13px;color:#555;line-height:1.4}

/* Wizard form cards */
.triton-wizard-card{background:#fff;border:1px solid var(--triton-border);border-radius:var(--triton-radius);padding:24px;margin-bottom:16px;box-shadow:var(--triton-card-shadow)}
.triton-wizard-card h3{margin:0 0 16px;font-size:16px;color:var(--triton-text)}

/* Deposit note */
.triton-deposit-note{font-size:13px;color:var(--triton-primary);background:var(--triton-primary-light);padding:10px 16px;border-radius:var(--triton-radius-sm);margin:0 0 16px;text-align:center;font-weight:500}

/* Form fields */
.triton-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.triton-field{margin-bottom:12px}
.triton-field label{display:block;font-size:13px;font-weight:500;color:#555;margin-bottom:4px}
.triton-field input,.triton-field textarea,.triton-field select{width:100%;padding:10px 14px;border:1px solid #e0e0e0;border-radius:8px;font-size:14px;color:var(--triton-text);outline:none;transition:.15s}
.triton-field input:focus,.triton-field textarea:focus,.triton-field select:focus{border-color:var(--triton-primary);box-shadow:0 0 0 3px rgba(124,58,237,.1)}

/* Time slot cards — premium CTA style */
.triton-slots{margin-top:16px}
.triton-slots-label{display:block;font-size:14px;font-weight:600;color:var(--triton-text);margin-bottom:10px}
.triton-slot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}

.triton-slot-card{display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 12px;background:#fff;border:2px solid #e8e5f5;border-radius:var(--triton-radius-sm);cursor:pointer;text-decoration:none;text-align:center;transition:.2s;color:var(--triton-text)}
.triton-slot-card:hover{border-color:var(--triton-primary);background:var(--triton-primary-light);transform:translateY(-1px);box-shadow:0 4px 12px rgba(124,58,237,.1)}
.triton-slot-card.active{background:var(--triton-primary);color:#fff;border-color:var(--triton-primary);box-shadow:0 4px 14px rgba(124,58,237,.3)}
.triton-slot-card.active .triton-slot-cta{background:rgba(255,255,255,.2);color:#fff}
.triton-slot-card.active .triton-badge{background:rgba(255,255,255,.15);color:#fff;border-color:rgba(255,255,255,.3)}

.triton-slot-time{font-size:18px;font-weight:700;letter-spacing:.5px}
.triton-slot-spaces{font-size:11px;color:var(--triton-muted);font-weight:500}
.triton-slot-card.active .triton-slot-spaces{color:rgba(255,255,255,.85)}
.triton-slot-cta{display:block;width:100%;margin-top:4px;padding:6px 10px;background:var(--triton-primary);color:#fff;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;transition:.15s}
a.triton-slot-card .triton-slot-cta{background:var(--triton-primary)}
a.triton-slot-card:hover .triton-slot-cta{background:var(--triton-primary-dark)}

.triton-no-slots{padding:16px;text-align:center;color:#999;background:#f9f9f9;border-radius:8px;font-size:14px}

/* Summary */
.triton-summary{padding:16px;background:var(--triton-surface);border-radius:var(--triton-radius-sm);margin-bottom:20px;text-align:center}
.triton-summary-row{font-size:15px;color:var(--triton-muted);line-height:1.6}
.triton-summary-row strong{color:var(--triton-text)}
.triton-summary-total{font-size:20px;font-weight:700;color:var(--triton-text);margin-top:8px}
.triton-summary-deposit{font-size:14px;font-weight:500;color:var(--triton-primary)}

/* Confirmation */
.triton-confirmed{text-align:center;padding:48px 24px}
.triton-confirmed-icon{font-size:64px;margin-bottom:16px}
.triton-confirmed h2{font-size:24px;color:var(--triton-text);margin:0 0 12px}
.triton-confirmed p{font-size:15px;color:#555;margin:4px 0}

/* Mobile */
@media(max-width:600px){
    .triton-form-row{grid-template-columns:1fr}
    .triton-grid{grid-template-columns:1fr !important}
    .triton-card-img{height:180px}
    .triton-slot-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
    .triton-wizard-hero-img{height:220px}
    .triton-wizard-hero-title{font-size:22px}
    .triton-wizard-details{grid-template-columns:1fr}
    .triton-wizard{padding:0 4px}
}
