/* Basic responsive layout: sidebar + header + content */
:root{
  --font-family: 'Cairo', Inter, 'Segoe UI', Roboto, Arial, sans-serif;
  --primary-base: #FF6A00; /* main blue */
  --primary: linear-gradient(180deg,#FF6A00,#FF6A00);
  --primary-solid: #FF6A00;
  --primary-dark: #793300;
  --accent: #FF6A00;
  --success: #FF6A00;
  --warning: #FF6A00;
  --danger: #d32f2f;
  --neutral-bg: #f4f7fb;
  --card-bg: #ffffff;
  --muted: #6b7785;
  --text: #0b1724;
}
*{box-sizing:border-box}
body{font-family:var(--font-family);margin:0;background:var(--neutral-bg);color:var(--text);transition:background 0.3s ease}
.app{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.sidebar{padding:22px 18px;border-right:0;box-shadow:2px 0 30px rgba(16,24,40,0.06);background:linear-gradient(180deg,var(--primary-base),var(--primary-dark));color:#fff}
.sidebar h3{color:#fff;margin:0 0 18px;display:flex;align-items:center;gap:10px}
.sidebar .sidebar-brand{display:flex;align-items:center;gap:10px}
.sidebar .logo-small{width:44px;height:44px;border-radius:10px;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;color:#fff}
.header{background:transparent;padding:18px;border-bottom:0}
.content{padding:20px}
/* Header bar: notification icon and user chip */
.header-bar{display:flex;align-items:center;justify-content:space-between;gap:12px}
.header-right{display:flex;align-items:center;gap:14px}
.notif-link{display:inline-flex;align-items:center;gap:8px;color:var(--primary-base);text-decoration:none;position:relative;padding:6px;border-radius:8px}
.notif-link i{font-size:18px}
.notif-badge{position:absolute;top:4px;right:4px;min-width:18px;height:18px;line-height:18px;border-radius:999px;background:var(--danger);color:#fff;font-size:12px;text-align:center;padding:0 5px;box-shadow:0 4px 10px rgba(0,0,0,0.12)}
.user-chip{display:inline-flex;align-items:center;gap:10px;padding:6px 10px;border-radius:999px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 6px 18px rgba(16,24,40,0.04);border:1px solid rgba(11,23,36,0.04);cursor:pointer}
.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid rgba(11,23,36,0.04)}
.user-name{font-weight:700;color:var(--text);font-size:14px}
.small-caret{color:var(--muted);font-size:12px}

@media(max-width:720px){
  .user-name{display:none}
  .user-chip{padding:6px}
}

/* notifications dropdown */
.notif-dropdown{position:absolute;right:0;top:44px;width:320px;background:#fff;border:1px solid rgba(11,23,36,0.06);box-shadow:0 18px 60px rgba(9,30,66,0.08);border-radius:8px;overflow:hidden;z-index:9999}
.notif-dropdown #notif-list{max-height:320px;overflow:auto}
.notif-dropdown ul{margin:0;padding:0}
.notif-dropdown li a{display:block;padding:8px 10px;color:var(--text);text-decoration:none}
.notif-dropdown li a:hover{background:linear-gradient(90deg,#fff,#fbfdff)}
/* Ensure main column stacks header, content and footer; content grows so footer stays at bottom */
.app > div{display:flex;flex-direction:column;min-height:100vh}
.content{flex:1}
.nav-item{display:block;padding:10px 12px;color:rgba(255,255,255,0.92);text-decoration:none;border-radius:8px;margin-bottom:8px;transition:all 0.22s cubic-bezier(.2,.9,.2,1)}
.nav-item:hover{background:rgba(255,255,255,0.06);color:#fff;transform:translateX(6px)}
.nav-item i{margin-right:10px;color:rgba(255,255,255,0.95)}
.nav-item.active{background:rgba(255,255,255,0.12);box-shadow:inset 3px 0 0 rgba(255,255,255,0.18)}
.card{background:var(--card-bg);padding:18px;border-radius:12px;box-shadow:0 8px 30px rgba(9,30,66,0.06);transition:box-shadow 0.28s ease,transform 0.28s ease}
.card:hover{box-shadow:0 18px 50px rgba(9,30,66,0.09);transform:translateY(-4px)}
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid #eee;text-align:left}
.btn{display:inline-block;padding:10px 14px;border-radius:10px;background:linear-gradient(90deg,var(--primary-base),var(--accent));color:#fff;text-decoration:none;border:none;cursor:pointer;transition:all 0.22s ease}
.btn:hover{filter:brightness(.98);transform:translateY(-2px);box-shadow:0 14px 40px rgba(30,136,229,0.18)}
.btn.secondary{background:#6c757d}
.btn.secondary:hover{background:#5a6268}
.muted{color:var(--muted);font-size:13px}

@media(max-width:900px){
  .app{grid-template-columns:1fr}
  .sidebar{order:2}
}

/* Dashboard extras */
.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.stat{display:flex;gap:16px;align-items:center;padding:18px;border-radius:14px;background:linear-gradient(180deg,#fff,#fbfdff);box-shadow:0 18px 60px rgba(9,30,66,0.06);transition:transform 0.28s ease, box-shadow 0.28s ease}
.stat:hover{transform:translateY(-8px);box-shadow:0 30px 80px rgba(9,30,66,0.08)}
.stat .stat-icon{flex:0 0 64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:22px}
.stat h3{margin:0 0 6px;font-size:15px;color:var(--muted)}
.stat .value{font-size:30px;font-weight:700;margin-top:4px;color:var(--primary-dark)}
.stat-primary .stat-icon{background:linear-gradient(135deg,var(--primary-base),var(--accent))}
.stat-accent .stat-icon{background:linear-gradient(135deg,#FF6A00,#FF6A00)}
.stat-success .stat-icon{background:linear-gradient(135deg,#FF6A00,#FF6A00)}
/* Add matching backgrounds for info and warning stat icons */
.stat-info .stat-icon{background:linear-gradient(135deg,var(--primary-base),var(--accent))}
.stat-warning .stat-icon{background:linear-gradient(135deg,var(--primary-base),var(--accent))}

/* Ensure inline SVGs inherit the icon color and size consistently */
.stat-icon svg{width:28px;height:28px;display:block;color:inherit;fill:currentColor;stroke:currentColor}

/* Range controls for dashboard charts */
.range-controls{display:inline-flex;gap:8px}
.range-btn{padding:8px 12px;border-radius:8px;border:1px solid rgba(11,23,36,0.06);background:transparent;color:var(--muted);cursor:pointer}
.range-btn:hover{background:rgba(255,106,0,0.08)}
.range-btn.active{background:linear-gradient(135deg,var(--primary-base),var(--accent));color:#fff;border:none}
.range-btn:focus{outline:none;box-shadow:0 6px 18px rgba(255,106,0,0.12)}

/* Quick Links / Quick Actions */
.quick-links{margin-top:20px}
.quick-links h4{margin:0 0 12px;display:flex;align-items:center;gap:10px;font-size:16px}
.quick-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.quick-card{display:flex;gap:12px;align-items:center;padding:14px;border-radius:12px;background:linear-gradient(90deg,#fff,#fbfdff);box-shadow:0 12px 36px rgba(9,30,66,0.04);text-decoration:none;color:var(--text);transition:transform 0.18s ease,box-shadow 0.18s ease}
.quick-card:hover{transform:translateY(-6px);box-shadow:0 30px 60px rgba(9,30,66,0.08)}
.qc-icon{width:56px;height:56px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px}
.qc-icon .fas{font-size:20px}
.qc-body strong{display:block}
.qc-body .muted{font-size:13px;color:var(--muted)}
.quick-card:nth-child(1) .qc-icon{background:linear-gradient(135deg,var(--primary-base),var(--accent))}
.quick-card:nth-child(2) .qc-icon{background:linear-gradient(135deg,#FF6A00,#FF6A00)}
.quick-card:nth-child(3) .qc-icon{background:linear-gradient(135deg,#FF6A00,#FF6A00)}
.user-info{float:right;color:#fff;display:flex;align-items:center;gap:10px}
.user-info i{font-size:18px;opacity:0.95}

/* Login page styles (centralized) */
.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:28px;background:linear-gradient(135deg,var(--primary) 0%, #42a5f5 100%)}
.login-card{width:100%;max-width:460px;padding:28px;border-radius:12px;background:linear-gradient(180deg,#ffffff 0%, #fbfdff 100%);box-shadow:0 18px 50px rgba(9,30,66,0.12);position:relative;overflow:hidden}
.brand{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.brand .logo{width:56px;height:56px;border-radius:10px;background:var(--primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}
.login-card h2{margin:0 0 6px;font-size:20px;color:#172b4d}
.login-card .muted{color:#65748b}
.alert{padding:10px 12px;border-radius:8px;margin-bottom:12px;font-size:14px}
.alert-error{background:#fff4f4;border:1px solid #ffd2d2;color:#8a1f1f}
.form-row{margin-bottom:14px}
.form-row label{display:block;margin-bottom:6px;font-size:14px;color:#f27a1a}
.input-wrap{position:relative}
.input-wrap input[type="email"], .input-wrap input[type="password"], .input-wrap input[type="text"], .input-wrap input[type="tel"]{width:100%;padding:12px 56px 12px 44px;border:1px solid #e6e9ef;border-radius:8px;background:#fff;transition:box-shadow 0.15s ease,border-color 0.15s ease;height:44px;line-height:20px;font-size:15px}
.input-wrap input:focus{outline:none;border-color:var(--primary-solid);box-shadow:0 10px 30px rgba(30,136,229,0.12)}
.input-wrap .icon-left{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--primary-base);font-size:16px;line-height:1;pointer-events:none}

/* toggle (right) */
.toggle-pass{position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--primary-base);cursor:pointer;font-size:16px;z-index:50;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:rgba(255,255,255,0.06);border-radius:8px}
/* focus styles for toggle */
.toggle-pass:focus{outline:none;box-shadow:0 0 0 4px rgba(30,136,229,0.12);border-radius:8px}

/* form actions (align links and button) */
.form-actions{display:flex;justify-content:space-between;align-items:center;margin-top:12px}
.form-actions .forgot-link{font-size:14px}
.login-card .forgot-link{color:#65748b;text-decoration:none;font-size:14px}
.login-card .forgot-link:hover{text-decoration:underline}
.btn.primary{background:var(--primary)}
.btn.primary:hover{background:#b74d01}

@media(max-width:520px){
  .login-card{padding:20px;border-radius:10px}
  .brand .logo{width:48px;height:48px}
}

/* Extended form styles for module forms (Properties, Users, Roles) */
.form-card{max-width:920px;margin:0 auto}
.form-row{display:flex;flex-direction:column;margin-bottom:14px}
.form-row > label{font-weight:600;font-size:14px;color:#f27a1a;margin-bottom:6px}
.input-wrap{position:relative;display:flex;align-items:center}
.input-wrap .icon-left{position:absolute;left:12px;color:var(--muted);font-size:14px}
.input-wrap input[type="text"],
.input-wrap input[type="number"],
.input-wrap input[type="password"],
.input-wrap input[type="file"],
.input-wrap input[type="email"],
.input-wrap textarea,
.input-wrap select{
  width:100%;padding:10px 12px;border:1px solid rgba(34,51,68,0.06);border-radius:8px;background:var(--card-bg);font-size:14px;color:var(--text);transition:border-color .12s ease,box-shadow .12s ease
}
.input-wrap input[type="file"]{padding:6px 10px}
.input-wrap textarea{min-height:88px;resize:vertical}
.input-wrap input:focus,.input-wrap textarea:focus,.input-wrap select:focus{outline:none;border-color:var(--primary-solid);box-shadow:0 8px 30px rgba(30,136,229,0.06)}
.form-actions{display:flex;gap:10px;margin-top:8px}
.btn.primary{background:linear-gradient(90deg,var(--primary-base),var(--accent));color:#fff;border:none;padding:10px 14px;border-radius:8px;cursor:pointer}
.btn.primary:hover{filter:brightness(.98)}

/* Make file inputs look consistent */
input[type="file"]{font-size:14px}

@media(max-width:720px){
  .form-card{padding:12px}
}

/* Unified input/icon spacing: ensure left icons don't overlap text */
.input-wrap{position:relative}
.input-wrap .icon-left{position:absolute;left:14px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--muted);font-size:15px}
.input-wrap input[type="text"],
.input-wrap input[type="number"],
.input-wrap input[type="password"],
.input-wrap input[type="email"],
.input-wrap input[type="tel"],
.input-wrap textarea,
.input-wrap select{
  padding-left:44px !important;
}

/* Ensure date/time inputs visually match other inputs and align with left icons */
.input-wrap input[type="datetime-local"],
.input-wrap input[type="date"],
.input-wrap input[type="time"]{
  width:100%;
  padding:10px 12px;
  padding-left:44px !important;
  height:44px;
  line-height:20px;
  border:1px solid rgba(11,23,36,0.06);
  border-radius:8px;
  background:var(--card-bg);
  box-shadow:0 6px 18px rgba(16,24,40,0.04);
  font-size:14px;
  color:var(--text);
  -webkit-appearance: textfield;
  appearance: textfield;
}

/* On some browsers the native date/time control shows an inner calendar icon; ensure it doesn't overlap left icon */
.input-wrap input[type="datetime-local"]::-webkit-calendar-picker-indicator,
.input-wrap input[type="date"]::-webkit-calendar-picker-indicator,
.input-wrap input[type="time"]::-webkit-calendar-picker-indicator{
  padding:0 6px; /* keep clickable area */
}

/* Icon + control alignment fixes
   - Ensure the left icon is consistently sized and vertically centered
   - Move small controls (checkboxes) right so they don't overlap the icon
   - Keep selects and text-like inputs using left padding so icon sits inside the input area
*/
.input-wrap .icon-left{left:12px;color:var(--muted);font-size:14px}
.input-wrap .icon-left i{display:inline-block;line-height:1}
.form-row label i{margin-left:6px;vertical-align:middle;color:var(--muted);font-size:14px}
.input-wrap input[type="checkbox"]{margin-left:8px;vertical-align:middle;width:auto;height:auto}
.input-wrap input[type="checkbox"]:focus{outline:none}
.input-wrap input[type="checkbox"]{transform:translateY(-1px)}

@media(max-width:520px){
  .input-wrap input[type="checkbox"]{margin-left:6px}
  .form-row label i{margin-left:4px}
}

/* small adjustment for file inputs to avoid clipped name */
.input-wrap input[type="file"]{padding-left:12px !important}

/* Inline row for grouped fields (area, bedrooms, bathrooms) */
/* Stronger rules to keep Area / Bedrooms / Bathrooms side-by-side */
.form-row.inline-row{display:flex !important;flex-direction:row !important;gap:14px !important;align-items:flex-start}
.form-row.inline-row > .form-field{flex:1 1 0 !important;display:flex;flex-direction:column;min-width:0 !important}
.form-row.inline-row .form-field .input-wrap{width:100%}
.form-row.inline-row .form-field label{margin-bottom:6px}

@media(max-width:720px){
  .form-row.inline-row{flex-direction:column !important}
  .form-row.inline-row > .form-field{flex:1 1 100%}
}

/* Modern form look */
.form-card{background:linear-gradient(180deg,#ffffff, #fbfdff);padding:22px;border-radius:14px}
.section-title{display:flex;align-items:center;gap:12px;margin:18px 0 10px}
.section-title .dot{width:12px;height:12px;border-radius:50%}
.section-title h4{margin:0;font-size:16px}
.section-title.color-1 .dot{background:linear-gradient(45deg,var(--primary-base),var(--accent))}
.section-title.color-2 .dot{background:linear-gradient(45deg,#FF6A00,#FF6A00)}
.section-title.color-3 .dot{background:linear-gradient(45deg,#6dd3ff,#42a5f5)}
.section-title.color-4 .dot{background:linear-gradient(45deg,#66bb6a,#2e7d32)}

/* Inputs: modern rounded fields */
.input-wrap input[type="text"],
.input-wrap input[type="number"],
.input-wrap input[type="email"],
.input-wrap input[type="tel"],
.input-wrap textarea,
.input-wrap select{
  border:1px solid rgba(11,23,36,0.06);
  box-shadow:0 6px 18px rgba(16,24,40,0.04);
}

/* Image preview grid */
.image-preview-grid{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.image-thumb{width:110px;height:80px;border-radius:8px;overflow:hidden;border:1px solid #eef;background:#fff;position:relative;box-shadow:0 6px 18px rgba(16,24,40,0.04);display:flex;align-items:center;justify-content:center}
.image-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.image-thumb .meta{position:absolute;left:6px;bottom:6px;background:rgba(0,0,0,0.45);color:#fff;padding:3px 6px;border-radius:6px;font-size:12px}
.image-thumb .remove-btn{position:absolute;right:6px;top:6px;background:rgba(255,255,255,0.9);border-radius:6px;border:none;width:26px;height:26px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.image-thumb .remove-btn i{color:#c0392b}

/* responsive tweaks */
@media(max-width:520px){
  .image-thumb{width:90px;height:70px}
}

/* Action icon buttons used in tables */
.action-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;margin-right:8px;text-decoration:none;color:#fff;font-size:14px;box-shadow:0 8px 22px rgba(9,30,66,0.06);transition:transform .12s ease,box-shadow .12s ease}

/* Properties - Features section (custom checkbox list) */
.features-section{border-top:1px solid rgba(11,23,36,0.06);padding-top:16px;margin-top:12px}
.features-title{color:#f27a1a;font-weight:700;font-size:18px;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.features-list{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.feature-item{position:relative;padding-left:28px;cursor:pointer;user-select:none;display:inline-flex;align-items:center;gap:8px;font-size:14px;color:#0b1714}
.feature-item input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}
.feature-item .checkmark{position:absolute;left:0;top:0;height:18px;width:18px;border:1px solid #f27a1a;border-radius:6px;background:#fff}
.feature-item .checkmark:after{content:"";position:absolute;display:none;left:6px;top:2px;width:5px;height:9px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}
.feature-item input:checked ~ .checkmark{background:#f27a1a}
.feature-item input:checked ~ .checkmark:after{display:block}
.feature-label{display:inline-block;padding-left:2px}
.features-section .muted{font-size:13px;color:rgba(11,23,36,0.5);margin-left:6px}

/* Keep Type / Status / Payment Method on one line when possible */
/* Use grid to force three columns and override inline flex styles */
.form-row.three-selects{display:grid !important;grid-template-columns:repeat(3,minmax(0,1fr)) !important;gap:12px;align-items:start}
.form-row.three-selects > div{width:100% !important;min-width:0 !important}
.form-row.three-selects label{margin-bottom:6px;display:block}
.form-row.three-selects .input-wrap{width:100%}
.form-row.three-selects select{width:100%;box-sizing:border-box}

/* responsive: stack to a single column on smaller screens */
@media (max-width:920px){
  .form-row.three-selects{grid-template-columns:repeat(1,minmax(0,1fr)) !important}
}

/* Price & Payment side-by-side (one flexible column + fixed 220px column) */
.form-row.price-payment{display:grid !important;grid-template-columns:1fr 220px;gap:12px;align-items:start}
.form-row.price-payment .price-field .input-wrap{width:100%}
.form-row.price-payment .payment-field .input-wrap{width:100%}
@media (max-width:720px){
  .form-row.price-payment{grid-template-columns:1fr !important}
}

/* Generic two-column form grid for create/edit pages */
.form-card .form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}
.form-card .form-grid .form-row{margin-bottom:0}
.form-card .form-grid .full{grid-column:1 / -1}
@media(max-width:900px){
  .form-card .form-grid{grid-template-columns:1fr}
}
.action-btn i{pointer-events:none}
.action-btn.view{background:linear-gradient(135deg,var(--primary-base),var(--accent));}
.action-btn.view:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(30,136,229,0.16)}
.action-btn.edit{background:linear-gradient(135deg,#FF6A00,#c35100)}
.action-btn.edit:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(90,107,255,0.16)}
.action-btn.delete{background:linear-gradient(135deg,#ff7b7b,#ff4d4d)}
.action-btn.delete:hover{transform:translateY(-3px);box-shadow:0 14px 40px rgba(255,77,77,0.16)}

/* Reduce table cell padding for actions column */
table td .action-btn:last-child{margin-right:0}

/* Property view styles */
.property-view{padding:18px}
.pv-title{margin:6px 0 14px}
.pv-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:6px}
.pv-subtitle{display:flex;gap:12px;align-items:center;color:var(--muted);margin-bottom:12px}
.pv-subtitle .meta-item{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(180deg,#fff,#fbfdff);padding:8px 10px;border-radius:8px;box-shadow:0 8px 24px rgba(9,30,66,0.04);font-weight:600}
.pv-grid{display:grid;grid-template-columns:360px 1fr;gap:18px}
.pv-media{display:flex;flex-direction:column;gap:12px}
.pv-main-btn{border:0;padding:0;background:transparent;cursor:pointer;border-radius:10px;overflow:hidden}
.pv-main-img{width:100%;height:260px;object-fit:cover;border-radius:10px;display:block}
.pv-gallery{display:flex;flex-wrap:wrap;gap:8px}
.pv-thumb{width:80px;height:60px;border:0;padding:0;background:transparent;cursor:pointer;border-radius:6px;overflow:hidden}
.pv-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.pv-noimg{width:100%;height:260px;display:flex;align-items:center;justify-content:center;background:#f5f7fb;border-radius:10px;color:var(--muted)}

.pv-details{padding:14px}
.pv-meta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.pv-meta div{display:flex;align-items:center;gap:8px;background:linear-gradient(180deg,#fff,#fbfdff);padding:8px 10px;border-radius:8px;box-shadow:0 8px 24px rgba(9,30,66,0.04)}
.pv-meta .meta-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;color:var(--primary-base);font-size:14px;background:linear-gradient(135deg,rgba(30,136,229,0.06),rgba(66,165,245,0.04))}
.pv-stats{display:flex;gap:12px;margin-bottom:12px}
.pv-stats div{display:flex;align-items:center;gap:8px;background:rgba(15,23,42,0.02);padding:8px 10px;border-radius:8px}
.pv-stats .meta-icon{width:20px;height:20px;border-radius:6px;color:#FF6A00;background:transparent;font-size:13px}
.pv-contact{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.pv-contact .meta-icon{color:var(--primary-base);width:22px;height:22px;background:transparent}
.pv-desc h4{margin-top:0}

/* Activity / Timeline styles (CRM-style) */
.activity-panel{padding:0}
.activity-actions{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.activity-filters{display:flex;gap:8px;align-items:center}
.activity-filters select{padding:8px 10px;border-radius:8px;border:1px solid rgba(11,23,36,0.06);background:#fff}
.timeline{border-left:3px solid rgba(11,23,36,0.04);padding-left:14px;margin-top:8px}
.activity-item{position:relative;padding:12px 14px 12px 22px;margin-bottom:12px;background:linear-gradient(180deg,#fff,#fbfdff);border-radius:10px;box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.activity-item:before{content:"";position:absolute;left:-23px;top:18px;width:12px;height:12px;border-radius:50%;background:#fff;border:3px solid var(--primary-base);box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.activity-avatar{float:left;width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary-base),var(--accent));color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;margin-right:12px}
.activity-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.activity-user{font-weight:700}
.activity-time{color:var(--muted);font-size:12px}
.activity-text{margin-top:8px;white-space:pre-wrap}
.activity-badge{display:inline-block;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:700}
.activity-badge.note{background:linear-gradient(90deg,#eef6ff,#fbfdff);color:#0b6aa8}
.activity-badge.comment{background:linear-gradient(90deg,#f7f7fb,#fff);color:#6b7785;border:1px solid rgba(11,23,36,0.04)}
.activity-badge.task{background:linear-gradient(90deg,#fff7e6,#fffaf5);color:#b85a00}
.activity-badge.visit{background:linear-gradient(90deg,#eefef6,#f6fff9);color:#0b7a3a;border:1px solid rgba(11,23,36,0.04)}
.activity-badge.communication{background:linear-gradient(90deg,#fff6fb,#fffafc);color:#8a3ba8;border:1px solid rgba(11,23,36,0.04)}
.activity-badge.calendar{background:linear-gradient(90deg,#eef6ff,#f0f9ff);color:#0b6aa8;border:1px solid rgba(11,23,36,0.04)}
.activity-actions-inline{display:flex;gap:6px;margin-top:8px}
.activity-actions-inline button{background:transparent;border:0;color:var(--muted);cursor:pointer;padding:6px 8px;border-radius:8px}
.activity-empty{color:var(--muted);font-size:13px}

@media(max-width:520px){
  .activity-avatar{width:36px;height:36px;font-size:13px}
}

/* Tabs for Account view */
.tabs{display:flex;flex-direction:column;gap:12px}
.tab-buttons{display:flex;gap:8px;flex-wrap:wrap}
.tab-buttons button{padding:8px 12px;border-radius:8px;border:1px solid rgba(11,23,36,0.04);background:transparent;cursor:pointer;color:var(--muted)}
.tab-buttons button.active{background:linear-gradient(90deg,var(--primary-base),var(--accent));color:#fff;border:none;box-shadow:0 8px 24px rgba(16,24,40,0.06)}
.tab-content{background:transparent}
.tab-panel{display:none}
.tab-panel.active{display:block}

@media(max-width:900px){
  .tab-buttons{overflow:auto}
}

/* Feature chips for property view */
.feature-chip{display:inline-block;padding:6px 10px;border-radius:999px;background:linear-gradient(90deg,#fff6f0,#fffaf6);color:#b85a00;font-weight:700;font-size:13px;margin:6px 8px 6px 0;box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.features-list-visual{display:flex;flex-wrap:wrap;align-items:center}

/* Lightbox */
.pv-lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,12,20,0.72);z-index:9999;padding:20px}
.pv-lightbox[aria-hidden="false"]{display:flex}
.pv-lb-img{max-width:100%;max-height:80vh;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,0.6)}
.pv-lb-close{position:absolute;right:24px;top:18px;background:rgba(255,255,255,0.95);border-radius:8px;border:none;width:40px;height:40px;font-size:22px;cursor:pointer}
.pv-lb-caption{position:absolute;bottom:28px;left:28px;color:#fff;font-size:14px}

@media(max-width:900px){
  .pv-grid{grid-template-columns:1fr}
  .pv-main-img{height:200px}
}

/* Lightbox navigation buttons */
.pv-lb-prev, .pv-lb-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,0.45);border:none;color:#fff;width:48px;height:48px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.pv-lb-prev{left:20px}
.pv-lb-next{right:20px}
.pv-lb-prev i, .pv-lb-next i{font-size:18px}

/* style close icon to match */
.pv-lb-close i{font-size:18px}

/* Footer styles */
.app-footer{padding:14px 18px;text-align:center;background:transparent;color:rgba(11,23,36,0.6);font-size:13px;border-top:1px solid rgba(11,23,36,0.04)}
.app-footer a{color:var(--primary-base);text-decoration:none}
.app-footer a:hover{text-decoration:underline}

/* Properties module specific styles */
.upload-box{border:2px dashed rgba(255,106,0,0.18);background:linear-gradient(180deg, #f8fbff, #fff);padding:18px;border-radius:8px}
.section-title.color-1 h4{color:var(--primary-base)}
.ai-btn{display:inline-block;padding:8px 12px;border-radius:8px;background:#fff;border:1px solid rgba(11,23,36,0.06);color:var(--primary-base);text-decoration:none}
.ai-btn:hover{background:var(--primary-base);color:#fff}

/* dropdowns and compact fields */
.form-row[style*="display:flex"] .input-wrap select{width:100%;padding:10px 12px;border-radius:8px;border:1px solid rgba(11,23,36,0.06);height:44px}
.form-row.inline-row .form-field{display:flex;flex-direction:column}
.upload-box label div{line-height:1}

/* upload preview image adjustments */
.upload-preview img{display:block;margin:0 auto}
.upload-preview{min-height:40px}

/* Status pill styles for properties */
.status-pill{
  display:inline-block;
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:600;
  letter-spacing:0.3px;
  color:#0b1724;
  background:rgba(11,23,36,0.06);
  transition:all .15s ease-in-out;
  min-width:72px;
  text-align:center;
}
.status-pill.status-available{
  background:linear-gradient(180deg,#e6f6ea,#d8f1de);
  color:#0b6a2e;
  box-shadow:0 1px 0 rgba(11,23,36,0.04) inset;
}
.status-pill.status-sold{
  background:linear-gradient(180deg,#fdecea,#fbe0de);
  color:#8a1f1f;
  box-shadow:0 1px 0 rgba(11,23,36,0.04) inset;
}
.status-pill.status-pending{
  background:linear-gradient(180deg,#fff7e6,#fff3d1);
  color:#6a570b;
}
.status-pill.small{font-size:11px;padding:3px 8px;min-width:64px}

/* Price badge: prominent styled price */
.price-badge{
  display:inline-flex;
  align-items:baseline;
  gap:8px;
  background:linear-gradient(90deg,#fff3e6,#fffaf5);
  border-radius:12px;
  padding:8px 12px;
  box-shadow:0 6px 18px rgba(16,24,40,0.06);
  font-weight:700;
  color:#b85a00;
  font-size:14px;
}
.price-badge .amount{font-size:16px;color:#b85a00}
.price-badge .currency{font-size:12px;color:#8a4a00;opacity:0.9}
.price-badge.small{padding:6px 10px;border-radius:10px;font-size:13px}

/* Search box and filter panel styling */
.search-box{width:320px}
.filter-panel{border:1px solid rgba(11,23,36,0.04);background:linear-gradient(180deg,#fff,#fbfdff);padding:12px;border-radius:10px}
.filter-panel select,.filter-panel input{box-shadow:none}
.filter-panel .btn{height:40px;padding:8px 12px}

/* Search wrap with icon */
.search-wrap{position:relative;display:inline-block}
.search-wrap .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:14px;pointer-events:none}
.search-wrap .search-box{width:260px;padding:10px 12px 10px 36px;border-radius:10px;border:1px solid rgba(11,23,36,0.06);box-shadow:0 8px 20px rgba(16,24,40,0.04);transition:box-shadow .12s ease,border-color .12s ease}
.search-wrap .search-box:focus{outline:none;border-color:var(--primary-solid);box-shadow:0 12px 30px rgba(30,136,229,0.08)}

@media(max-width:920px){
  .search-wrap .search-box{width:180px}
}

/* Calendar layout and side panel styling */
.calendar-wrap{display:flex;gap:18px;align-items:flex-start}
#calendar{flex:1;background:#fff;padding:14px;border:1px solid #eee;border-radius:8px}
.calendar-side{width:340px}
.side-box{background:#fff;padding:12px;border:1px solid #eee;border-radius:8px}
.btn{display:inline-block;padding:8px 12px;background:var(--primary-base);color:#fff;border-radius:6px;text-decoration:none}
.btn-danger{background:#e53935}
.link-button{background:none;border:none;color:var(--primary-base);cursor:pointer}

/* FullCalendar buttons and title match system primary color */
.fc .fc-button, .fc .fc-toolbar .fc-button, .fc-button-primary {
  background: var(--primary-base) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
  border-radius: 6px !important;
  margin: 5px;
}
.fc .fc-button:hover { filter: brightness(0.95); }
.fc .fc-toolbar-title { color: var(--primary-base); font-weight:700; }
.fc .fc-daygrid-event, .fc .fc-timegrid-event { border: none !important; color: #fff !important; }

@media(max-width:920px){
  .calendar-wrap{flex-direction:column}
  .calendar-side{width:100%}
}

/* Modal styles for New Event */
.modal-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,12,20,0.48);z-index:9999;padding:20px}
.modal-overlay.modal-open{display:flex}
.modal{width:680px;max-width:96%;background:#fff;border-radius:10px;box-shadow:0 30px 80px rgba(9,30,66,0.12);overflow:hidden}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid rgba(11,23,36,0.04)}
.modal-header h3{margin:0;font-size:18px}
.modal-close{background:none;border:0;font-size:26px;line-height:1;color:#666;cursor:pointer}
.modal-body{padding:16px}
.modal .form-group{margin-bottom:12px}
.modal .form-group label{display:block;margin-bottom:6px;font-weight:600}
.modal .form-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:6px}
.modal .form-actions .btn{min-width:90px}

/* Modal form rows: support single and two-column layouts */
.modal .form-row{display:flex;gap:12px;align-items:flex-start}
.modal .form-row .form-field{flex:1;display:flex;flex-direction:column}
.modal .form-row .form-field label{margin-bottom:6px;font-weight:600}

/* inputs inside modal should align and match global form styles */
.modal .form-row .input-wrap input[type="text"],
.modal .form-row .input-wrap input[type="datetime-local"],
.modal .form-row .input-wrap input[type="date"],
.modal .form-row .input-wrap input[type="time"],
.modal .form-row .input-wrap select,
.modal .form-row .input-wrap textarea{
  width:100%;padding:10px 12px;border:1px solid rgba(11,23,36,0.06);border-radius:6px;background:var(--card-bg);font-size:14px;color:var(--text);height:40px;box-shadow:none;box-sizing:border-box
}
.modal .form-row .input-wrap textarea{min-height:84px;height:auto;padding:8px}

/* Color swatch styling */
.modal .color-swatch{display:flex;align-items:center;gap:8px}
.modal .color-swatch input[type="color"]{width:44px;height:28px;border:1px solid rgba(11,23,36,0.06);border-radius:6px;padding:2px;background:#fff;cursor:pointer}

/* Priority select: ensure visual parity with inputs */
.modal .priority-select{height:40px;padding:8px 10px;border-radius:6px;border:1px solid rgba(11,23,36,0.06);background:#fff}

/* Buttons in modal: Save = primary orange, Cancel = neutral */
.modal .form-actions .btn.save{background:var(--primary-base);color:#fff;border-radius:6px;padding:10px 18px;border:none}
.modal .form-actions .btn.save:hover{filter:brightness(0.98)}
.modal .form-actions .btn.cancel{background:#6c757d;color:#fff;border-radius:6px;padding:10px 16px;border:none}

/* Responsive: stack form rows on narrow screens */
@media (max-width:520px){
  .modal .form-row{flex-direction:column}
}


