@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap');

:root {
  --bg:           #F2F4F8;
  --surface:      #FFFFFF;
  --border:       #E2E6EF;
  --text:         #0D1B3E;
  --muted:        #6B7595;
  --accent:       #003C9B;
  --accent-dark:  #002d78;
  --accent-bg:    rgba(0,60,155,.06);
  --accent-border:rgba(0,60,155,.22);
  --danger:       #EF4444;
  --danger-bg:    rgba(239,68,68,.06);
  --warning:      #F59E0B;
  --sb-w:         240px;
  --sb-bg:        #0D1B3E;
  --ease:         cubic-bezier(0.16,1,0.3,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{font-size:15px;}
body{font-family:'Outfit',Arial,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
button,input,select,textarea{font-family:inherit;}

/* ══════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════ */
.layout{display:flex;min-height:100vh;}
.main{flex:1;margin-left:var(--sb-w);display:flex;flex-direction:column;min-height:100vh;transition:margin .3s var(--ease);min-width:0;}
.content{flex:1;padding:28px 32px;}

/* ══════════════════════════════════════════════════
   SIDEBAR
   ══════════════════════════════════════════════════ */
.sidebar{
  width:var(--sb-w);
  background:var(--sb-bg);
  position:fixed;top:0;bottom:0;left:0;
  display:flex;flex-direction:column;
  z-index:800;
  transition:transform .3s var(--ease);
  overflow-y:auto;overflow-x:hidden;
}
.sb-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:20px 16px;
  border-bottom:1px solid rgba(255,255,255,.06);
  flex-shrink:0;
}
.sb-logo{display:flex;align-items:center;gap:10px;padding:4px 0;}
.sb-logo img{display:block;height:28px;width:auto;}
.sb-close{
  display:none;background:none;border:none;
  color:rgba(255,255,255,.45);font-size:18px;
  cursor:pointer;padding:6px;line-height:1;
  border-radius:8px;transition:background .2s;
}
.sb-close:hover{background:rgba(255,255,255,.08);}
.sb-nav{flex:1;padding:16px 10px;display:flex;flex-direction:column;gap:22px;}
.nav-section{display:flex;flex-direction:column;gap:2px;}
.nav-section-label{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:1.5px;color:rgba(255,255,255,.25);
  padding:0 10px;margin-bottom:4px;
}
.nav-link{
  display:flex;align-items:center;gap:11px;
  padding:10px 12px;border-radius:10px;
  font-size:13.5px;font-weight:500;color:rgba(255,255,255,.5);
  transition:all .2s;text-decoration:none;
}
.nav-link:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85);}
.nav-link.active{background:rgba(0,60,155,.2);color:#6699ff;}
.nav-link.active i{color:#6699ff;}
.nav-link i{width:16px;text-align:center;font-size:14px;flex-shrink:0;}
.nav-link .lbl{white-space:nowrap;}
.badge{
  margin-left:auto;background:var(--danger);color:#fff;
  font-size:10px;font-weight:700;min-width:18px;height:18px;
  border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 5px;
}
.sb-user{
  margin:12px;border-top:1px solid rgba(255,255,255,.06);
  padding:14px 0 4px;display:flex;align-items:center;gap:10px;
  flex-shrink:0;
}
.sb-avatar{
  width:34px;height:34px;border-radius:10px;
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;flex-shrink:0;
}
.sb-user-info{flex:1;min-width:0;}
.sb-user-info strong{display:block;font-size:13px;color:rgba(255,255,255,.85);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-user-info span{font-size:11px;color:rgba(255,255,255,.35);}
.sb-logout{background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;font-size:15px;padding:4px;transition:color .2s;flex-shrink:0;}
.sb-logout:hover{color:var(--danger);}
/* Overlay — hidden by default, shown only when sidebar opens on mobile */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:799;}

/* ══════════════════════════════════════════════════
   TOPBAR
   ══════════════════════════════════════════════════ */
.topbar{
  background:var(--surface);border-bottom:1px solid var(--border);
  padding:0 20px;height:60px;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;position:sticky;top:0;z-index:700;flex-shrink:0;
}
.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;}
.sb-toggle{
  background:none;border:none;color:var(--muted);font-size:18px;
  cursor:pointer;padding:4px;display:none;transition:color .2s;
  flex-shrink:0;
}
.sb-toggle:hover{color:var(--text);}
.page-title{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.topbar-right{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted);flex-shrink:0;}

/* ══════════════════════════════════════════════════
   PAGE HEADER BAR
   ══════════════════════════════════════════════════ */
.page-header-bar{
  display:flex;align-items:flex-start;justify-content:space-between;
  gap:12px;flex-wrap:wrap;margin-bottom:24px;
}
.page-header-bar h2{font-size:20px;font-weight:700;color:var(--text);}
.page-header-bar p{font-size:13px;color:var(--muted);margin-top:2px;}
.page-header-bar .phb-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center;}

