/* ═══ PREROW PORTAL v3 ═══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --sand:#f5f0e8;--sand-light:#faf8f3;
  --ocean:#1a6b8a;--ocean-deep:#0e4a60;--ocean-light:#2a8fb3;
  --dune:#c4a66a;--dune-dark:#9e8450;
  --coral:#d4725c;--slate:#3d4a52;--slate-light:#6b7a85;
  --white:#ffffff;--bg:#f3f5f7;--border:#e2e5e9;
  --shadow:rgba(15,40,55,0.08);--shadow-md:rgba(15,40,55,0.12);
  --radius:8px;--radius-lg:12px;
  --sidebar-w:110px;--panel-w:400px;
  --font:'Segoe UI',system-ui,-apple-system,'Helvetica Neue',Arial,sans-serif;
  --font-display:Georgia,'Times New Roman',serif;
}
html,body{height:100%;font-family:var(--font);color:var(--slate);background:var(--sand-light);overflow:hidden;line-height:1.5;}

/* ─── BUTTONS ─── */
.btn-primary{padding:9px 20px;background:var(--ocean);color:#fff;border:none;border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;}
.btn-primary:hover{background:var(--ocean-deep);transform:translateY(-1px);box-shadow:0 3px 10px rgba(26,107,138,0.25);}
.btn-outline{padding:9px 16px;background:transparent;color:var(--ocean);border:1.5px solid var(--ocean);border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;}
.btn-outline:hover{background:var(--ocean);color:#fff;}
.btn-ghost{padding:7px 14px;background:transparent;color:var(--slate-light);border:none;font-family:var(--font);font-size:12px;cursor:pointer;transition:color .2s;text-decoration:none;display:inline-block;}
.btn-ghost:hover{color:var(--ocean);}
.btn-sm{padding:5px 10px;font-size:11px;}
.btn-del{width:28px;height:28px;border-radius:6px;border:none;background:#fee;color:var(--coral);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;}
.btn-del:hover{background:#fdd;}
.btn-close{width:32px;height:32px;border-radius:50%;border:none;background:#f0f0f0;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;}
.btn-close:hover{background:#e0e0e0;}
.btn-full{width:100%;}
.btn-danger{padding:6px 14px;background:#e74c3c;color:#fff;border:none;border-radius:var(--radius);font-size:11px;cursor:pointer;transition:background .2s;}
.btn-danger:hover{background:#c0392b;}

/* ─── FORMS ─── */
.form-group{margin-bottom:16px;}
.form-group label{display:block;font-size:11px;font-weight:600;color:var(--slate-light);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:5px;}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s;background:var(--white);}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--ocean);}
.form-group textarea{resize:vertical;min-height:72px;}
.form-row{display:flex;gap:14px;}
.form-row .form-group{flex:1;}
.form-actions{display:flex;gap:10px;margin-top:20px;}
.form-info-row{display:flex;gap:8px;align-items:center;margin-bottom:16px;padding:10px 14px;background:var(--sand-light);border-radius:var(--radius);font-size:13px;}
.form-info-label{font-weight:600;color:var(--slate-light);}
.form-card{padding:24px;}
.form-card h3{font-family:var(--font-display);font-size:18px;color:var(--ocean-deep);margin-bottom:20px;}

/* ─── EXTRA FIELDS ─── */
.extra-fields-section{margin-top:20px;padding-top:20px;border-top:2px solid var(--border);}
.extra-fields-title{font-size:12px;font-weight:700;color:var(--ocean);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:16px;display:flex;align-items:center;gap:8px;}
.extra-fields-title::after{content:'';flex:1;height:1px;background:var(--border);}
.hours-grid{display:flex;flex-direction:column;gap:6px;}
.hours-grid-row{display:flex;align-items:center;gap:10px;}
.hours-grid-day{width:90px;font-size:12px;font-weight:600;color:var(--slate-light);flex-shrink:0;}
.hours-grid-input{flex:1;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13px;outline:none;transition:border-color .2s;}
.hours-grid-input:focus{border-color:var(--ocean);}

/* ─── PHOTO UPLOAD ─── */
.photo-section{margin-top:20px;padding-top:20px;border-top:2px solid var(--border);}
.photo-section-title{font-size:12px;font-weight:700;color:var(--ocean);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:14px;display:flex;align-items:center;gap:8px;}
.photo-section-title::after{content:'';flex:1;height:1px;background:var(--border);}
.photo-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px;}
.photo-thumb{position:relative;width:100px;height:80px;border-radius:var(--radius);overflow:hidden;border:2px solid var(--border);transition:border-color .2s;}
.photo-thumb img{width:100%;height:100%;object-fit:cover;}
.photo-thumb:hover{border-color:var(--coral);}
.photo-thumb .photo-del{position:absolute;top:3px;right:3px;width:22px;height:22px;border-radius:50%;background:rgba(0,0,0,0.6);color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;}
.photo-thumb:hover .photo-del{opacity:1;}
.photo-drop{border:2px dashed var(--border);border-radius:var(--radius);padding:20px;text-align:center;cursor:pointer;transition:all .2s;background:var(--sand-light);}
.photo-drop:hover,.photo-drop.dragover{border-color:var(--ocean);background:#e8f4f8;}
.photo-drop input{display:none;}
.photo-drop p{font-size:12px;color:var(--slate-light);margin-top:4px;}
.photo-drop .drop-icon{font-size:28px;display:block;margin-bottom:4px;}
.upload-progress{margin-top:10px;display:none;}
.upload-progress.active{display:block;}
.progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden;}
.progress-bar-fill{height:100%;background:var(--ocean);border-radius:3px;width:0;transition:width .3s;}
.progress-text{font-size:11px;color:var(--slate-light);margin-top:4px;text-align:center;}

/* Popup photos */
.popup-photos{display:flex;gap:4px;margin-top:8px;overflow-x:auto;}
.popup-photos img{width:80px;height:60px;object-fit:cover;border-radius:4px;flex-shrink:0;}

/* ─── SHARED ─── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:40px;color:var(--slate-light);text-align:center;}
.empty-state p{font-size:13px;}
.toast{position:fixed;bottom:24px;right:24px;z-index:9999;padding:12px 24px;background:var(--ocean-deep);color:#fff;border-radius:var(--radius);font-size:13px;box-shadow:0 4px 16px var(--shadow-md);opacity:0;transform:translateY(10px);transition:all .3s;}
.toast.show{opacity:1;transform:translateY(0);}
.listing-badge{display:inline-block;margin-top:5px;padding:2px 10px;border-radius:4px;font-size:10px;font-weight:600;letter-spacing:0.3px;}
.badge-open{background:#e0f5e9;color:#2a7a4b;}
.badge-closed{background:#fde8e4;color:#c04030;}

/* ═══ LOGIN ═══ */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--ocean-deep) 0%,var(--ocean) 50%,var(--ocean-light) 100%);}
.login-wrap{width:100%;max-width:400px;padding:20px;}
.login-card{background:var(--white);border-radius:var(--radius-lg);padding:36px 32px;box-shadow:0 20px 60px rgba(0,0,0,0.2);}
.login-brand{text-align:center;margin-bottom:28px;}
.login-logo{font-size:40px;margin-bottom:8px;}
.login-brand h1{font-family:var(--font-display);font-size:28px;color:var(--ocean-deep);}
.login-brand span{font-size:13px;color:var(--slate-light);}
.login-error{background:#fde8e4;color:var(--coral);padding:10px 14px;border-radius:var(--radius);font-size:13px;margin-bottom:16px;}
.login-back{display:block;text-align:center;margin-top:16px;font-size:12px;color:var(--slate-light);text-decoration:none;}
.login-back:hover{color:var(--ocean);}

/* ═══ PUBLIC SIDEBAR – WEISS, BREITER ═══ */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--white);display:flex;flex-direction:column;z-index:1000;overflow-y:auto;overflow-x:hidden;border-right:1px solid var(--border);box-shadow:2px 0 12px var(--shadow);}
.sidebar::-webkit-scrollbar{width:0;}
.sidebar-logo{padding:14px 10px;text-align:center;border-bottom:1px solid var(--border);min-height:48px;}
.sidebar-logo img{max-width:80px;max-height:36px;}

