/* ═══════════════════════════════════════════════════
   ARVO KIINTEISTÖT — admin.css
   Light professional theme — matches main site palette
   ═══════════════════════════════════════════════════ */
:root{
  --bg:#F8F9FC; --bg-2:#EEF1F8; --bg-3:#E4E8F3;
  --white:#FFFFFF;
  --accent:#3B5BDB; --accent-d:#2F4AC7; --accent-l:#A5B4F8; --accent-bg:rgba(59,91,219,.08);
  --ink:#0F1523; --ink-2:#2D3A52; --ink-3:#6B7A99;
  --border:#DDE2EF; --border-2:#C8CFE3;
  --success:#16A34A; --success-bg:rgba(22,163,74,.08);
  --warning:#D97706; --warning-bg:rgba(217,119,6,.08);
  --danger:#DC2626;  --danger-bg:rgba(220,38,38,.08);
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'DM Sans',system-ui,sans-serif;
  --sidebar-w:256px; --ban-h:34px; --topbar-h:60px;
  --r:12px; --r-sm:8px;
  --shadow:0 1px 8px rgba(15,21,35,.06);
  --shadow-md:0 4px 20px rgba(15,21,35,.10);
}
*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:6px}
::-webkit-scrollbar-thumb:hover{background:var(--accent-l)}

/* ── BANNER ── */
.adm-banner{position:fixed;top:0;left:0;right:0;z-index:300;height:var(--ban-h);background:var(--ink);display:flex;align-items:center;justify-content:center;gap:18px;font-size:.72rem;color:rgba(255,255,255,.5)}
.abn-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-l);flex-shrink:0}
.adm-banner b{color:#fff;font-weight:600}
.adm-banner a{color:var(--accent-l);display:inline-flex;align-items:center;gap:4px;font-weight:500;transition:.15s}
.adm-banner a:hover{color:#fff}
.abn-sep{opacity:.25}
.abn-home{color:rgba(255,255,255,.35)!important}

/* ── SHELL ── */
.adm-shell{display:flex;min-height:100vh;padding-top:var(--ban-h)}

/* ── SIDEBAR ── */
.sidebar{
  position:fixed;top:var(--ban-h);bottom:0;left:0;width:var(--sidebar-w);z-index:200;
  background:var(--white);border-right:1px solid var(--border);
  display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.16,1,.3,1);
}
.sidebar-logo{
  padding:1.2rem 1.4rem;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:.8rem;
}
.logo-mark{
  width:40px;height:40px;border-radius:10px;background:var(--accent);color:#fff;
  font-family:var(--serif);font-size:1.5rem;font-style:italic;
  display:grid;place-items:center;flex-shrink:0;
}
.sidebar-name{font-family:var(--serif);font-size:1.3rem;color:var(--ink);line-height:1}
.sidebar-sub{font-size:.6rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-3);margin-top:2px}
.sidebar-nav{flex:1;padding:.8rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.sidebar-nav-item{
  display:flex;align-items:center;gap:.8rem;padding:.65rem .85rem;border-radius:var(--r-sm);
  font-size:.82rem;font-weight:400;color:var(--ink-3);transition:.15s;text-align:left;width:100%;
  border-left:2px solid transparent;
}
.sidebar-nav-item i{font-size:1rem;color:var(--ink-3);transition:.15s;flex-shrink:0}
.sidebar-nav-item:hover{background:var(--bg);color:var(--ink-2)}
.sidebar-nav-item:hover i{color:var(--accent)}
.sidebar-nav-item.active{background:var(--accent-bg);color:var(--accent-d);border-left-color:var(--accent);font-weight:500}
.sidebar-nav-item.active i{color:var(--accent)}
.sidebar-nav-sep{height:1px;background:var(--border);margin:.4rem .8rem}
.sidebar-foot{padding:.9rem 1.4rem;border-top:1px solid var(--border);font-size:.68rem;color:var(--ink-3)}

/* ── MAIN ── */
.main{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column;min-height:100vh}
.topbar{
  position:sticky;top:var(--ban-h);z-index:150;height:var(--topbar-h);
  background:rgba(248,249,252,.95);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 1.6rem;display:flex;align-items:center;justify-content:space-between;
}
.tb-left{display:flex;align-items:center;gap:1rem}
.tb-burger{display:none;width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);align-items:center;justify-content:center;font-size:1rem;color:var(--ink-2)}
.tb-title{font-family:var(--serif);font-size:1.3rem;color:var(--ink)}
.tb-right{display:flex;align-items:center;gap:.8rem}
.tb-online{display:flex;align-items:center;gap:.4rem;font-size:.72rem;color:var(--ink-3)}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(22,163,74,.4)}70%{box-shadow:0 0 0 6px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}
.demo-badge{font-size:.62rem;font-weight:700;letter-spacing:.12em;padding:.2rem .5rem;border-radius:6px;background:var(--accent-bg);color:var(--accent-d);border:1px solid var(--border-2)}
.adm-lang{display:flex;gap:2px;background:var(--bg-2);border:1px solid var(--border);border-radius:8px;padding:2px}
.adm-lb{font-size:.68rem;font-weight:600;letter-spacing:.06em;padding:4px 8px;border-radius:6px;color:var(--ink-3);transition:.15s}
.adm-lb-active{background:var(--accent);color:#fff}
.tb-site{display:inline-flex;align-items:center;gap:.4rem;font-size:.75rem;font-weight:500;color:var(--accent);padding:.4rem .8rem;border:1px solid var(--border-2);border-radius:var(--r-sm);transition:.15s}
.tb-site:hover{background:var(--accent-bg)}
.content{padding:1.6rem;flex:1}

/* ── CARDS & GRIDS ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.4rem;margin-bottom:1.2rem}
.card-title{font-size:.82rem;font-weight:600;color:var(--ink-2);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.06em}
.card-title i{color:var(--accent);font-size:1rem}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.4rem}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.4rem}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;margin-bottom:1.4rem}

/* Stat cards */
.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:.3rem}
.stat-card-label{font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3)}
.stat-card-val{font-family:var(--serif);font-size:2rem;color:var(--ink);line-height:1}
.stat-card-sub{font-size:.72rem;color:var(--ink-3);display:flex;align-items:center;gap:.3rem;margin-top:.2rem}
.stat-card-sub.up{color:var(--success)}
.stat-card-sub.down{color:var(--danger)}
.stat-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:.5rem}
.stat-card-icon.blue{background:var(--accent-bg);color:var(--accent)}
.stat-card-icon.green{background:var(--success-bg);color:var(--success)}
.stat-card-icon.amber{background:var(--warning-bg);color:var(--warning)}
.stat-card-icon.red{background:var(--danger-bg);color:var(--danger)}