/* ══════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════ */
.btn-primary{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--text);color:#fff;
  padding:9px 18px;border-radius:100px;
  font-size:13px;font-weight:600;border:none;cursor:pointer;
  transition:all .2s var(--ease);text-decoration:none;white-space:nowrap;
}
.btn-primary:hover{background:var(--accent-dark);transform:translateY(-1px);box-shadow:0 4px 16px rgba(13,27,62,.2);}
.btn-secondary{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--surface);color:var(--text);
  padding:8px 18px;border-radius:100px;
  font-size:13px;font-weight:600;
  border:1.5px solid var(--border);cursor:pointer;
  transition:all .2s;text-decoration:none;white-space:nowrap;
}
.btn-secondary:hover{border-color:var(--text);background:var(--text);color:#fff;}
.btn-danger{
  display:inline-flex;align-items:center;gap:7px;
  background:var(--danger-bg);color:var(--danger);
  padding:8px 18px;border-radius:100px;
  font-size:13px;font-weight:600;
  border:1.5px solid rgba(239,68,68,.2);cursor:pointer;
  transition:all .2s;text-decoration:none;white-space:nowrap;
}
.btn-danger:hover{background:var(--danger);color:#fff;}

/* ══════════════════════════════════════════════════
   STAT CARDS
   ══════════════════════════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px;}
.stat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:14px;
  padding:20px 16px;display:flex;align-items:flex-start;gap:14px;
  transition:box-shadow .2s,transform .2s;
}
.stat-card:hover{box-shadow:0 4px 16px rgba(13,27,62,.07);transform:translateY(-2px);}
.stat-icon{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.stat-icon.green{background:rgba(0,60,155,.1);color:var(--accent-dark);}
.stat-icon.blue{background:rgba(59,130,246,.1);color:#3B82F6;}
.stat-icon.orange{background:rgba(245,158,11,.1);color:var(--warning);}
.stat-icon.purple{background:rgba(139,92,246,.1);color:#8B5CF6;}
.stat-num{font-size:26px;font-weight:700;line-height:1;color:var(--text);}
.stat-lbl{font-size:12px;color:var(--muted);margin-top:3px;}

/* ══════════════════════════════════════════════════
   TABLES
   ══════════════════════════════════════════════════ */
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;}
.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}
.data-table{width:100%;border-collapse:collapse;min-width:520px;}
.data-table thead tr{background:var(--bg);}
.data-table th{
  padding:11px 14px;font-size:10.5px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;color:var(--muted);
  text-align:left;white-space:nowrap;border-bottom:1px solid var(--border);
}
.data-table td{padding:13px 14px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle;}
.data-table tr:last-child td{border-bottom:none;}
.data-table tbody tr{transition:background .15s;}
.data-table tbody tr:hover{background:var(--bg);}

/* ══════════════════════════════════════════════════
   STATUS PILLS
   ══════════════════════════════════════════════════ */
