﻿body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";color:#0a0a0a;margin:0;background:#fafafa;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
html{box-sizing:border-box}
*,*::before,*::after{box-sizing:inherit}
.container{padding:0 16px;max-width:960px;margin:0 auto}
.btn{display:inline-flex;align-items:center;justify-content:center;height:44px;padding:0 16px;background:#111;color:#fff;text-decoration:none;border:0;border-radius:12px;cursor:pointer;font-weight:500;letter-spacing:.01em;transition:background .2s,transform .1s;font-size:16px;line-height:1.2;box-sizing:border-box;white-space:nowrap}
.btn:hover{background:#000; color:#fff}
.btn:active{transform:translateY(1px)}
.btn,button.btn{appearance:none;-webkit-appearance:none}
.btn-outline{background:#fff;color:#111;border:1px solid rgba(0,0,0,.12)}
.btn-muted{background:#f2f2f2;color:#111}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid #e5e7eb;padding:12px;text-align:left; font-size: 14px;}
.table-responsive{overflow:auto;-webkit-overflow-scrolling:touch}
.card{border:1px solid rgba(0,0,0,.08);border-radius:16px;background:#fff;box-shadow:0 1px 2px rgba(0,0,0,.04)}
.card-body{padding:16px}
.badge{display:inline-block;padding:4px 8px;border-radius:9999px;background:#eef1f6;color:#111;font-size:12px}
input[type="text"],input[type="email"],input[type="password"],input[type="datetime-local"],input[type="date"],input[type="url"],select{border:1px solid rgba(0,0,0,.12);border-radius:12px;padding:12px 14px;width:100%;box-sizing:border-box;background:#fff;color:#111;caret-color:#111;transition:border-color .2s,box-shadow .2s}
input:focus,select:focus{outline:none;border-color:#111;box-shadow:0 0 0 3px rgba(17,17,17,.08)}
input::placeholder{color:#9ca3af;opacity:1}
input:-webkit-autofill,textarea:-webkit-autofill,select:-webkit-autofill{ -webkit-text-fill-color:#111; transition: background-color 5000s ease-in-out 0s }
label{display:block;margin-bottom:6px;color:#5b5b5b;font-weight:600;letter-spacing:.01em}
small,.help{color:#6b7280}
.grid{display:grid;gap:16px}
@media(min-width:640px){.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
.stack{display:flex;flex-direction:column;gap:12px}
.center{margin-left:auto;margin-right:auto}
.container-fluid{padding:0 16px;margin:0 auto;max-width:none;width:100%;box-sizing:border-box}
.hidden-sm{display:none}
@media(min-width:640px){.hidden-sm{display:block}.only-sm{display:none}}
.header{padding:20px 0}
.title{font-size:28px;line-height:1.2;margin:0 0 8px 0;letter-spacing:-.01em}
.subtitle{font-size:14px;color:#6b7280;margin:0}
.surface{background:linear-gradient(180deg,#fff, #f7f7f7);border:1px solid rgba(0,0,0,.06);border-radius:20px;padding:20px}
.hero{padding:24px 0}
.footer{padding:24px 0;color:#6b7280;font-size:13px}
.link{color:#111;text-decoration:none;border-bottom:1px solid rgba(0,0,0,.2);padding-bottom:1px}
.link:hover{border-bottom-color:#111}
.notice{padding:12px 14px;border-radius:12px;background:#f1f5f9;color:#0f172a}
.danger{background:#fee2e2;color:#7f1d1d}
.success{background:#e8f5e9;color:#1b5e20}
.admin-nav{position:sticky;top:0;background:#fff;border-bottom:1px solid rgba(0,0,0,.06);z-index:10}
.admin-nav .nav-wrap{display:flex;align-items:center;justify-content:space-between;padding:8px 0}
.admin-nav .links{display:flex;gap:8px;flex-wrap:wrap}
.admin-slots-wrap{display:flex;flex-direction:column;gap:16px}
.admin-cal,.admin-picked{min-width:0}
@media(min-width:1024px){.admin-slots-wrap{flex-direction:row}.admin-cal{flex:3 1 0}.admin-picked{flex:1 1 0}}
.fc .fc-col-header-cell-cushion{padding:8px 6px}
.fc .fc-col-date{font-size:18px;font-weight:700;line-height:1.2}
.fc .fc-col-weekday{font-size:12px;color:#6b7280;line-height:1.2}
.cta{display:flex;gap:8px;flex-wrap:wrap}
.cta > *{flex:1}
.cta > * .btn{width:100%}
.cta > .btn{width:100%}
.h-scroll-touch{overflow-x:auto;-webkit-overflow-scrolling:touch}
.table-min-720{min-width:720px}
/* Accordion for filters */
.accordion-panel{overflow:hidden;max-height:0;transition:max-height .25s ease}
.accordion-panel.open{max-height:500px}
.filter-form-grid{display:flex;gap:8px;flex-wrap:wrap;align-items:end}
@media (max-width: 640px){
  .btn-cap-130{max-width:130px;width:100%}
  .btn-cap-80{max-width:80px;width:100%}
}
.full-bleed{margin-left:-16px;margin-right:-16px}
@media(min-width:640px){.full-bleed{margin-left:0;margin-right:0}}
/* Minimal base styles for welcome page retained */
:root{--brand-color:#111}
html,body{height:100%}
a{color:var(--brand-color);text-decoration:none}
a:hover{text-decoration:none}

/* Booking Detail Page Styles */
.booking-detail-container {
    min-height: 100vh;
    padding: 20px 0;
}

.booking-header {
    text-align: center;
    margin-bottom: 32px;
}

.booking-card {
    max-width: 600px;
    margin: 0 auto;
}

.detail-row {
    padding: 16px 0;
    border-bottom: 1px solid rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.detail-row:last-child {
    border-bottom: none;
}

.detail-label {
    font-size: 13px;
    color: #6b7280;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.detail-value {
    font-size: 16px;
    color: #111;
    font-weight: 500;
}

.datetime-value {
    font-size: 18px;
    font-weight: 600;
    color: #111;
    line-height: 1.4;
}

.actions-section {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid rgba(0,0,0,0.08);
}

.cancel-form {
    
}

.btn-cancel {
    background: #ff3b30;
    color: white;
    border: none;
    font-weight: 600;
}

.btn-cancel:hover {
    background: #d70015;
}

.btn-reschedule {
    background: #007aff;
    color: white;
    margin-top: 12px;
    display: inline-block;
    text-decoration: none;
}

.btn-reschedule:hover {
    background: #0051d2;
    color: white;
    text-decoration: none;
}

.status-cancelled {
    background: #fee2e2;
    color: #7f1d1d;
    padding: 16px;
    border-radius: 12px;
    text-align: center;
    font-weight: 600;
    margin-top: 20px;
}

/* Apple-like animations and transitions */
.booking-card .card {
    background: linear-gradient(145deg, #ffffff, #f8f9fa);
    border: 1px solid rgba(255,255,255,0.8);
    box-shadow: 
        0 4px 16px rgba(0,0,0,0.08),
        0 1px 2px rgba(0,0,0,0.04),
        inset 0 1px 0 rgba(255,255,255,0.9);
    transition: transform 0.2s ease, box-shadow 0.3s ease;
    backdrop-filter: blur(10px);
}

.booking-card .card:hover {
    transform: translateY(-3px);
    box-shadow: 
        0 12px 32px rgba(0,0,0,0.15),
        0 4px 8px rgba(0,0,0,0.06),
        inset 0 1px 0 rgba(255,255,255,0.9);
}

/* Enhanced button animations */
.btn {
    transition: all 0.2s cubic-bezier(0.4, 0.0, 0.2, 1);
}

.btn:active {
    transform: scale(0.98);
}

/* Responsive improvements for mobile */
@media (max-width: 640px) {
    .booking-detail-container {
        padding: 16px 0;
    }
    
    .booking-header {
        margin-bottom: 24px;
    }
    
    .booking-header .title {
        font-size: 24px;
    }
    
    .cta {
        flex-direction: column;
        gap: 12px;
    }
    
    .btn {
        width: 100%;
        text-align: center;
        justify-content: center;
    }
    
    .detail-value {
        font-size: 15px;
    }
    
    .datetime-value {
        font-size: 16px;
    }
    /* FullCalendar mobile font sizing */
    .fc { font-size: 10px; }
    .fc table{font-size:1.2em;}
    .fc .fc-col-date{font-size:16px}
    .fc .fc-col-weekday{font-size:11px}
    .fc .fc-timegrid-slot-label-cushion, .fc .fc-col-header-cell-cushion { padding: 2px 4px; }
    .fc-timegrid-event .fc-event-time{font-size: 13px; white-space: break-spaces;}
    .fc .fc-toolbar.fc-header-toolbar {padding:0 20px;}

    
}

/* Admin navbar (mobile burger) */
.nav-toggle{appearance:none;-webkit-appearance:none;border:0;background:transparent;padding:8px;margin:0;display:none;align-items:center;justify-content:center;border-radius:8px;width:40px;height:40px}
.nav-toggle:focus{outline:none;box-shadow:0 0 0 3px rgba(17,17,17,.08)}
.nav-toggle span{display:block;width:22px;height:2px;background:#111;margin:3px 0;border-radius:2px;transition:transform .2s ease,opacity .2s ease}

@media (max-width: 640px){
  .nav-toggle{display:inline-flex; flex-direction: column;}
  .admin-nav .links{display:none;width:100%;flex-direction:column;gap:8px;padding:8px 0}
  .admin-nav.open .links{display:flex; padding: 20px;}
  .admin-nav .nav-wrap{flex-wrap:wrap; padding: 10px 20px;}
  tbody#meeting-tbody {
    white-space: nowrap;
}
}

/* Additional mobile-first improvements */
@media (max-width: 480px) {
    .container {
        padding: 0 12px;
    }
    
    .card {
        border-radius: 12px;
        margin: 0 -4px;
    }
    
    .card-body {
        padding: 20px 16px;
    }
}