/* ── TABLE ── */
.table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;background:var(--white)}
thead{background:var(--bg)}
th{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:.85rem 1rem;font-size:.82rem;color:var(--ink-2);border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--bg)}
.td-img{width:52px;height:40px;border-radius:6px;background:var(--bg-2) center/cover no-repeat;flex-shrink:0}

/* ── BADGES / PILLS ── */
.badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.67rem;font-weight:600;letter-spacing:.05em;padding:.22rem .6rem;border-radius:20px}
.badge-sale{background:var(--accent-bg);color:var(--accent-d)}
.badge-rent{background:var(--success-bg);color:var(--success)}
.badge-active{background:var(--success-bg);color:var(--success)}
.badge-sold{background:var(--bg-2);color:var(--ink-3)}
.badge-pending{background:var(--warning-bg);color:var(--warning)}
.badge-new{background:rgba(139,92,246,.08);color:#6D28D9}
.badge-viewing{background:var(--accent-bg);color:var(--accent-d)}
.badge-offer{background:var(--warning-bg);color:var(--warning)}
.badge-cancelled{background:var(--danger-bg);color:var(--danger)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;padding:.45rem .9rem;border-radius:var(--r-sm);transition:.15s;cursor:pointer;border:none}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-d)}
.btn-ghost{background:transparent;color:var(--ink-2);border:1px solid var(--border-2)}
.btn-ghost:hover{background:var(--bg-2)}
.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid rgba(220,38,38,.2)}
.btn-danger:hover{background:var(--danger);color:#fff}
.btn-sm{padding:.3rem .65rem;font-size:.72rem}
.btn-icon{width:30px;height:30px;border-radius:var(--r-sm);padding:0;justify-content:center;border:1px solid var(--border)}
.btn-icon:hover{background:var(--bg-2);border-color:var(--border-2)}

/* ── FORM ELEMENTS ── */
.form-field{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.9rem}
.form-label{font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3)}
.form-input{border:1px solid var(--border-2);border-radius:var(--r-sm);padding:.55rem .8rem;color:var(--ink);background:var(--bg);transition:.15s;outline:none;width:100%}
.form-input:focus{border-color:var(--accent);background:var(--white)}
.form-select{border:1px solid var(--border-2);border-radius:var(--r-sm);padding:.55rem .8rem;color:var(--ink);background:var(--bg);outline:none;width:100%;cursor:pointer}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}