.cat-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 6px;border:none;background:transparent;cursor:pointer;color:var(--slate);font-size:10px;font-family:var(--font);font-weight:500;transition:all .2s;text-align:center;line-height:1.25;text-decoration:none;width:100%;box-shadow:inset 3px 0 0 transparent;}
.cat-btn:hover{color:var(--ocean);background:var(--sand-light);}
.cat-btn.active{color:var(--ocean);background:#e8f4f8;box-shadow:inset 3px 0 0 var(--ocean);font-weight:600;}
.cat-btn svg{width:22px;height:22px;flex-shrink:0;display:block;margin:0 auto;}
.sidebar-bottom{margin-top:auto;border-top:1px solid var(--border);padding:6px 0;}

/* ═══ PANEL ═══ */
.panel{position:fixed;left:var(--sidebar-w);top:0;bottom:0;width:var(--panel-w);background:var(--white);z-index:900;display:flex;flex-direction:column;box-shadow:2px 0 20px var(--shadow);transform:translateX(-110%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
.panel.open{transform:translateX(0);}
.panel-header{padding:20px 22px 14px;border-bottom:1px solid var(--border);}
.panel-header h2{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--ocean-deep);}
.panel-search{margin-top:10px;}
.panel-search input{width:100%;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:var(--font);outline:none;transition:border-color .2s;}
.panel-search input:focus{border-color:var(--ocean);}
.subcats{display:flex;gap:6px;padding:10px 22px;border-bottom:1px solid #f0f0f0;flex-wrap:wrap;}
.subcat-chip{padding:5px 13px;border-radius:20px;border:1.5px solid var(--border);background:transparent;font-size:11px;font-family:var(--font);font-weight:500;cursor:pointer;transition:all .2s;color:var(--slate-light);}
.subcat-chip:hover{border-color:var(--ocean);color:var(--ocean);}
.subcat-chip.active{background:var(--ocean);color:#fff;border-color:var(--ocean);}
.panel-list{flex:1;overflow-y:auto;padding:4px 0;}
.panel-list::-webkit-scrollbar{width:5px;}
.panel-list::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px;}
.listing-card{display:flex;gap:12px;padding:14px 22px;cursor:pointer;transition:background .15s;border-bottom:1px solid #f5f5f5;}
.listing-card:hover{background:var(--sand-light);}
.listing-info{flex:1;min-width:0;}
.listing-info h3{font-size:14px;font-weight:600;color:var(--ocean-deep);margin-bottom:3px;}
.listing-info p{font-size:12px;color:var(--slate-light);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.listing-extra{display:block;font-size:11px;color:var(--ocean);margin-top:3px;font-weight:500;}
.listing-thumb{width:80px;height:65px;border-radius:var(--radius);background:var(--sand);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden;}
.listing-thumb img{width:100%;height:100%;object-fit:cover;}

/* ═══ MAP ═══ */
.map-wrap{position:fixed;top:0;bottom:0;right:0;left:var(--sidebar-w);transition:left .35s cubic-bezier(.4,0,.2,1);}
.map-wrap.shifted{left:calc(var(--sidebar-w) + var(--panel-w));}
#map{width:100%;height:100%;}
.custom-marker{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:700;box-shadow:0 2px 8px rgba(0,0,0,0.25);border:2.5px solid #fff;cursor:pointer;transition:transform .15s;}
.custom-marker:hover{transform:scale(1.15);}
.leaflet-popup-content-wrapper{border-radius:var(--radius-lg)!important;padding:0!important;box-shadow:0 4px 20px rgba(0,0,0,0.15)!important;}
.leaflet-popup-content{margin:0!important;width:300px!important;}
.popup-inner{padding:16px;}
.popup-inner h3{font-family:var(--font-display);font-size:16px;color:var(--ocean-deep);margin-bottom:6px;}
.popup-inner p{font-size:12px;color:var(--slate-light);line-height:1.5;margin-bottom:8px;}
.popup-inner .popup-cat{font-size:10px;color:var(--dune-dark);font-weight:600;text-transform:uppercase;letter-spacing:0.8px;margin-bottom:4px;}
.popup-inner .popup-meta{font-size:11px;color:var(--slate-light);margin-top:5px;}
.popup-inner .popup-meta a{color:var(--ocean);}
.popup-extra-row{font-size:12px;color:var(--slate);margin-top:6px;line-height:1.4;}
.popup-hours{display:flex;flex-wrap:wrap;gap:3px 12px;margin-top:8px;padding:8px 10px;background:var(--sand-light);border-radius:6px;}
.popup-hours .hours-row{font-size:11px;color:var(--slate-light);display:inline-block;white-space:nowrap;}
.popup-hours .hours-row b{color:var(--slate);margin-right:3px;}
.popup-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;}
.popup-tag{display:inline-block;padding:2px 8px;background:var(--ocean);color:#fff;border-radius:4px;font-size:10px;font-weight:500;}

/* ═══ ADMIN LAYOUT ═══ */
.admin-layout{display:flex;height:100vh;overflow:hidden;background:var(--bg);}
.admin-sidebar{width:220px;background:var(--white);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;}
.admin-brand{padding:20px;text-align:center;border-bottom:1px solid var(--border);}
.admin-logo{font-size:32px;}
.admin-brand h2{font-family:var(--font-display);font-size:22px;color:var(--ocean-deep);margin:4px 0 2px;}
.admin-brand small{font-size:11px;color:var(--slate-light);letter-spacing:1px;text-transform:uppercase;}
.admin-nav{padding:12px 10px;display:flex;flex-direction:column;gap:4px;}
.admin-nav-btn{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;border-radius:var(--radius);font-family:var(--font);font-size:13px;font-weight:500;color:var(--slate-light);cursor:pointer;transition:all .2s;text-align:left;}
.admin-nav-btn svg{width:18px;height:18px;flex-shrink:0;}
.admin-nav-btn:hover{background:var(--sand-light);color:var(--slate);}
.admin-nav-btn.active{background:var(--ocean);color:#fff;}
.admin-nav-btn.active svg{stroke:#fff;}
.admin-sidebar-bottom{margin-top:auto;padding:14px;border-top:1px solid var(--border);}
.admin-user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px;}
.admin-avatar{width:34px;height:34px;border-radius:50%;background:var(--ocean);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;}
.admin-user-info strong{font-size:13px;display:block;}
.admin-user-info small{font-size:11px;color:var(--slate-light);}
.admin-sidebar-actions{display:flex;gap:4px;flex-wrap:wrap;}
.admin-main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0;}
.admin-toolbar{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--border);background:var(--white);flex-shrink:0;}
.admin-toolbar h1{font-family:var(--font-display);font-size:20px;color:var(--ocean-deep);}
.toolbar-actions{display:flex;gap:10px;align-items:center;}
.toolbar-actions select{padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:var(--font);font-size:13px;}
.admin-tab{display:none;flex:1;flex-direction:column;overflow:hidden;min-height:0;}
.admin-tab.active{display:flex;}
.admin-content-split{flex:1;display:flex;overflow:hidden;min-height:0;}
.admin-list-col{width:380px;border-right:1px solid var(--border);overflow-y:auto;background:var(--white);min-height:0;}
.admin-form-col{flex:1;overflow-y:auto;background:var(--bg);min-height:0;}
.admin-entry{display:flex;align-items:center;gap:12px;padding:12px 18px;cursor:pointer;transition:background .15s;border-bottom:1px solid #f5f5f5;}
.admin-entry:hover{background:var(--sand-light);}
.admin-entry.active{background:#e8f4f8;border-left:3px solid var(--ocean);}
.admin-entry-icon{width:36px;height:36px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.admin-entry-info{flex:1;min-width:0;}
.admin-entry-info h4{font-size:13px;font-weight:600;color:var(--slate);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.admin-entry-info small{font-size:11px;color:var(--slate-light);display:block;}
.assigned-tag{color:var(--ocean)!important;font-weight:500;}
.user-stats{display:flex;gap:20px;padding:12px 0;border-top:1px solid var(--border);margin-top:8px;font-size:12px;color:var(--slate-light);}

/* ═══ MODAL ═══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:5000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-box{background:var(--white);border-radius:var(--radius-lg);display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 50px rgba(0,0,0,0.25);transform:scale(0.95);transition:transform .3s;}
.modal-overlay.open .modal-box{transform:scale(1);}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);}
.modal-header h3{font-size:15px;font-weight:600;}
.modal-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);}

/* ═══ RESPONSIVE ═══ */
@media(max-width:900px){
  :root{--sidebar-w:80px;--panel-w:300px;}
  .cat-btn{font-size:9px;padding:10px 4px;}
  .cat-btn svg{width:18px;height:18px;}
  .admin-sidebar{width:180px;}
  .admin-list-col{width:260px;}
}
@media(max-width:600px){
  :root{--sidebar-w:60px;--panel-w:260px;}
  .cat-btn span{display:none;}
  .admin-layout{flex-direction:column;}
  .admin-sidebar{width:100%;height:auto;flex-direction:row;align-items:center;}
  .admin-nav{flex-direction:row;}
  .admin-sidebar-bottom{display:none;}
  .admin-content-split{flex-direction:column;}
  .admin-list-col{width:100%;max-height:40vh;border-right:none;border-bottom:1px solid var(--border);}
  .modal-box{width:95vw!important;height:70vh!important;}
}
