/* ============================================================
   CLV PUBLIC CSS — Mobile-First v2.0
   ============================================================ */

:root {
    --clv-primary: #1e3a5f;
    --clv-primary-light: #2d5986;
    --clv-sea: #0369a1;
    --clv-sea-light: #0ea5e9;
    --clv-success: #22c55e;
    --clv-warning: #f59e0b;
    --clv-danger: #ef4444;
    --clv-dark: #1e293b;
    --clv-gray: #64748b;
    --clv-light: #f8fafc;
    --clv-border: #e2e8f0;
    --clv-radius: 10px;
    --clv-shadow: 0 2px 12px rgba(0,0,0,.08);
    --touch-target: 44px;
    font-size: 16px;
}

/* ===== BASE ===== */
.clv-public-wrap, .clv-weather-widget, .clv-booking-wrap, .clv-menu-wrap,
.clv-events-wrap, .clv-member-area, .clv-reservation-wrap {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: var(--clv-dark);
    -webkit-text-size-adjust: 100%;
}
* { box-sizing: border-box; }

/* ===== BUTTONS ===== */
.clv-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 7px;
    padding: 12px 22px; border-radius: 50px; font-size: .95rem;
    font-weight: 700; cursor: pointer; border: none; text-decoration: none;
    transition: all .2s; min-height: var(--touch-target); white-space: nowrap;
}
.clv-btn-primary   { background: var(--clv-primary); color: #fff; }
.clv-btn-primary:hover { background: var(--clv-primary-light); color: #fff; }
.clv-btn-secondary { background: #fff; color: var(--clv-primary); border: 2px solid var(--clv-primary); }
.clv-btn-secondary:hover { background: var(--clv-light); color: var(--clv-primary); }
.clv-btn-danger    { background: var(--clv-danger); color: #fff; }
.clv-btn-danger:hover { background: #dc2626; color: #fff; }
.clv-btn-large  { padding: 14px 28px; font-size: 1.05rem; }
.clv-btn-small  { min-height: 36px; padding: 8px 16px; font-size: .82rem; }
.clv-btn-block  { width: 100%; }
.clv-btn:disabled { opacity: .55; cursor: not-allowed; }

/* ===== FORM ===== */
.clv-form-group { margin-bottom: 18px; }
.clv-form-group label {
    display: block; font-weight: 700; margin-bottom: 6px;
    font-size: .87rem; color: var(--clv-dark);
}
.clv-input, .clv-select, .clv-textarea, .clv-form-group input, .clv-form-group select, .clv-form-group textarea {
    width: 100%; padding: 12px 14px; border: 2px solid var(--clv-border);
    border-radius: 10px; font-size: 1rem; transition: border .2s;
    background: #fff; color: var(--clv-dark); font-family: inherit;
    min-height: var(--touch-target);
}
.clv-input:focus, .clv-select:focus, .clv-textarea:focus,
.clv-form-group input:focus, .clv-form-group select:focus, .clv-form-group textarea:focus {
    border-color: var(--clv-sea); outline: none;
    box-shadow: 0 0 0 3px rgba(3,105,161,.12);
}
.clv-textarea, .clv-form-group textarea { min-height: 90px; resize: vertical; }
.clv-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .clv-form-row { grid-template-columns: 1fr; } }
.clv-form-actions { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 6px; }
.clv-form-group.clv-full { grid-column: 1 / -1; }

/* ===== ALERTS ===== */
.clv-alert {
    padding: 14px 18px; border-radius: 10px; margin-bottom: 18px;
    font-size: .9rem; display: flex; align-items: center; gap: 8px;
}
.clv-alert-success { background: #dcfce7; color: #15803d; border-left: 4px solid var(--clv-success); }
.clv-alert-error   { background: #fee2e2; color: #dc2626; border-left: 4px solid var(--clv-danger); }
.clv-alert-warning { background: #fef3c7; color: #92400e; border-left: 4px solid var(--clv-warning); }
.clv-alert-info    { background: #dbeafe; color: #1d4ed8; border-left: 4px solid var(--clv-sea); }
.clv-empty { color: var(--clv-gray); font-style: italic; text-align: center; padding: 32px; font-size: .95rem; }

/* ===== BADGES ===== */
.clv-badge {
    display: inline-block; padding: 3px 10px; border-radius: 20px;
    font-size: 12px; font-weight: 700;
}
.clv-status-confirmed       { background: #dcfce7; color: #15803d; }
.clv-status-pending         { background: #fef3c7; color: #92400e; }
.clv-status-checked_in      { background: #dbeafe; color: #1d4ed8; }
.clv-status-seated          { background: #f3e8ff; color: #7e22ce; }
.clv-status-completed       { background: #e0f2fe; color: #0369a1; }
.clv-status-cancelled_by_user, .clv-status-cancelled_by_staff { background: #f1f5f9; color: #64748b; }
.clv-status-no_show         { background: #fee2e2; color: #dc2626; }
.clv-status-expired         { background: #f1f5f9; color: #9ca3af; }

/* ===== WEATHER WIDGET ===== */
.clv-weather-widget {
    background: linear-gradient(135deg, #1e3a5f 0%, #0369a1 100%);
    color: #fff; border-radius: 16px; padding: clamp(18px, 4vw, 28px);
    box-shadow: 0 8px 30px rgba(0,0,0,.15); overflow: hidden;
}
.clv-weather-header { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; }
.clv-weather-header h3 { margin: 0; font-size: clamp(1rem, 3vw, 1.25rem); flex: 1; }
.clv-weather-updated { font-size: .75rem; opacity: .7; }
.clv-weather-current {
    display: grid; grid-template-columns: auto 1fr auto;
    gap: clamp(12px, 3vw, 20px); align-items: start;
}
@media (max-width: 600px) { .clv-weather-current { grid-template-columns: 1fr; } }
.clv-weather-main { text-align: center; padding: 8px; }
.clv-weather-big-icon { font-size: clamp(48px, 10vw, 64px); display: block; }
.clv-weather-temp { font-size: clamp(2rem, 8vw, 2.5rem); font-weight: 800; display: block; }
.clv-weather-desc { font-size: .85rem; opacity: .85; display: block; }
.clv-weather-details { display: flex; flex-direction: column; gap: 10px; }
.clv-weather-detail-item { display: flex; align-items: center; gap: 8px; font-size: .9rem; }
.clv-detail-icon { font-size: 1.25rem; width: 28px; flex-shrink: 0; }
.clv-detail-label { opacity: .75; min-width: 80px; font-size: .85rem; }
.clv-detail-value { font-weight: 700; }
.clv-activity-badge {
    padding: 12px 16px; border-radius: 10px; font-size: 1rem;
    font-weight: 700; text-align: center; margin-top: 8px;
}
.clv-weather-forecast { margin-top: 22px; }
.clv-weather-forecast h4 { margin: 0 0 12px; font-size: .9rem; opacity: .9; }
.clv-forecast-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
@media (max-width: 600px) { .clv-forecast-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 380px) { .clv-forecast-grid { grid-template-columns: repeat(3, 1fr); } }
.clv-forecast-day {
    background: rgba(255,255,255,.12); border-radius: 8px;
    padding: 8px 4px; text-align: center; font-size: .72rem;
}
.clv-forecast-date { display: block; font-weight: 700; margin-bottom: 3px; }
.clv-forecast-icon { font-size: 1.4rem; display: block; margin: 3px 0; }
.clv-temp-max { font-weight: 700; font-size: .82rem; }
.clv-temp-min { opacity: .65; font-size: .75rem; margin-left: 3px; }

/* ===== BOOKING FORM ===== */
.clv-booking-wrap { max-width: 680px; margin: 0 auto; padding: 0 16px; }
.clv-step-header { margin-bottom: 22px; }
.clv-step-header h2, .clv-step-header h3 { color: var(--clv-primary); margin-top: 0; font-size: clamp(1.1rem, 4vw, 1.4rem); }
.clv-step-header p { color: var(--clv-gray); font-size: .9rem; }
.clv-radio-group { display: flex; gap: 12px; flex-wrap: wrap; }
.clv-radio-label {
    display: flex; align-items: center; gap: 8px; cursor: pointer;
    font-weight: 700; padding: 12px 18px; border: 2px solid var(--clv-border);
    border-radius: 10px; transition: all .2s; flex: 1; min-height: var(--touch-target);
    font-size: .9rem;
}
.clv-radio-label:has(input:checked) { border-color: var(--clv-primary); background: #eff6ff; }
.clv-radio-label input { display: none; }
.clv-slots-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); gap: 10px; margin: 16px 0; }
.clv-slot-btn {
    padding: 14px 10px; border: 2px solid var(--clv-border); border-radius: 10px;
    text-align: center; cursor: pointer; background: #fff; transition: all .2s;
    font-size: .95rem; font-weight: 700; min-height: var(--touch-target);
}
.clv-slot-btn:hover, .clv-slot-btn.selected { border-color: var(--clv-primary); background: #eff6ff; color: var(--clv-primary); }
.clv-slot-btn.unavailable { background: #f3f4f6; color: #9ca3af; cursor: not-allowed; border-style: dashed; }
.clv-slot-time { font-size: 1.1rem; font-weight: 800; display: block; }
.clv-slot-avail { font-size: .7rem; margin-top: 3px; color: var(--clv-gray); }
.clv-booking-summary {
    background: #eff6ff; border-radius: 10px; padding: 16px;
    margin-bottom: 22px; border-left: 4px solid var(--clv-primary);
    font-size: .9rem;
}
.clv-back-btn {
    background: none; border: none; color: var(--clv-sea);
    cursor: pointer; font-size: .9rem; padding: 6px 0; min-height: var(--touch-target);
    display: inline-flex; align-items: center; gap: 4px; font-weight: 700;
}
.clv-step-indicator { display: flex; align-items: center; justify-content: center; margin-top: 24px; gap: 6px; }
.clv-step-dot {
    width: 34px; height: 34px; border-radius: 50%; border: 2px solid var(--clv-border);
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem; font-weight: 700; color: var(--clv-gray); background: #fff;
}
.clv-step-dot.active, .clv-step-dot.done { border-color: var(--clv-primary); background: var(--clv-primary); color: #fff; }
.clv-step-line { height: 2px; width: 32px; background: var(--clv-border); }
.clv-privacy-check { margin-bottom: 18px; font-size: .85rem; }
.clv-privacy-check label { display: flex; align-items: flex-start; gap: 10px; cursor: pointer; }
.clv-privacy-check input { margin-top: 3px; width: 18px; height: 18px; flex-shrink: 0; }
.clv-confirmation-box {
    text-align: center; padding: clamp(28px, 6vw, 48px);
    background: #f0fdf4; border-radius: 14px; border: 2px solid var(--clv-success);
}
.clv-confirm-icon { font-size: clamp(3rem, 10vw, 4rem); margin-bottom: 14px; display: block; }
.clv-confirm-code { font-size: 1.1rem; font-weight: 800; color: var(--clv-primary); }
.clv-confirm-email { color: var(--clv-gray); font-size: .85rem; margin-top: 8px; }

/* ===== MENU TODAY (+ domani) ===== */
.clv-menu-wrap { max-width: 960px; margin: 0 auto; padding: 0 16px; }

/* Tab oggi / domani */
.clv-menu-tabs {
    display: flex; gap: 6px; margin-bottom: 24px; border-bottom: 3px solid var(--clv-border);
}
.clv-menu-tab {
    padding: 10px 22px; border: none; background: transparent; cursor: pointer;
    font-size: .95rem; font-weight: 700; color: var(--clv-gray);
    border-bottom: 3px solid transparent; margin-bottom: -3px;
    border-radius: 8px 8px 0 0; transition: all .18s;
}
.clv-menu-tab:hover { color: var(--clv-primary); background: var(--clv-light); }
.clv-menu-tab.active { color: var(--clv-primary); border-bottom-color: var(--clv-primary); background: transparent; }
.clv-menu-panel { animation: clvFadeIn .2s ease; }
@keyframes clvFadeIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:none; } }
.clv-menu-day-heading {
    font-size: clamp(1rem,3.5vw,1.25rem); color: var(--clv-sea);
    margin-bottom: 20px; font-weight: 700;
}
.clv-menu-service { margin-bottom: 40px; }
.clv-menu-service-title {
    color: var(--clv-primary); border-bottom: 3px solid var(--clv-primary);
    padding-bottom: 8px; font-size: clamp(1.1rem, 4vw, 1.4rem);
}
.clv-menu-category { margin-bottom: 28px; }
.clv-menu-cat-title {
    color: var(--clv-dark); font-size: 1.05rem; font-weight: 800; margin-bottom: 14px;
    padding-left: 10px; border-left: 4px solid var(--clv-sea-light);
}
.clv-menu-items-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 14px; }
.clv-menu-item {
    background: #fff; border: 1px solid var(--clv-border); border-radius: 12px;
    padding: 16px; box-shadow: var(--clv-shadow); transition: all .2s;
}
.clv-menu-item:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.1); }
.clv-menu-item-soldout { opacity: .5; }
.clv-menu-item-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 6px; gap: 8px; }
.clv-menu-item-name { font-weight: 700; font-size: .95rem; color: var(--clv-dark); flex: 1; }
.clv-menu-item-price { font-weight: 800; color: var(--clv-primary); font-size: .95rem; white-space: nowrap; }
.clv-menu-item-desc { color: var(--clv-gray); font-size: .82rem; margin: 5px 0; line-height: 1.5; }
.clv-menu-allergens { font-size: .75rem; color: var(--clv-warning); margin-top: 6px; }
.clv-soldout-badge { background: #fee2e2; color: #991b1b; padding: 2px 8px; border-radius: 6px; font-size: .75rem; font-weight: 700; }
.clv-preorder-badge { background: #dcfce7; color: #15803d; padding: 2px 8px; border-radius: 6px; font-size: .75rem; }
.clv-menu-no-items { color: var(--clv-gray); font-style: italic; padding: 16px 0; }
.clv-menu-empty { text-align: center; padding: 40px 20px; color: var(--clv-gray); font-size: 1rem; }
.clv-menu-note { color: var(--clv-gray); font-size: .82rem; margin: 24px 0 12px; }

/* ===== EVENTS CALENDAR ===== */
.clv-events-wrap { max-width: 1100px; margin: 0 auto; padding: 0 16px; }
.clv-events-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 20px; }
.clv-event-card {
    background: #fff; border-radius: 14px; box-shadow: var(--clv-shadow);
    overflow: hidden; transition: all .2s;
}
.clv-event-card:hover { transform: translateY(-3px); box-shadow: 0 12px 32px rgba(0,0,0,.1); }
.clv-event-image {
    height: 150px; background-size: cover; background-position: center;
    background-color: var(--clv-primary);
}
.clv-event-body { padding: 18px; }
.clv-event-meta { margin-bottom: 8px; display: flex; gap: 5px; flex-wrap: wrap; }
.clv-event-type-badge { background: #dbeafe; color: #1d4ed8; padding: 2px 9px; border-radius: 20px; font-size: .72rem; font-weight: 700; }
.clv-members-badge { background: #fef3c7; color: #92400e; padding: 2px 9px; border-radius: 20px; font-size: .72rem; font-weight: 700; }
.clv-event-title { margin: 0 0 8px; font-size: 1rem; color: var(--clv-dark); font-weight: 800; }
.clv-event-datetime { font-size: .82rem; color: var(--clv-gray); margin-bottom: 6px; display: flex; gap: 10px; flex-wrap: wrap; }
.clv-event-location { font-size: .82rem; color: var(--clv-gray); margin-bottom: 10px; }
.clv-event-description { color: var(--clv-gray); font-size: .82rem; margin-bottom: 12px; line-height: 1.6; }
.clv-capacity-bar { height: 5px; background: #e2e8f0; border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.clv-capacity-fill { height: 100%; background: var(--clv-primary); border-radius: 3px; transition: width .4s; }
.clv-event-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 8px; }

/* ===== MODAL (pubblico) ===== */
.clv-modal {
    position: fixed; inset: 0; background: rgba(0,0,0,.6);
    z-index: 99999; display: flex; align-items: center; justify-content: center;
    padding: 16px; backdrop-filter: blur(4px);
}
.clv-modal-content {
    background: #fff; border-radius: 16px; padding: clamp(20px, 5vw, 32px);
    max-width: 500px; width: 100%; max-height: 90svh; overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.clv-modal h3 { margin: 0 0 16px; color: var(--clv-primary); font-size: 1.1rem; }
.clv-modal-subtitle { color: var(--clv-gray); font-size: .88rem; margin-top: -10px; margin-bottom: 16px; }

/* ===== MANAGE RESERVATION ===== */
.clv-reservation-wrap { max-width: 700px; margin: 0 auto; padding: 0 16px; }
.clv-reservation-card {
    background: #fff; border-radius: 14px; box-shadow: var(--clv-shadow); overflow: hidden;
}
.clv-reservation-header {
    background: linear-gradient(135deg, var(--clv-primary), var(--clv-sea));
    color: #fff; padding: clamp(18px, 4vw, 26px); display: flex;
    justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px;
}
.clv-reservation-header h2 { margin: 0; font-size: clamp(1rem, 4vw, 1.3rem); }
.clv-reservation-details { padding: clamp(16px, 4vw, 24px); }
.clv-detail-row {
    display: flex; justify-content: space-between; padding: 10px 0;
    border-bottom: 1px solid var(--clv-border); font-size: .9rem; gap: 8px;
    flex-wrap: wrap;
}
.clv-detail-row:last-child { border: none; }
.clv-detail-row > :first-child { color: var(--clv-gray); font-weight: 600; }
.clv-detail-row > :last-child { font-weight: 700; text-align: right; }
.clv-preorder-section {
    padding: clamp(16px, 4vw, 24px); background: var(--clv-light);
    border-top: 1px solid var(--clv-border);
}
.clv-preorder-section h3 { color: var(--clv-primary); margin-top: 0; font-size: 1.05rem; }
.clv-preorder-item {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 0; border-bottom: 1px solid var(--clv-border); flex-wrap: wrap;
}
.clv-preorder-name { flex: 1; font-weight: 700; font-size: .9rem; }
.clv-preorder-price { color: var(--clv-primary); font-weight: 800; }
.clv-allergy-mini { font-size: .72rem; color: var(--clv-warning); }
.clv-qty-control { display: flex; align-items: center; gap: 6px; }
.clv-qty-btn {
    width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--clv-primary);
    background: #fff; color: var(--clv-primary); cursor: pointer; font-size: 1.1rem;
    font-weight: 700; display: flex; align-items: center; justify-content: center;
}
.clv-qty-input { width: 44px; text-align: center; border: 2px solid var(--clv-border); border-radius: 8px; padding: 6px; font-size: .9rem; }
.clv-preorder-total { text-align: right; font-size: 1.1rem; font-weight: 800; padding: 14px 0; border-top: 2px solid var(--clv-border); margin-top: 10px; }
.clv-reservation-actions {
    padding: clamp(14px, 3vw, 20px); border-top: 1px solid var(--clv-border);
    display: flex; gap: 10px; flex-wrap: wrap;
}
.clv-order-table { width: 100%; border-collapse: collapse; font-size: .88rem; }
.clv-order-table td { padding: 8px; border-bottom: 1px solid var(--clv-border); }
.clv-order-total td { font-weight: 700; border-top: 2px solid var(--clv-border); border-bottom: none; }

/* ===== MEMBER AREA ===== */
.clv-member-area { max-width: 800px; margin: 0 auto; padding: 0 16px; }
.clv-member-header {
    display: flex; align-items: center; gap: 18px;
    background: linear-gradient(135deg, var(--clv-primary), var(--clv-sea));
    color: #fff; border-radius: 14px; padding: clamp(18px, 4vw, 28px);
    margin-bottom: 22px; flex-wrap: wrap;
}
.clv-member-avatar { font-size: clamp(2.5rem, 8vw, 3.5rem); }
.clv-member-info h2 { margin: 0; font-size: clamp(1.1rem, 4vw, 1.4rem); }
.clv-member-number, .clv-member-type { display: block; font-size: .85rem; opacity: .85; }
.clv-member-tabs { display: flex; gap: 4px; border-bottom: 2px solid var(--clv-border); margin-bottom: 22px; overflow-x: auto; scrollbar-width: none; }
.clv-member-tabs::-webkit-scrollbar { display: none; }
.clv-tab-btn {
    padding: 10px 18px; border: none; background: none; cursor: pointer;
    font-weight: 700; color: var(--clv-gray); border-bottom: 3px solid transparent;
    margin-bottom: -2px; transition: all .2s; white-space: nowrap;
    min-height: var(--touch-target); font-size: .88rem;
}
.clv-tab-btn.active { color: var(--clv-primary); border-bottom-color: var(--clv-primary); }
.clv-member-table { width: 100%; border-collapse: collapse; font-size: .85rem; }
.clv-member-table th, .clv-member-table td { padding: 10px; border-bottom: 1px solid var(--clv-border); }
.clv-member-table th { background: var(--clv-light); font-weight: 700; font-size: .8rem; text-transform: uppercase; color: var(--clv-gray); }
.clv-login-required {
    text-align: center; padding: clamp(32px, 8vw, 60px) 20px;
    background: var(--clv-light); border-radius: 14px;
}
.clv-login-required h3 { color: var(--clv-primary); margin: 0 0 10px; }
.clv-not-member { text-align: center; padding: 40px 20px; color: var(--clv-gray); }

/* ===== LOADING ===== */
.clv-loading {
    color: var(--clv-gray); text-align: center; padding: 22px;
    font-style: italic; font-size: .9rem;
}
.clv-loading::before { content: '⏳ '; }
.clv-spinner {
    width: 32px; height: 32px; border: 3px solid #e2e8f0;
    border-top-color: var(--clv-primary); border-radius: 50%;
    animation: clv-pub-spin .8s linear infinite; display: inline-block;
}
@keyframes clv-pub-spin { to { transform: rotate(360deg); } }
.clv-search-reservation { max-width: 400px; margin: 0 auto; text-align: center; padding: 40px 20px; }
.clv-search-reservation h2 { color: var(--clv-primary); }

/* ===== MOBILE OVERRIDES ===== */

/* Tablet ≤ 768px */
@media (max-width: 768px) {
    .clv-events-grid { grid-template-columns: 1fr; }
    .clv-menu-items-grid { grid-template-columns: 1fr; }
    .clv-member-header { flex-direction: row; }
}

/* Mobile ≤ 500px */
@media (max-width: 500px) {
    .clv-btn { padding: 12px 18px; font-size: .88rem; }
    .clv-slots-grid { grid-template-columns: repeat(3, 1fr); }
    .clv-radio-group { flex-direction: column; }
    .clv-member-header { flex-direction: column; align-items: flex-start; gap: 10px; }
    .clv-reservation-header { flex-direction: column; align-items: flex-start; }
    .clv-reservation-actions { flex-direction: column; }
    .clv-reservation-actions .clv-btn { width: 100%; }
    .clv-detail-row { flex-direction: column; gap: 4px; }
    .clv-detail-row > :last-child { text-align: left; }
}

/* Tutti i target toccabili ≥44px */
button, a.clv-btn, .clv-tab-btn, .clv-slot-btn, .clv-radio-label,
.clv-qty-btn, input[type="submit"], input[type="button"] {
    min-height: 44px;
}

/* ===== HOMEPAGE — DAY TABS ===== */
.clv-day-tabs {
    display: flex; gap: 6px; flex-wrap: wrap;
    margin: 0 0 18px; border-bottom: 2px solid var(--clv-border); padding-bottom: 0;
}
.clv-day-tab {
    padding: 10px 22px; border: none; background: none; cursor: pointer;
    font-weight: 700; font-size: .92rem; color: var(--clv-gray);
    border-bottom: 3px solid transparent; margin-bottom: -2px;
    transition: all .2s; min-height: var(--touch-target); border-radius: 8px 8px 0 0;
    white-space: nowrap;
}
.clv-day-tab:hover { color: var(--clv-primary); background: rgba(30,58,95,.04); }
.clv-day-tab.active { color: var(--clv-primary); border-bottom-color: var(--clv-primary); background: rgba(30,58,95,.06); }
.clv-day-panel { display: none; animation: clvFadeIn .3s ease; }
.clv-day-panel.active { display: block; }

/* ===== HOMEPAGE — SERVICE BLOCKS ===== */
.clv-svc-block {
    background: var(--clv-light); border: 1px solid var(--clv-border);
    border-radius: var(--clv-radius); padding: 20px; margin: 0 0 20px;
}
.clv-svc-title {
    display: flex; align-items: center; gap: 10px;
    color: var(--clv-primary); font-size: 1.1rem; font-weight: 700;
    margin: 0 0 14px; padding-bottom: 10px; border-bottom: 2px solid var(--clv-border);
}
.clv-svc-empty {
    text-align: center; padding: 28px 16px; color: var(--clv-gray);
    font-style: italic; font-size: .92rem;
}

/* ===== HOMEPAGE — CATEGORY BLOCKS ===== */
.clv-cat-block { margin: 0 0 16px; }
.clv-cat-title {
    font-size: .8rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
    color: var(--clv-sea); margin: 0 0 8px; display: flex; align-items: center; gap: 6px;
}
.clv-cat-title::after { content: ''; flex: 1; height: 1px; background: var(--clv-border); }
.clv-menu-item-card {
    display: flex; justify-content: space-between; align-items: flex-start;
    gap: 10px; padding: 10px 0; border-bottom: 1px dashed var(--clv-border);
}
.clv-menu-item-card:last-child { border-bottom: none; }
.clv-menu-item-name { font-weight: 600; font-size: .95rem; color: var(--clv-dark); }
.clv-menu-item-desc { font-size: .82rem; color: var(--clv-gray); margin-top: 2px; }
.clv-menu-item-badges { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 4px; }
.clv-badge {
    display: inline-block; padding: 2px 7px; border-radius: 50px;
    font-size: .7rem; font-weight: 700; letter-spacing: .04em;
}
.clv-badge-veg  { background: #dcfce7; color: #166534; }
.clv-badge-free { background: #fef3c7; color: #92400e; }
.clv-badge-spicy { background: #fee2e2; color: #991b1b; }
.clv-menu-item-price {
    font-weight: 700; color: var(--clv-sea); font-size: .92rem; white-space: nowrap;
    flex-shrink: 0;
}
.clv-menu-extras { font-size: .82rem; color: var(--clv-gray); margin-top: 10px; }
.clv-menu-note-inline {
    background: #fffbeb; border-left: 3px solid var(--clv-warning);
    padding: 10px 14px; border-radius: 0 8px 8px 0;
    font-size: .85rem; color: var(--clv-dark); margin-top: 12px;
}

/* ===== HOMEPAGE — BOOKING FORM INLINE ===== */
.clv-form-divider {
    display: flex; align-items: center; gap: 12px;
    color: var(--clv-gray); font-size: .8rem; text-transform: uppercase;
    letter-spacing: .08em; margin: 20px 0;
}
.clv-form-divider::before,
.clv-form-divider::after { content: ''; flex: 1; height: 1px; background: var(--clv-border); }

.clv-form-group-btn {
    display: flex; gap: 8px; align-items: stretch; flex-wrap: wrap;
}
.clv-form-group-btn input,
.clv-form-group-btn select { flex: 1 1 0; min-width: 120px; }
.clv-form-group-btn .clv-btn { flex-shrink: 0; }

.clv-btn-check {
    padding: 10px 16px; border-radius: 8px; font-size: .88rem; font-weight: 700;
    background: var(--clv-sea); color: #fff; border: none; cursor: pointer;
    transition: background .2s; min-height: var(--touch-target);
}
.clv-btn-check:hover { background: var(--clv-primary); }

/* ===== SLOTS ENHANCED ===== */
.clv-slot-btn {
    position: relative; padding: 10px 14px; border-radius: 8px;
    border: 2px solid var(--clv-border); background: #fff;
    cursor: pointer; font-size: .88rem; font-weight: 600; color: var(--clv-dark);
    transition: all .2s; display: flex; flex-direction: column;
    align-items: center; gap: 2px; min-height: 52px;
}
.clv-slot-btn:hover:not(:disabled) { border-color: var(--clv-sea); background: #f0f9ff; }
.clv-slot-btn.selected { border-color: var(--clv-primary); background: var(--clv-primary); color: #fff; }
.clv-slot-ok { font-size: .7rem; color: var(--clv-success); display: block; }
.clv-slot-btn.selected .clv-slot-ok { color: #a7f3d0; }
.clv-slot-no { font-size: .7rem; color: var(--clv-danger); display: block; }
.clv-slot-disabled {
    opacity: .45; cursor: not-allowed; background: #f8fafc; color: var(--clv-gray);
    border-color: var(--clv-border);
}
.clv-slot-disabled:hover { border-color: var(--clv-border); background: #f8fafc; }

/* ===== HOMEPAGE — FORM SUCCESS/ERROR ===== */
.clv-form-success {
    background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: var(--clv-radius);
    padding: 20px; text-align: center; color: #166534;
}
.clv-form-success h4 { color: #166534; margin: 0 0 6px; }
.clv-form-error {
    background: #fef2f2; border: 1px solid #fecaca; border-radius: var(--clv-radius);
    padding: 14px 16px; color: #991b1b; font-size: .9rem;
}

/* ===== HOMEPAGE — HERO & SECTIONS ===== */
.clvhp-hero {
    position: relative; overflow: hidden;
    min-height: clamp(280px, 50vw, 520px);
    display: flex; align-items: center; justify-content: center; text-align: center;
    background: linear-gradient(135deg, var(--clv-primary) 0%, var(--clv-sea) 60%, #0891b2 100%);
    color: #fff; padding: 60px 20px;
}
.clvhp-hero-bg {
    position: absolute; inset: 0; background-size: cover; background-position: center;
    opacity: .25; z-index: 0;
}
.clvhp-hero-content { position: relative; z-index: 1; max-width: 680px; }
.clvhp-hero-title {
    font-size: clamp(1.7rem, 5vw, 3rem); font-weight: 800; line-height: 1.15;
    margin: 0 0 14px; text-shadow: 0 2px 12px rgba(0,0,0,.35);
}
.clvhp-hero-subtitle {
    font-size: clamp(.95rem, 2.5vw, 1.18rem); opacity: .9; margin: 0 0 28px; line-height: 1.55;
}
.clvhp-hero-actions { display: flex; gap: 12px; flex-wrap: wrap; justify-content: center; }

.clvhp-section {
    padding: clamp(32px, 7vw, 72px) clamp(16px, 5vw, 40px);
    max-width: 1100px; margin: 0 auto;
}
.clvhp-section-title {
    font-size: clamp(1.3rem, 3.5vw, 2rem); font-weight: 800; color: var(--clv-primary);
    text-align: center; margin: 0 0 10px;
}
.clvhp-section-subtitle {
    text-align: center; color: var(--clv-gray); font-size: clamp(.9rem, 2vw, 1.05rem);
    margin: 0 0 36px; line-height: 1.6;
}
.clvhp-divider {
    display: flex; align-items: center; gap: 14px; color: var(--clv-sea);
    font-size: 1.2rem; margin: 0 auto 32px; justify-content: center;
}
.clvhp-divider::before,
.clvhp-divider::after { content: ''; width: 48px; height: 2px; background: var(--clv-sea); opacity: .4; }

.clvhp-features-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 22px; margin: 0 0 8px;
}
.clvhp-feature-card {
    background: #fff; border: 1px solid var(--clv-border); border-radius: 14px;
    padding: 26px 20px; text-align: center; box-shadow: var(--clv-shadow);
    transition: transform .2s, box-shadow .2s;
}
.clvhp-feature-card:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(0,0,0,.12); }
.clvhp-feature-icon { font-size: 2.2rem; margin: 0 0 12px; display: block; }
.clvhp-feature-card h3 { font-size: 1.05rem; color: var(--clv-primary); margin: 0 0 8px; }
.clvhp-feature-card p { font-size: .88rem; color: var(--clv-gray); line-height: 1.55; margin: 0; }

.clvhp-book-strip {
    background: linear-gradient(90deg, var(--clv-primary) 0%, var(--clv-sea) 100%);
    color: #fff; padding: clamp(28px, 6vw, 56px) clamp(16px, 5vw, 40px);
    text-align: center;
}
.clvhp-book-strip h2 { font-size: clamp(1.2rem, 3.5vw, 1.8rem); margin: 0 0 10px; }
.clvhp-book-strip p { opacity: .88; margin: 0 0 24px; font-size: clamp(.9rem, 2vw, 1rem); }

.clvhp-two-col {
    display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start;
}
@media (max-width: 800px) {
    .clvhp-two-col { grid-template-columns: 1fr; }
    .clvhp-hero-actions { flex-direction: column; align-items: center; }
    .clv-day-tab { padding: 8px 14px; font-size: .84rem; }
}
@media (max-width: 480px) {
    .clvhp-features-grid { grid-template-columns: 1fr; }
    .clv-form-group-btn { flex-direction: column; }
    .clv-form-group-btn .clv-btn { width: 100%; }
    .clv-menu-item-card { flex-direction: column; gap: 4px; }
    .clv-menu-item-price { align-self: flex-start; }
}

/* ===== HOMEPAGE — WEATHER STRIP ===== */
.clvhp-weather-strip {
    display: flex; align-items: center; justify-content: center; gap: 18px;
    flex-wrap: wrap; padding: 12px 20px;
    background: rgba(255,255,255,.08); backdrop-filter: blur(6px);
    border-radius: 50px; border: 1px solid rgba(255,255,255,.2);
    margin: 0 auto 24px; max-width: 520px; color: #fff; font-size: .92rem;
}
.clvhp-weather-strip .wi { font-size: 1.4rem; }

/* ===== HOMEPAGE — EVENTS PREVIEW ===== */
.clvhp-events-grid {
    display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 18px;
}
.clvhp-event-card {
    background: #fff; border: 1px solid var(--clv-border); border-radius: 12px;
    overflow: hidden; box-shadow: var(--clv-shadow); transition: transform .2s;
}
.clvhp-event-card:hover { transform: translateY(-2px); }
.clvhp-event-date-badge {
    background: var(--clv-primary); color: #fff; text-align: center;
    padding: 12px; font-size: .78rem; text-transform: uppercase; letter-spacing: .06em;
}
.clvhp-event-date-badge strong { display: block; font-size: 1.5rem; line-height: 1.1; }
.clvhp-event-info { padding: 14px 16px; }
.clvhp-event-info h4 { margin: 0 0 6px; font-size: .95rem; color: var(--clv-dark); }
.clvhp-event-info p { margin: 0; font-size: .82rem; color: var(--clv-gray); line-height: 1.5; }

/* ===== BOOKING INLINE — STEP INDICATOR ===== */
.clv-book-steps {
    display: flex; align-items: center; gap: 0; margin: 0 0 22px;
    counter-reset: step;
}
.clv-book-step {
    display: flex; align-items: center; gap: 8px; flex: 1;
    font-size: .8rem; font-weight: 700; color: var(--clv-gray);
}
.clv-book-step.active { color: var(--clv-primary); }
.clv-book-step.done { color: var(--clv-success); }
.clv-book-step-num {
    width: 26px; height: 26px; border-radius: 50%; border: 2px solid currentColor;
    display: flex; align-items: center; justify-content: center; font-size: .75rem;
    flex-shrink: 0; background: #fff; transition: all .2s;
}
.clv-book-step.active .clv-book-step-num { background: var(--clv-primary); color: #fff; }
.clv-book-step.done .clv-book-step-num { background: var(--clv-success); color: #fff; border-color: var(--clv-success); }
.clv-book-step-connector { flex: 1; height: 2px; background: var(--clv-border); margin: 0 4px; }

/* ===== ANIMATIONS ===== */
@keyframes clvFadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}
.clv-fade-in { animation: clvFadeIn .35s ease both; }
