/*
 * ENEX Integrated System — Production Theme
 * Brand: #00A0E9
 */

/* ── tokens ── */
:root{
  --brand:#00A0E9;--brand-d:#0084be;--brand-l:#e8f5fd;--brand-rgb:0,160,233;
  --ok:#1a7f37;--warn:#bf8700;--ng:#cf222e;--info:#0969da;
  --bg:#f0f2f5;--surface:#fff;--surface-alt:#f6f8fa;
  --border:#d0d7de;--border-l:#e8ebef;
  --text:#24292f;--text-2:#57606a;--text-3:#8b949e;
  --sidebar-bg:#1b2332;--sidebar-w:224px;--header-h:46px;
  --radius:4px;--shadow-sm:0 1px 2px rgba(0,0,0,.06);
}

/* ── base ── */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:"Hiragino Kaku Gothic ProN","Hiragino Sans",
              "Yu Gothic Medium","Yu Gothic","Meiryo UI",Meiryo,
              -apple-system,sans-serif;
  font-size:13px;color:var(--text);background:var(--bg);
  line-height:1.6;margin:0;overflow-x:hidden;
}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--brand-d);text-decoration:none}
::selection{background:rgba(var(--brand-rgb),.18)}
:focus-visible{outline:2px solid var(--brand);outline-offset:1px}