.status-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;white-space:nowrap;}
.status-pill::before{content:'';width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.status-active{background:rgba(0,60,155,.1);color:var(--accent-dark);}
.status-active::before{background:var(--accent-dark);}
.status-inactive{background:rgba(100,116,139,.08);color:#64748B;}
.status-inactive::before{background:#94A3B8;}
.status-new{background:rgba(59,130,246,.08);color:#3B82F6;}
.status-new::before{background:#3B82F6;}
.status-responded{background:rgba(0,60,155,.1);color:var(--accent-dark);}
.status-responded::before{background:var(--accent-dark);}
.status-closed{background:rgba(100,116,139,.08);color:#64748B;}
.status-closed::before{background:#94A3B8;}

/* ══════════════════════════════════════════════════
   ROW ACTIONS
   ══════════════════════════════════════════════════ */
.row-actions{display:flex;align-items:center;gap:5px;}
.act-btn{width:30px;height:30px;border-radius:8px;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s;flex-shrink:0;}
.act-view{background:rgba(59,130,246,.08);color:#3B82F6;}
.act-view:hover{background:#3B82F6;color:#fff;}
.act-edit{background:rgba(245,158,11,.08);color:var(--warning);}
.act-edit:hover{background:var(--warning);color:#fff;}
.act-delete{background:var(--danger-bg);color:var(--danger);}
.act-delete:hover{background:var(--danger);color:#fff;}

/* ══════════════════════════════════════════════════
   ALERTS
   ══════════════════════════════════════════════════ */
.alert{display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:11px;margin-bottom:18px;font-size:13.5px;transition:opacity .4s;}
.alert-success{background:rgba(0,60,155,.08);border:1px solid rgba(0,60,155,.15);color:var(--accent-dark);}
.alert-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.2);color:#991b1b;}

/* ══════════════════════════════════════════════════
   FORM LAYOUT
   ══════════════════════════════════════════════════ */
.form-layout{display:grid;grid-template-columns:1fr 300px;gap:20px;align-items:start;}
.form-main{display:flex;flex-direction:column;gap:18px;}
.form-side{display:flex;flex-direction:column;gap:14px;}
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;}
.form-card-title{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:18px;display:flex;align-items:center;gap:8px;}

/* ══════════════════════════════════════════════════
   FORM FIELDS
   ══════════════════════════════════════════════════ */
.fg{margin-bottom:16px;}
.fg:last-child{margin-bottom:0;}
.fg label{display:block;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:6px;}
.req{color:var(--danger);}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.fc{
  width:100%;padding:10px 13px;font-size:14px;
  color:var(--text);background:var(--bg);
  border:1.5px solid var(--border);border-radius:10px;
  outline:none;transition:all .2s;
}
.fc:focus{background:var(--surface);border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,60,155,.1);}
.fc::placeholder{color:#B0B7C8;}
.fc.is-invalid{border-color:var(--danger);}
textarea.fc{resize:vertical;min-height:100px;line-height:1.6;}
select.fc{
  cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A7F9A' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}
.invalid-feedback{font-size:12px;color:var(--danger);margin-top:5px;display:block;}
code{background:rgba(13,27,62,.06);padding:1px 6px;border-radius:4px;font-size:12px;font-family:monospace;}

/* ══════════════════════════════════════════════════
   TOGGLE SWITCH
   ══════════════════════════════════════════════════ */
.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px;background:var(--bg);border-radius:11px;margin-bottom:18px;}
.toggle{position:relative;width:44px;height:24px;flex-shrink:0;cursor:pointer;}
.toggle input{opacity:0;width:0;height:0;position:absolute;}
.toggle-slider{position:absolute;inset:0;background:#D1D5DB;border-radius:100px;transition:background .25s;}
.toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .25s;box-shadow:0 1px 4px rgba(0,0,0,.15);}
.toggle input:checked ~ .toggle-slider{background:var(--accent);}
.toggle input:checked ~ .toggle-slider::before{transform:translateX(20px);}

/* ══════════════════════════════════════════════════
   DASHBOARD
   ══════════════════════════════════════════════════ */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.dash-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px;}
.dash-card h3{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;}
.dash-card h3 a{font-size:12px;font-weight:500;color:var(--muted);transition:color .2s;}
.dash-card h3 a:hover{color:var(--accent-dark);}
/* Dashboard tables need scroll too */
.dash-card .table-scroll{margin:0 -20px;padding:0 20px;overflow-x:auto;-webkit-overflow-scrolling:touch;}
.activity-list{display:flex;flex-direction:column;gap:10px;}
.activity-item{display:flex;align-items:flex-start;gap:10px;padding:11px;background:var(--bg);border-radius:10px;}
.act-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.act-title{font-size:13px;font-weight:600;color:var(--text);}
.act-meta{font-size:11.5px;color:var(--muted);margin-top:1px;}

/* ══════════════════════════════════════════════════
   DETAIL VIEW
   ══════════════════════════════════════════════════ */
.detail-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:28px;margin-bottom:18px;}
.detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap;margin-bottom:22px;padding-bottom:22px;border-bottom:1px solid var(--border);}
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.detail-item .di-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--muted);margin-bottom:5px;}
.detail-item .di-val{font-size:14px;color:var(--text);}

/* ══════════════════════════════════════════════════
   EMPTY STATE
   ══════════════════════════════════════════════════ */
.empty-state{text-align:center;padding:70px 20px;color:var(--muted);}
.empty-state i{font-size:44px;color:#E2E4EE;margin-bottom:14px;display:block;}
.empty-state h3{font-size:17px;font-weight:700;color:var(--text);margin-bottom:6px;}
.empty-state p{font-size:13.5px;margin-bottom:22px;}

/* ══════════════════════════════════════════════════
   LOGIN
   ══════════════════════════════════════════════════ */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 16px 56px rgba(13,27,62,.08);}
.login-logo{display:flex;align-items:center;justify-content:center;margin-bottom:28px;}
.login-card h1{font-size:21px;font-weight:700;text-align:center;margin-bottom:6px;}
.login-card > p{font-size:13.5px;color:var(--muted);text-align:center;margin-bottom:28px;}
.form-submit{width:100%;padding:12px;background:var(--text);color:#fff;border:none;border-radius:100px;font-size:14.5px;font-weight:600;cursor:pointer;transition:all .25s var(--ease);}
.form-submit:hover{background:var(--accent-dark);transform:translateY(-1px);}

/* ══════════════════════════════════════════════════
   UPLOAD ZONE (portfolio / services)
   ══════════════════════════════════════════════════ */
.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:24px 16px;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--accent);background:var(--accent-bg);}
.extra-thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:10px;}
.extra-thumb{position:relative;border-radius:8px;overflow:hidden;aspect-ratio:1;}
.extra-thumb img{width:100%;height:100%;object-fit:cover;}
.extra-remove{position:absolute;top:4px;right:4px;width:20px;height:20px;background:rgba(239,68,68,.9);color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:9px;}

/* ══════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════════ */

/* ── Large tablet (≤ 1100px) ─────────────────────── */
@media(max-width:1100px){
  .stats-grid{grid-template-columns:repeat(3,1fr);}
  .form-layout{grid-template-columns:1fr;}
  .form-side{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
  .dash-grid{grid-template-columns:1fr;}
}

/* ── Tablet (≤ 900px) ───────────────────────────── */
@media(max-width:900px){
  .stats-grid{grid-template-columns:repeat(3,1fr);}
  .form-side{display:flex;flex-direction:column;}
  .detail-grid{grid-template-columns:1fr 1fr;}
}

/* ── Mobile (≤ 768px) ───────────────────────────── */
@media(max-width:768px){

  /* Sidebar slides in from left */
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .sb-close{display:flex;}

  /* Overlay visible only when sidebar is open */
  .sb-overlay{display:none;}
  .sb-overlay.show{display:block;}

  /* Main takes full width */
  .main{margin-left:0;}
  .sb-toggle{display:flex;}
  .content{padding:16px;}

  /* Stats — 2 columns */
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px;}
  .stat-card{padding:16px 12px;gap:10px;}
  .stat-num{font-size:22px;}

  /* Forms */
  .form-layout{grid-template-columns:1fr;}
  .form-side{display:flex;flex-direction:column;}
  .frow{grid-template-columns:1fr;}
  .form-card{padding:18px;}
  .toggle-row{padding:12px;}

  /* Tables — horizontal scroll */
  .table-card{border-radius:12px;}
  .table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .data-table{min-width:480px;}
  .data-table th,.data-table td{padding:11px 12px;}

  /* Dashboard */
  .dash-grid{grid-template-columns:1fr;}
  .dash-card{padding:16px;}
  .page-header-bar{flex-direction:column;align-items:flex-start;gap:10px;}
  .page-header-bar .btn-primary,
  .page-header-bar .btn-secondary{width:100%;justify-content:center;}

  /* Detail views */
  .detail-grid{grid-template-columns:1fr;}
  .detail-card{padding:18px;}
  .detail-header{flex-direction:column;gap:10px;}

  /* Login */
  .login-card{padding:28px 20px;border-radius:16px;}

  /* Topbar */
  .topbar{padding:0 14px;}
  .topbar-right span{display:none;}
}

/* ── Small mobile (≤ 480px) ─────────────────────── */
@media(max-width:480px){
  .stats-grid{grid-template-columns:1fr 1fr;gap:8px;}
  .stat-card{padding:14px 10px;}
  .stat-num{font-size:20px;}
  .stat-lbl{font-size:11px;}
  .content{padding:12px;}
  .extra-thumbs{grid-template-columns:repeat(2,1fr);}
}

/* ── Modal animations ─────────────────────────────── */
@keyframes overlayIn { from { opacity:0 } to { opacity:1 } }
@keyframes modalIn   { from { opacity:0; transform:scale(.94) translateY(12px) } to { opacity:1; transform:none } }
.modal-overlay { animation: overlayIn .2s cubic-bezier(0.4,0,0.2,1) both; }
.modal-box     { animation: modalIn .28s cubic-bezier(0.34,1.4,0.64,1) both; }

@media (prefers-reduced-motion: reduce) {
  .modal-overlay, .modal-box { animation: none; }
}