/* ── PROPERTY CARD GRID (admin) ── */
.prop-admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.pac{background:var(--white);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:.15s}
.pac:hover{box-shadow:var(--shadow-md)}
.pac-img{aspect-ratio:16/9;background:var(--bg-2) center/cover no-repeat;position:relative}
.pac-badges{position:absolute;top:.6rem;left:.6rem;display:flex;gap:.3rem}
.pac-body{padding:1rem}
.pac-title{font-family:var(--serif);font-size:.95rem;color:var(--ink);margin-bottom:.25rem;line-height:1.3}
.pac-addr{font-size:.72rem;color:var(--ink-3);margin-bottom:.6rem}
.pac-meta{display:flex;gap:.8rem;font-size:.72rem;color:var(--ink-3);margin-bottom:.8rem}
.pac-meta span{display:flex;align-items:center;gap:.25rem}
.pac-meta i{color:var(--accent);font-size:.85rem}
.pac-price{font-family:var(--serif);font-size:1.1rem;color:var(--ink);margin-bottom:.7rem}
.pac-actions{display:flex;gap:.4rem}

/* ── VIEWING TIMELINE ── */
.viewing-list{display:flex;flex-direction:column;gap:.5rem}
.viewing-row{display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);transition:.15s}
.viewing-row:hover{border-color:var(--border-2);background:var(--white)}
.vr-time{font-family:var(--serif);font-size:.95rem;color:var(--ink);min-width:52px}
.vr-prop{flex:1;font-size:.8rem;font-weight:500;color:var(--ink-2)}
.vr-prop span{display:block;font-size:.7rem;font-weight:400;color:var(--ink-3)}
.vr-client{font-size:.75rem;color:var(--ink-3);min-width:120px}
.vr-actions{display:flex;gap:.3rem;flex-shrink:0}