/* ── bootstrap override ── */
.btn{font-size:12px;border-radius:var(--radius);padding:5px 12px;font-weight:500;line-height:1.4}
.btn-sm{font-size:11px;padding:3px 10px}
.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}
.btn-primary:hover,.btn-primary:focus,.btn-primary:active{background:var(--brand-d);border-color:var(--brand-d);color:#fff}
.btn-save{font-size:14px;padding:8px 28px;font-weight:600;letter-spacing:.03em}
.btn-outline-primary{color:var(--brand);border-color:var(--brand)}
.btn-outline-primary:hover{background:var(--brand);border-color:var(--brand);color:#fff}
.btn-outline-secondary{border-color:var(--border);color:var(--text-2)}
.btn-outline-secondary:hover{background:var(--surface-alt);border-color:var(--border);color:var(--text)}
.btn-light{background:var(--surface-alt);border-color:var(--border);color:var(--text-2)}
.form-control,.form-select{font-size:13px;border-radius:var(--radius);border-color:var(--border);padding:5px 10px;color:var(--text)}
.form-control:focus,.form-select:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(var(--brand-rgb),.12)}
.form-control-sm,.form-select-sm{font-size:12px;padding:3px 8px}
.form-label{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}
.form-check-input:checked{background-color:var(--brand);border-color:var(--brand)}
.form-text{font-size:11px;color:var(--text-3)}
.badge{font-weight:600;font-size:10px;border-radius:2px;padding:2px 5px}
.input-group-text{font-size:12px;background:var(--surface-alt);border-color:var(--border);color:var(--text-3);padding:5px 10px}
.dropdown-menu{font-size:13px;border-radius:var(--radius);border-color:var(--border);box-shadow:0 8px 24px rgba(0,0,0,.12);padding:4px}
.dropdown-item{font-size:13px;border-radius:3px;padding:5px 10px}
.dropdown-item:hover{background:var(--surface-alt)}
.dropdown-divider{margin:4px 0}
.page-link{font-size:12px;color:var(--brand);padding:4px 9px}
.page-item.active .page-link{background:var(--brand);border-color:var(--brand)}
.pagination{gap:2px}
.nav-link{font-size:13px}
.table{--bs-table-bg:transparent}
.modal-content{border-radius:6px;border:1px solid var(--border)}
.modal-header{padding:12px 16px;border-color:var(--border-l)}
.modal-body{padding:16px}
.modal-footer{padding:10px 16px;border-color:var(--border-l)}
.toast{border-radius:var(--radius);font-size:13px}

/* ── login ── */
.auth-body{background:var(--sidebar-bg);min-height:100vh;display:flex;align-items:center;justify-content:center}
.auth-card{background:#fff;border-radius:6px;box-shadow:0 2px 16px rgba(0,0,0,.3);width:100%;max-width:360px;padding:32px 28px}
.auth-logo{text-align:center;margin-bottom:20px}
.auth-logo img{height:46px}

/* ── sidebar ── */
.sidebar{
  position:fixed;top:0;left:0;width:var(--sidebar-w);height:100vh;
  background:var(--sidebar-bg);z-index:1040;
  display:flex;flex-direction:column;transition:transform .2s;
}
.sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:8px 8px;border-bottom:1px solid rgba(255,255,255,.06);flex-shrink:0;
}
.sidebar-brand{display:block;text-decoration:none;background:#fff;border-radius:4px;padding:8px 8px;flex:1}
.sidebar-brand:hover{text-decoration:none}
.sidebar-brand img{display:block;width:100%;height:auto}
.sidebar-close{color:rgba(255,255,255,.5);background:none;border:none;padding:0;font-size:16px;line-height:1}
.sidebar-section-label{
  font-size:10px;font-weight:600;color:rgba(255,255,255,.28);
  padding:12px 14px 4px;text-transform:uppercase;letter-spacing:.06em;
}
.sidebar-nav{list-style:none;padding:4px 0;margin:0;flex:1;overflow-y:auto;scrollbar-width:thin}
.sidebar-nav::-webkit-scrollbar{width:4px}
.sidebar-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}
.sidebar-divider{border-top:1px solid rgba(255,255,255,.06);margin:6px 14px}
.sidebar-item{margin:1px 6px}
.sidebar-link{
  display:flex;align-items:center;gap:8px;
  padding:6px 8px;border-radius:var(--radius);
  color:rgba(255,255,255,.55);font-size:13px;font-weight:400;
  text-decoration:none;transition:all .1s;
}
.sidebar-link:hover{background:rgba(255,255,255,.06);color:rgba(255,255,255,.85);text-decoration:none}
.sidebar-link i{font-size:14px;width:16px;text-align:center;flex-shrink:0;opacity:.7}
.sidebar-item.active .sidebar-link{background:rgba(var(--brand-rgb),.15);color:#fff;font-weight:500}
.sidebar-item.active .sidebar-link i{color:var(--brand);opacity:1}
.sidebar-footer{padding:8px 14px;border-top:1px solid rgba(255,255,255,.06);text-align:center;flex-shrink:0}
.sidebar-footer .text-muted{color:rgba(255,255,255,.2)!important;font-size:10px}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:1039}

/* ── main ── */
#main-wrapper{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;transition:margin .2s}

/* ── header ── */
.top-header{
  background:var(--surface);border-bottom:1px solid var(--border);
  height:var(--header-h);padding:0 16px;
  display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:1020;
}
.header-search{width:260px}
.header-search .form-control{height:28px;font-size:12px}
.header-search .input-group-text{height:28px;font-size:11px;padding:0 8px}
.hamburger-btn{color:var(--text);padding:0;background:none;border:none;line-height:1}

/* ── content ── */
.main-content{flex:1;padding:12px 16px}

/* ── footer ── */
.app-footer{padding:6px 16px;text-align:center;color:var(--text-3);font-size:10px;border-top:1px solid var(--border-l);background:var(--surface)}

/* ── breadcrumb ── */
.breadcrumb{font-size:11px;margin-bottom:6px;padding:0}
.breadcrumb-item{color:var(--text-3)}
.breadcrumb-item a{color:var(--text-2)}
.breadcrumb-item+.breadcrumb-item::before{font-size:10px;color:var(--text-3)}

/* ── back link ── */
.back-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-2);margin-bottom:6px}
.back-link:hover{color:var(--brand);text-decoration:none}
.back-link i{font-size:11px}

/* ── page heading ── */
.page-heading{font-size:16px;font-weight:700;margin:0;color:var(--text);letter-spacing:-.01em}
.page-heading-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-bottom:12px}

/* ── card ── */
.card{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:var(--surface);margin-bottom:10px}
.card-header{
  background:var(--surface-alt);border-bottom:1px solid var(--border-l);
  font-weight:600;font-size:13px;padding:8px 12px;
  display:flex;align-items:center;justify-content:space-between;
  color:var(--text);border-radius:var(--radius) var(--radius) 0 0;
}
.card-header i{color:var(--text-3)}
.card-header a{font-size:11px;font-weight:400}
.card-body{padding:10px 12px}

