/* ================================================================
   UL RV & Campsite Management — CSS
   ================================================================ */

/* ── Base ── */
.ul-rv-wrapper{max-width:1100px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:#333;}

/* ── Header ── */
.ul-rv-header{margin-bottom:24px;}
.ul-rv-header h2{font-size:24px;font-weight:700;color:#1a3a4a;margin:0 0 6px;}
.ul-rv-header p{font-size:14px;color:#666;margin:0 0 16px;}
.ul-rv-header-actions{display:flex;gap:10px;flex-wrap:wrap;}

/* ── Back Link ── */
.ul-rv-back-link{margin-bottom:16px;}
.ul-rv-back-link a{font-size:14px;color:#3b82f6;text-decoration:none;}
.ul-rv-back-link a:hover{text-decoration:underline;}

/* ── Buttons ── */
.ul-rv-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;border:none;transition:all 0.15s;}
.ul-rv-btn-primary{background:linear-gradient(135deg,#1a6da0,#134e73);color:#fff;}
.ul-rv-btn-primary:hover{background:linear-gradient(135deg,#1e7bb8,#165d87);color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,0.15);}
.ul-rv-btn-secondary{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0;}
.ul-rv-btn-secondary:hover{background:#e2e8f0;}
.ul-rv-btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;}
.ul-rv-btn-danger:hover{background:#fee2e2;}

/* ── Notices / Empty States ── */
.ul-rv-notice,.ul-rv-empty{text-align:center;padding:40px 20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;margin:20px 0;}
.ul-rv-notice h3{font-size:20px;color:#1a3a4a;margin:0 0 8px;}
.ul-rv-notice p,.ul-rv-empty p{font-size:14px;color:#666;margin:0 0 16px;}

/* ── Park Cards (list view) ── */
.ul-rv-park-card{display:block;padding:20px;margin-bottom:16px;border-radius:14px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff 0%,#fafcff 100%);text-decoration:none;color:#333;transition:all 0.2s;}
.ul-rv-park-card:hover{border-color:#bde0fe;box-shadow:0 4px 16px rgba(59,130,246,0.08);transform:translateY(-2px);color:#333;}
.ul-rv-park-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;}
.ul-rv-park-card-header h3{font-size:18px;font-weight:700;color:#1a3a4a;margin:0;}
.ul-rv-park-location{font-size:13px;color:#888;}
.ul-rv-park-stats{display:flex;gap:24px;margin-bottom:12px;}
.ul-rv-park-stat{display:flex;flex-direction:column;align-items:center;}
.ul-rv-stat-value{font-size:20px;font-weight:700;color:#1a3a4a;}
.ul-rv-stat-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:0.3px;}
.ul-rv-park-bar{display:flex;border-radius:4px;overflow:hidden;background:#f1f5f9;}

/* ── Status Bar ── */
.ul-rv-status-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px;}
.ul-rv-status-badge{font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;}

/* ── Rates Bar ── */
.ul-rv-rates-bar{display:flex;gap:16px;flex-wrap:wrap;padding:12px 16px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:20px;font-size:13px;color:#475569;}
.ul-rv-rates-bar strong{color:#1a3a4a;margin-right:4px;}

/* ── Spot Grid ── */
.ul-rv-spot-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:16px;}
.ul-rv-spot-card{position:relative;padding:16px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;text-align:center;cursor:pointer;transition:all 0.15s;}
.ul-rv-spot-card:hover{border-color:#bde0fe;box-shadow:0 4px 12px rgba(59,130,246,0.1);transform:translateY(-2px);}
.ul-rv-spot-status-dot{position:absolute;top:8px;right:8px;width:10px;height:10px;border-radius:50%;}
.ul-rv-spot-number{font-size:18px;font-weight:800;color:#1a3a4a;margin-bottom:4px;}
.ul-rv-spot-icon{font-size:22px;margin:4px 0;}
.ul-rv-spot-type{font-size:11px;color:#888;margin-bottom:4px;}
.ul-rv-spot-rate{font-size:13px;font-weight:600;color:#1a6da0;}
.ul-rv-spot-status{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px;margin-top:4px;}
.ul-rv-spot-length{font-size:10px;color:#999;margin-top:2px;}
.ul-rv-spot-hookups{display:flex;gap:4px;justify-content:center;margin-top:6px;font-size:14px;}

/* ── Detail Card ── */
.ul-rv-detail-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;}
.ul-rv-detail-row{display:flex;padding:12px 16px;border-bottom:1px solid #f1f5f9;}
.ul-rv-detail-row:last-child{border-bottom:none;}
.ul-rv-detail-label{width:160px;flex-shrink:0;font-size:13px;font-weight:600;color:#64748b;}
.ul-rv-detail-value{flex:1;font-size:13px;color:#1a3a4a;}

/* ── Section ── */
.ul-rv-section h3{font-size:18px;font-weight:700;color:#1a3a4a;margin:0 0 12px;}

/* ── Forms ── */
.ul-rv-form{max-width:700px;}
.ul-rv-form-section{margin-bottom:28px;padding:20px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;}
.ul-rv-form-section h3{font-size:16px;font-weight:700;color:#1a3a4a;margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid #e2e8f0;}
.ul-rv-form-note{font-size:12px;color:#888;margin:-8px 0 14px;}
.ul-rv-form-row{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap;}
.ul-rv-form-row label{display:flex;align-items:center;gap:6px;font-size:13px;color:#475569;cursor:pointer;}
.ul-rv-form-group{flex:1;min-width:140px;display:flex;flex-direction:column;margin-bottom:8px;}
.ul-rv-form-group label{font-size:13px;font-weight:600;color:#475569;margin-bottom:4px;}
.ul-rv-form-group input,.ul-rv-form-group select,.ul-rv-form-group textarea{padding:9px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;color:#333;background:#fff;transition:border 0.15s;}
.ul-rv-form-group input:focus,.ul-rv-form-group select:focus,.ul-rv-form-group textarea:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px rgba(59,130,246,0.1);}

/* ── Modals ── */
.ul-rv-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.4);z-index:99999;display:flex;align-items:center;justify-content:center;}
.ul-rv-modal-content{background:#fff;border-radius:16px;padding:28px;max-width:560px;width:90%;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 12px 40px rgba(0,0,0,0.2);}
.ul-rv-modal-close{position:absolute;top:12px;right:16px;font-size:28px;cursor:pointer;color:#999;line-height:1;}
.ul-rv-modal-close:hover{color:#333;}
.ul-rv-modal-content h3{font-size:18px;font-weight:700;color:#1a3a4a;margin:0 0 16px;}
.ul-rv-modal-content h4{font-size:14px;color:#475569;margin:0 0 8px;}

/* ── Responsive ── */
@media(max-width:768px){
    .ul-rv-spot-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;}
    .ul-rv-spot-card{padding:12px 8px;}
    .ul-rv-spot-number{font-size:15px;}
    .ul-rv-park-stats{gap:16px;}
    .ul-rv-stat-value{font-size:16px;}
    .ul-rv-header-actions{flex-direction:column;}
    .ul-rv-form-row{flex-direction:column;gap:8px;}
    .ul-rv-detail-row{flex-direction:column;gap:4px;}
    .ul-rv-detail-label{width:auto;}
    .ul-rv-booking-row{flex-direction:column;gap:4px;}
    .ul-rv-guest-row{flex-direction:column;gap:6px;}
}

/* ── Booking List ── */
.ul-rv-booking-list{display:flex;flex-direction:column;gap:2px;}
.ul-rv-booking-row{display:flex;align-items:center;gap:16px;padding:12px 16px;background:#fff;border:1px solid #f1f5f9;border-radius:8px;font-size:13px;transition:background 0.1s;}
.ul-rv-booking-row:hover{background:#f8fafc;}
.ul-rv-booking-dates{min-width:180px;color:#1a3a4a;}
.ul-rv-booking-guest{flex:1;}
.ul-rv-booking-guest a{color:#3b82f6;text-decoration:none;font-weight:600;}
.ul-rv-booking-guest a:hover{text-decoration:underline;}
.ul-rv-booking-rate{min-width:80px;text-align:right;font-weight:600;color:#1a3a4a;}
.ul-rv-booking-status{min-width:90px;text-align:right;font-weight:600;font-size:12px;text-transform:uppercase;}
.ul-rv-booking-actions{min-width:30px;text-align:right;}
.ul-rv-btn-sm{background:none;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;padding:2px 8px;font-size:14px;color:#999;transition:all 0.15s;}
.ul-rv-btn-sm:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626;}

/* ── Guest List ── */
.ul-rv-guest-list{display:flex;flex-direction:column;gap:2px;}
.ul-rv-guest-row{display:flex;align-items:center;gap:16px;padding:14px 16px;background:#fff;border:1px solid #f1f5f9;border-radius:8px;text-decoration:none;color:#333;transition:all 0.15s;}
.ul-rv-guest-row:hover{background:#f8fafc;border-color:#bde0fe;color:#333;}
.ul-rv-guest-name{min-width:200px;font-size:14px;color:#1a3a4a;}
.ul-rv-guest-meta{flex:1;display:flex;gap:12px;flex-wrap:wrap;font-size:12px;color:#888;}
.ul-rv-guest-stats{display:flex;gap:12px;font-size:12px;color:#64748b;}

/* ── Admin Dashboard ── */
.ul-rv-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;}
.ul-rv-admin-card{padding:18px;border-radius:12px;border:1px solid #e2e8f0;background:linear-gradient(180deg,#fff 0%,#fafcff 100%);text-align:center;}
.ul-rv-admin-card-value{font-size:24px;font-weight:800;color:#1a3a4a;line-height:1.2;}
.ul-rv-admin-card-label{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:0.3px;margin-top:4px;}

/* ── Tables ── */
.ul-rv-table{width:100%;border-collapse:collapse;font-size:13px;}
.ul-rv-table thead{background:#f8fafc;}
.ul-rv-table th{padding:10px 12px;text-align:left;font-weight:600;color:#475569;border-bottom:2px solid #e2e8f0;font-size:12px;text-transform:uppercase;letter-spacing:0.3px;}
.ul-rv-table td{padding:9px 12px;border-bottom:1px solid #f1f5f9;color:#333;}
.ul-rv-table tbody tr:hover{background:#f8fafc;}

/* ── Quick Tools Grid ── */
.ul-rv-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:12px;}
.ul-rv-quick-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:20px 14px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;text-decoration:none;color:#333;transition:all 0.2s;}
.ul-rv-quick-card:hover{border-color:#bde0fe;box-shadow:0 4px 16px rgba(59,130,246,0.08);transform:translateY(-2px);color:#333;}
.ul-rv-quick-emoji{font-size:36px;margin-bottom:10px;line-height:1;}
.ul-rv-quick-icon{width:44px;height:44px;margin-bottom:10px;object-fit:contain;}
.ul-rv-quick-card strong{font-size:14px;color:#1a3a4a;margin-bottom:2px;}
.ul-rv-quick-card span{font-size:12px;color:#888;}

@media(max-width:768px){
    .ul-rv-quick-grid{grid-template-columns:repeat(2,1fr);gap:10px;}
}

/* ── Help Drawer ── */
#ul-rv-help-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.4);z-index:99998;display:none;}
#ul-rv-help-overlay.open{display:block;}
#ul-rv-help-drawer{position:fixed!important;top:0;right:-520px;width:500px;max-width:92vw;height:100vh;background:#fff;z-index:99999!important;box-shadow:-4px 0 20px rgba(0,0,0,0.15);transition:right 0.3s ease;display:flex!important;flex-direction:column;overflow:hidden;}
#ul-rv-help-drawer.open{right:0;}
.ul-rv-help-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:linear-gradient(135deg,#1a3a4a 0%,#0f2736 100%);color:#fff;flex-shrink:0;}
.ul-rv-help-header h2{margin:0;font-size:16px;color:#fff;}
.ul-rv-help-header p{margin:2px 0 0;font-size:11px;color:rgba(170,221,255,0.7);}
.ul-rv-help-close{background:none;border:none;color:#fff;font-size:24px;cursor:pointer;padding:0 4px;line-height:1;}
.ul-rv-help-body{display:flex;flex:1;overflow:hidden;}
.ul-rv-help-nav{width:180px;background:#f8fafc;border-right:1px solid #e2e8f0;overflow-y:auto;flex-shrink:0;padding:8px 0;}
.ul-rv-help-nav-item{display:block;width:100%;text-align:left;padding:10px 16px;border:none;background:none;cursor:pointer;font-size:13px;color:#475569;transition:all 0.15s;}
.ul-rv-help-nav-item:hover{background:#e2e8f0;}
.ul-rv-help-nav-item.active{background:#fff;color:#1a3a4a;font-weight:700;border-right:3px solid #AADDFF;}
.ul-rv-help-content{flex:1;overflow-y:auto;padding:20px;}
.ul-rv-help-topic{display:none;}
.ul-rv-help-topic.active{display:block;}
.ul-rv-help-topic h3{margin:0 0 16px;font-size:18px;color:#1a3a4a;}
.ul-rv-help-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:14px 16px;margin-bottom:12px;}
.ul-rv-help-card h4{margin:0 0 8px;font-size:14px;color:#1a3a4a;}
.ul-rv-help-card p,.ul-rv-help-card ul{font-size:13px;color:#475569;line-height:1.6;margin:0;}
.ul-rv-help-card ul{padding-left:18px;margin-top:6px;}
.ul-rv-help-card li{margin-bottom:4px;}
.ul-rv-help-tip{background:#f0f7ff;border:1px solid #bde0fe;border-radius:8px;padding:12px 16px;margin-top:12px;font-size:13px;color:#1a3a4a;}
.ul-rv-help-tip strong{color:#1a6da0;}
.ul-rv-help-fab{position:fixed;bottom:24px;right:24px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#1a3a4a,#0f2736);color:#fff;font-size:22px;border:none;cursor:pointer;box-shadow:0 4px 16px rgba(0,0,0,0.2);z-index:99997;display:flex;align-items:center;justify-content:center;transition:transform 0.2s;}
.ul-rv-help-fab:hover{transform:scale(1.1);}
@media(max-width:600px){.ul-rv-help-nav{width:120px;}.ul-rv-help-nav-item{font-size:11px;padding:8px 10px;}}