/* ── LEAD CARDS ── */
.lead-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1rem 1.2rem;display:flex;align-items:flex-start;gap:.9rem;transition:.15s;margin-bottom:.5rem}
.lead-card:hover{border-color:var(--border-2);box-shadow:var(--shadow)}
.lead-avatar{width:38px;height:38px;border-radius:50%;background:var(--accent-bg);color:var(--accent-d);font-size:.78rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.lead-info{flex:1;min-width:0}
.lead-name{font-size:.85rem;font-weight:600;color:var(--ink);margin-bottom:.15rem}
.lead-detail{font-size:.72rem;color:var(--ink-3);display:flex;flex-wrap:wrap;gap:.4rem .8rem}
.lead-detail span{display:flex;align-items:center;gap:.2rem}
.lead-detail i{color:var(--accent);font-size:.8rem}
.lead-actions{display:flex;gap:.3rem;flex-shrink:0}

/* ── AGENT CARDS (admin) ── */
.agent-admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.aac{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem;display:flex;align-items:center;gap:.9rem}
.aac-photo{width:52px;height:52px;border-radius:50%;background:var(--bg-2) center top/cover no-repeat;flex-shrink:0}
.aac-info{flex:1;min-width:0}
.aac-name{font-size:.88rem;font-weight:600;color:var(--ink);margin-bottom:.15rem}
.aac-role{font-size:.7rem;color:var(--ink-3);margin-bottom:.4rem}
.aac-stats{display:flex;gap:.8rem;font-size:.7rem;color:var(--ink-3)}
.aac-actions{display:flex;gap:.3rem}

/* ── ANALYTICS CHART ── */
.chart-bars{display:flex;align-items:flex-end;gap:.4rem;height:120px;padding-top:1rem}
.chart-bar-col{display:flex;flex-direction:column;align-items:center;gap:.3rem;flex:1}
.chart-bar{width:100%;border-radius:4px 4px 0 0;background:var(--accent-bg);transition:height .8s cubic-bezier(.16,1,.3,1);position:relative;min-height:4px}
.chart-bar.accent{background:var(--accent)}
.chart-bar-label{font-size:.62rem;color:var(--ink-3);text-align:center}
.chart-bar-val{font-size:.65rem;font-weight:600;color:var(--ink-2);position:absolute;top:-1.2rem;left:50%;transform:translateX(-50%);white-space:nowrap}

/* ── INTEGRATIONS ── */
.int-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.int-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:1.2rem}
.int-head{display:flex;align-items:center;gap:.7rem;margin-bottom:.9rem}
.int-icon{width:36px;height:36px;border-radius:8px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--accent);flex-shrink:0}
.int-name{font-size:.85rem;font-weight:600;color:var(--ink)}
.int-desc{font-size:.72rem;color:var(--ink-3);margin-bottom:1rem;line-height:1.5}
.int-fields{display:flex;flex-direction:column;gap:.5rem}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 0;border-bottom:1px solid var(--border)}
.toggle-row:last-child{border:none}
.toggle-label{font-size:.78rem;color:var(--ink-2)}
.toggle{width:34px;height:18px;border-radius:9px;background:var(--border-2);position:relative;cursor:pointer;transition:.2s;flex-shrink:0}
.toggle.on{background:var(--accent)}
.toggle::after{content:'';position:absolute;width:14px;height:14px;border-radius:50%;background:#fff;top:2px;left:2px;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.15)}
.toggle.on::after{left:18px}

/* ── MODAL ── */
.modal-back{position:fixed;inset:0;z-index:400;background:rgba(15,21,35,.4);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:.25s}
.modal-back.show{opacity:1;pointer-events:all}
.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-45%);z-index:401;width:min(560px,95vw);max-height:90vh;overflow-y:auto;background:var(--white);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-md);opacity:0;pointer-events:none;transition:.25s}
.modal.show{opacity:1;pointer-events:all;transform:translate(-50%,-50%)}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 1.4rem;border-bottom:1px solid var(--border)}
.modal-head-title{font-size:.95rem;font-weight:600;color:var(--ink)}
.modal-close{width:30px;height:30px;border-radius:var(--r-sm);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--ink-3);font-size:.9rem;transition:.15s}
.modal-close:hover{background:var(--bg-2)}
.modal-body{padding:1.4rem}
.modal-foot{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 1.4rem;border-top:1px solid var(--border)}

/* ── TOAST ── */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:500;background:var(--ink);color:#fff;font-size:.78rem;font-weight:500;padding:.65rem 1.1rem;border-radius:var(--r-sm);display:flex;align-items:center;gap:.5rem;box-shadow:var(--shadow-md);opacity:0;transform:translateY(8px);transition:.25s;pointer-events:none}
.toast.show{opacity:1;transform:translateY(0)}
.toast i{font-size:1rem;color:var(--accent-l)}

/* ── SECTION HEADER ── */
.sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem;flex-wrap:wrap;gap:.8rem}
.sec-head-title{font-family:var(--serif);font-size:1.4rem;color:var(--ink)}
.sec-head-actions{display:flex;gap:.5rem;align-items:center}
.sec-note{font-size:.75rem;color:var(--ink-3);display:flex;align-items:center;gap:.4rem;margin-bottom:1rem;background:var(--accent-bg);border:1px solid var(--border-2);border-radius:var(--r-sm);padding:.6rem .9rem}
.sec-note i{color:var(--accent)}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0);box-shadow:var(--shadow-md)}
  .main{margin-left:0}
  .tb-burger{display:flex}
  .grid-4{grid-template-columns:1fr 1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .agent-admin-grid{grid-template-columns:1fr}
  .int-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .content{padding:1rem}
  .grid-4{grid-template-columns:1fr 1fr}
  .grid-2{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .tb-site span{display:none}
  .table-wrap{overflow-x:auto}
  table{min-width:500px}
}