/* ── table ── */
.table-list{font-size:13px;margin-bottom:0}
.table-list thead th{
  background:var(--surface-alt);font-weight:600;font-size:11px;
  color:var(--text-2);letter-spacing:.03em;text-transform:uppercase;
  border-bottom:1px solid var(--border);padding:6px 10px;white-space:nowrap;
  position:sticky;top:0;
}
.table-list td{vertical-align:middle;padding:7px 10px;border-bottom:1px solid var(--border-l);color:var(--text)}
.table-list tbody tr{cursor:pointer;transition:background .08s}
.table-list tbody tr:hover{background:var(--brand-l)}
.table-list .fw-semibold{color:var(--text);font-weight:600}

/* ── status badge ── */
.status-badge{
  display:inline-block;padding:1px 6px;border-radius:10px;
  font-size:11px;font-weight:600;line-height:1.5;white-space:nowrap;
}
.status-prospect{background:#dbeafe;color:#1d4ed8}
.status-negotiation{background:#fef9c3;color:#854d0e}
.status-contracted{background:#dcfce7;color:#166534}
.status-construction{background:#ede9fe;color:#6d28d9}
.status-completed{background:#dbeafe;color:#1e40af}
.status-cancelled{background:#fee2e2;color:#b91c1c}
.status-pending{background:#ffedd5;color:#c2410c}
.status-alert{background:#fee2e2;color:#b91c1c}
.status-active{background:#dcfce7;color:#166534}
.status-unpaid{background:#fef9c3;color:#854d0e}
.status-paid{background:#dcfce7;color:#166534}
.status-overdue{background:#fee2e2;color:#b91c1c}
.status-survey{background:#dbeafe;color:#1d4ed8}
.status-inprogress{background:#ede9fe;color:#6d28d9}

/* ── search + tabs ── */
.search-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;margin-bottom:10px}
.search-bar .row{display:flex;flex-wrap:nowrap;align-items:center;gap:12px}
.search-bar .row>[class*="col"]{flex:none;width:auto;padding:0}
.search-bar .input-group{width:280px}
.search-bar .input-group .form-control{height:34px;font-size:13px}
.search-bar .input-group .input-group-text{height:34px;font-size:13px}
.status-tabs{
  gap:0;flex-wrap:nowrap;margin:0;overflow-x:auto;
  border:1px solid var(--border);border-radius:5px;
  background:var(--surface-alt);padding:2px;
}
.status-tabs .nav-item{margin:0}
.status-tabs .nav-link{
  color:var(--text-2);font-size:13px;font-weight:500;
  padding:5px 14px;border-radius:3px;border:none;
  background:transparent;line-height:1.4;white-space:nowrap;
  transition:all .12s;
}
.status-tabs .nav-link:hover{background:rgba(var(--brand-rgb),.08);color:var(--brand)}
.status-tabs .nav-link.active{
  background:var(--brand);color:#fff;font-weight:600;
  box-shadow:0 1px 3px rgba(var(--brand-rgb),.3);
}
.status-tabs .badge{
  font-size:10px;font-weight:700;vertical-align:1px;margin-left:3px;
  padding:1px 6px;min-width:18px;border-radius:9px;
  background:rgba(0,0,0,.1)!important;color:inherit;
}
.status-tabs .nav-link.active .badge{background:rgba(255,255,255,.25)!important;color:#fff}
@media(max-width:767.98px){
  .search-bar{flex-direction:column;gap:8px!important}
  .search-bar .input-group{width:100%!important}
  .status-tabs{flex-wrap:wrap;padding:2px}
}

/* ── stat card ── */
.stat-card{border-left:3px solid var(--brand);background:var(--surface);border-radius:var(--radius)}
.stat-card .stat-value{font-size:22px;font-weight:700;color:var(--text);line-height:1.1}
.stat-card .stat-label{font-size:11px;color:var(--text-2);margin-top:2px}
.stat-card.border-success{border-left-color:var(--ok)}
.stat-card.border-warning{border-left-color:var(--warn)}
.stat-card.border-danger{border-left-color:var(--ng)}
.stat-card.border-info{border-left-color:var(--info)}

/* ── alert list ── */
.alert-list-item{
  display:flex;align-items:center;gap:6px;
  padding:5px 4px;border-bottom:1px solid var(--border-l);
  font-size:13px;color:var(--text);border-radius:var(--radius);
}
.alert-list-item:last-child{border-bottom:none}
.alert-list-item:hover{background:var(--brand-l)}

/* ── detail header ── */
.detail-header{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:10px 14px;margin-bottom:10px;box-shadow:var(--shadow-sm);
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;
}
.detail-title{font-size:16px;font-weight:700;margin:0;display:flex;align-items:center;gap:8px;color:var(--text)}
.detail-meta{font-size:12px;color:var(--text-3)}
.detail-actions{display:flex;gap:4px;flex-wrap:wrap}

/* ── detail tabs ── */
.detail-tabs .nav-tabs{border-bottom:1px solid var(--border)}
.detail-tabs .nav-link{
  font-size:13px;color:var(--text-2);font-weight:500;
  border:none;padding:8px 14px;margin-bottom:-1px;
}
.detail-tabs .nav-link:hover{color:var(--brand)}
.detail-tabs .nav-link.active{color:var(--brand);font-weight:600;border-bottom:2px solid var(--brand);background:transparent}

/* ── info grid ── */
.info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:0 20px}
.info-item{display:flex;padding:6px 0;border-bottom:1px solid var(--border-l);font-size:13px;align-items:baseline}
.info-label{min-width:120px;color:var(--text-2);font-size:12px;font-weight:500;flex-shrink:0}
.info-value{font-weight:500;color:var(--text)}
.info-value a{font-weight:500}

/* ── timeline ── */
.timeline-item{
  display:flex;gap:10px;padding:6px 0;
  border-left:2px solid var(--border);margin-left:6px;padding-left:14px;
  position:relative;font-size:13px;
}
.timeline-item::before{content:'';position:absolute;left:-5px;top:10px;width:8px;height:8px;border-radius:50%;background:var(--brand);border:2px solid var(--surface)}
.timeline-date{color:var(--text-3);font-size:11px;min-width:80px;flex-shrink:0}

/* ── form ── */
.form-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;box-shadow:var(--shadow-sm)}
.form-section-header{
  font-weight:600;font-size:13px;padding:8px 14px;
  border-bottom:1px solid var(--border-l);background:var(--surface-alt);
  display:flex;align-items:center;gap:6px;border-radius:var(--radius) var(--radius) 0 0;
}
.form-section-header i{color:var(--text-3)}
.form-section-body{padding:12px 14px}
.form-page{max-width:900px}
.form-actions{display:flex;justify-content:flex-end;gap:8px;padding:16px 0;border-top:1px solid var(--border-l);margin-top:8px}

/* ── pagination ── */
.pagination-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;font-size:13px;color:var(--text-2);
  background:var(--surface);border-top:1px solid var(--border);
  margin-top:8px;border-radius:var(--radius);
  border:1px solid var(--border);
}
.pagination-bar .pagination{margin:0}
.pagination-bar .page-link{font-size:13px;padding:5px 11px;min-width:36px;text-align:center;border-color:var(--border)}
.pagination-bar .page-item.active .page-link{background:var(--brand);border-color:var(--brand);font-weight:600}
.pagination-bar .page-item.disabled .page-link{color:var(--text-3)}
.pagination-bar .page-info{font-weight:500;color:var(--text)}

/* ── map ── */
.map-container{height:calc(100vh - 120px);min-height:380px;background:#dde1e7;border-radius:var(--radius);position:relative}
.map-panel{position:absolute;top:8px;right:8px;width:300px;max-height:calc(100% - 16px);overflow-y:auto;background:var(--surface);border-radius:var(--radius);box-shadow:0 2px 12px rgba(0,0,0,.15);z-index:10}

/* ── responsive ── */
@media(max-width:991.98px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.show{transform:translateX(0)}
  .sidebar.show+.sidebar-overlay{display:block}
  #main-wrapper{margin-left:0}
  .header-search{width:160px}
  .map-panel{position:static;width:100%;margin-top:8px}
  .map-container{height:300px}
}
@media(max-width:575.98px){
  .main-content{padding:8px}
  .header-search{display:none!important}
  .info-grid{grid-template-columns:1fr}
  .detail-header{flex-direction:column;align-items:flex-start}
  .page-heading-bar{flex-direction:column;align-items:flex-start}
  .page-heading{font-size:15px}
}

/* ── utility ── */
.text-truncate-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.btn-xs{padding:2px 6px;font-size:11px}
.cursor-pointer{cursor:pointer}
.text-primary{color:var(--brand)!important}
.bg-primary{background-color:var(--brand)!important}
.fw-semibold{font-weight:600!important}
