/* Alpine Renova Ops — admin theme (navy + brass, matching the marketing site) */
:root{
  --bg:#f6f7f9; --surface:#fff; --ink:#16202E; --ink-soft:#38465A; --muted:#64748B;
  --line:#e3e9f1; --line-2:#cbd6e3;
  --navy:#16467E; --navy-d:#0F3460; --navy-soft:rgba(22,70,126,.08);
  --brass:#B08842; --brass-soft:rgba(176,136,66,.12);
  --green:#1d7a3a; --green-soft:#e8f6ec; --red:#b5121e; --red-soft:#fdecec;
  --amber:#9a6a00; --amber-soft:#fdf3df;
  --ff-head:"Plus Jakarta Sans","Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --ff-body:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --radius:14px; --shadow:0 1px 2px rgba(17,19,22,.04),0 8px 24px rgba(17,19,22,.06);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--ff-body);background:var(--bg);color:var(--ink);font-size:12px;line-height:1.5}
a{color:var(--navy);text-decoration:none}a:hover{text-decoration:underline}
h1,h2,h3{font-family:var(--ff-head);font-weight:800;letter-spacing:-.02em;line-height:1.15;margin:0 0 .4em}
h1{font-size:1.7rem}h2{font-size:1.25rem}h3{font-size:1.02rem}
.muted{color:var(--muted)}.small{font-size:.85rem}

/* ── Bootstrap reconciliation: our component classes win over Bootstrap's ──── */
.card{display:block}                 /* Bootstrap makes .card flex-column */
.badge{vertical-align:baseline}
body{--bs-body-font-family:var(--ff-body);--bs-body-bg:var(--bg);--bs-body-color:var(--ink)}

/* ── Top navigation (Bootstrap navbar, themed navy + brass) ───────────────── */
.ar-nav{background:#fff;border-bottom:3px solid var(--brass);box-shadow:0 2px 10px rgba(19,36,63,.06);z-index:1030}
.navwrap{width:90%;max-width:90%;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;gap:4px 14px}
.ar-nav .navbar-brand{margin:0;padding-top:.4rem;padding-bottom:.4rem}
.ar-nav .navbar-brand img{display:block;height:62px;width:auto}
.ar-nav .navbar-toggler{padding:6px 9px}
.ar-nav .navbar-nav{gap:2px;align-items:center}
.ar-nav .nav-link{color:var(--ink);padding:7px 12px;border-radius:999px;font-family:var(--ff-head);font-weight:600;font-size:12px;line-height:1.2}
.ar-nav .ar-dropdown-toggle{display:inline-flex;align-items:center;gap:4px}
.ar-nav .nav-link:hover,.ar-nav .nav-link:focus{color:var(--navy);background:rgba(19,36,63,.06)}
.ar-nav .nav-link.active{color:#fff;background:var(--navy)}
.ar-search-form{flex:0 0 auto}
.ar-search-form .form-control{width:160px;background:#f1f3f7;border:1px solid #dfe4ec;color:#1b2435;border-radius:999px;padding:7px 14px;font-size:.85rem}
.ar-search-form .form-control::placeholder{color:#8a99ad}
.ar-search-form .form-control:focus{background:#fff;border-color:var(--brass);box-shadow:none;color:#1b2435}
.ar-lang{appearance:none;-webkit-appearance:none;background:#f1f3f7 url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2333445f' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 10px center;
  width:auto;min-width:0;flex:0 0 auto;color:#1b2435;border:1px solid #dfe4ec;border-radius:999px;padding:6px 28px 6px 12px;font-family:var(--ff-head);font-weight:600;font-size:12px;cursor:pointer;line-height:1.2}
.ar-lang:focus{outline:none;border-color:var(--brass);box-shadow:none}
.ar-lang option{color:#16202E;background:#fff}
/* Documents dropdown + Settings gear */
.ar-caret{opacity:.55;flex:0 0 auto;margin-top:1px}
.ar-nav .nav-item.dropdown{position:relative}
.ar-nav .ar-menu{display:none;position:absolute;top:calc(100% + 6px);left:0;min-width:190px;background:#fff;border:1px solid #e6e9f0;border-radius:12px;box-shadow:0 12px 30px rgba(19,36,63,.14);padding:6px;margin:0;list-style:none;z-index:1040}
.ar-nav .ar-menu.show{display:block}
.ar-nav .ar-menu .dropdown-item{display:block;border-radius:8px;padding:7px 12px;font-family:var(--ff-head);font-weight:600;font-size:12px;color:var(--ink);text-decoration:none}
.ar-nav .ar-menu .dropdown-item:hover{background:rgba(19,36,63,.06);color:var(--navy)}
.ar-nav .ar-menu .dropdown-item.active{background:var(--navy);color:#fff}
.ar-nav-icon{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;color:var(--ink-soft);text-decoration:none;flex:0 0 auto}
.ar-nav-icon:hover{background:rgba(19,36,63,.06);color:var(--navy)}
.ar-nav-icon.active{background:var(--navy);color:#fff}
@media(max-width:991.98px){
  .navwrap{padding:4px 0}
  .ar-nav .navbar-collapse{padding:6px 0 4px}
  .ar-nav .navbar-nav{gap:1px;width:100%}
  .ar-nav .nav-link{display:block;width:100%}
  .ar-search-form{width:100%}
  .ar-search-form .form-control{width:100%}
  .ar-lang{margin-top:8px;align-self:flex-start;width:auto}
  .ar-nav .ar-menu{position:static;box-shadow:none;border:none;padding:2px 0 2px 14px;min-width:0}
  .ar-nav-icon{margin-top:6px}
}
.appfoot{border-top:1px solid var(--line);background:#fff;margin-top:40px}
.appfoot .wrap{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 22px;font-size:.82rem;color:var(--muted);flex-wrap:wrap}

.wrap{width:90%;max-width:90%;margin:0 auto;padding:26px 22px}
.page-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.page-head h1{margin:0}
.spacer{flex:1}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);transition:box-shadow .22s ease,border-color .22s ease}
.card:hover{box-shadow:0 1px 2px rgba(17,19,22,.05),0 10px 30px rgba(22,70,126,.09);border-color:#d7e0ec}
.card-pad{padding:20px 22px}
.card-pad h2,.card>.card-pad h2{font-size:1.06rem;letter-spacing:-.01em}
.grid{display:grid;gap:16px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}
@media(max-width:560px){.grid.cols-4{grid-template-columns:1fr}}

.btn{display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-head);font-weight:700;font-size:.92rem;
  padding:9px 16px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;background:var(--navy);color:#fff;
  box-shadow:0 1px 2px rgba(16,40,80,.10);transition:background .18s ease,transform .08s ease,box-shadow .18s ease}
.btn:hover{background:var(--navy-d);text-decoration:none;box-shadow:0 2px 8px rgba(16,40,80,.18)}
.btn:active{transform:translateY(1px)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{background:#fff;border-color:var(--ink)}
.btn--brass{background:var(--brass);color:#fff}.btn--brass:hover{background:#946f30}
.btn--danger{background:#fff;color:var(--red);border-color:#e7b9bd}.btn--danger:hover{background:var(--red-soft)}
.btn--sm{padding:6px 12px;font-size:.84rem}
.actions{display:flex;gap:8px;flex-wrap:wrap}

table{width:100%;border-collapse:collapse;font-size:12px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{font-family:var(--ff-head);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
tbody tr:hover{background:var(--navy-soft)}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}

.badge{display:inline-block;font-family:var(--ff-head);font-weight:700;font-size:.72rem;letter-spacing:.04em;
  text-transform:uppercase;padding:3px 9px;border-radius:999px;background:var(--navy-soft);color:var(--navy)}
.badge.green{background:var(--green-soft);color:var(--green)}
.badge.red{background:var(--red-soft);color:var(--red)}
.badge.amber{background:#fdf3df;color:var(--amber)}
.badge.brass{background:var(--brass-soft);color:#7a5a23}
.badge.grey{background:#eef1f5;color:var(--muted)}

label{display:block;font-family:var(--ff-head);font-weight:600;font-size:.82rem;margin:0 0 5px;color:var(--ink-soft)}
input,select,textarea{width:100%;padding:10px 12px;border:1.5px solid var(--line-2);border-radius:10px;font:inherit;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 4px var(--navy-soft)}
textarea{min-height:120px;resize:vertical}
.field{margin-bottom:14px}
.row{display:grid;gap:14px;margin:0}.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:2fr 1fr 1fr}
@media(max-width:680px){.row.c2,.row.c3{grid-template-columns:1fr}}
.req{color:var(--brass)}

.alert{padding:12px 16px;border-radius:12px;margin-bottom:18px;font-weight:600;border:1px solid}
.alert.ok{background:var(--green-soft);color:var(--green);border-color:#bfe6c9}
.alert.err{background:var(--red-soft);color:var(--red);border-color:#e7b9bd}
.alert.info{background:var(--navy-soft);color:var(--navy);border-color:#cbd9ee}

.kv{display:grid;grid-template-columns:140px 1fr;gap:6px 14px}
.kv dt{color:var(--muted);font-size:.85rem}.kv dd{margin:0;font-weight:600}

.empty{text-align:center;padding:48px 20px;color:var(--muted)}
.stat{display:flex;flex-direction:column;gap:3px;position:relative;overflow:hidden}
.card.stat::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--navy),var(--brass))}
.stat .muted.small{text-transform:uppercase;letter-spacing:.06em;font-size:.7rem;font-weight:600}
.stat .n{font-family:var(--ff-head);font-weight:800;font-size:1.75rem;color:var(--navy);letter-spacing:-.02em;line-height:1.1;margin-top:2px}
.stat .n .suffix{color:var(--brass);font-size:.7em}
.note{font-size:.82rem;color:var(--muted);margin-top:6px}
.contract-clauses{margin:10px 0 0;padding-left:20px}
.contract-clauses li{margin-bottom:9px;line-height:1.55;color:var(--ink-soft)}
.contract-clauses li b{color:var(--ink)}
.itemtable input{padding:7px 9px}
hr{border:none;border-top:1px solid var(--line);margin:18px 0}
/* Connected progress timeline (project lifecycle) */
.stepper{display:flex;align-items:flex-start;gap:0;overflow-x:auto;padding:6px 2px 2px;-webkit-overflow-scrolling:touch}
.step{flex:1 0 auto;min-width:92px;display:flex;flex-direction:column;align-items:center;gap:9px;position:relative;background:none;border:0;padding:0;font-family:var(--ff-head);font-weight:600;font-size:.74rem;line-height:1.25;color:var(--muted);text-align:center}
.step::before{content:"";position:absolute;top:11px;right:50%;width:100%;height:2px;background:var(--line-2);z-index:0}
.step:first-child::before{display:none}
.step .dot{width:24px;height:24px;border-radius:50%;background:#fff;border:2px solid var(--line-2);z-index:1;position:relative;transition:.2s}
.step.done{color:var(--ink-soft)}
.step.done::before{background:var(--green)}
.step.done .dot{background:var(--green);border-color:var(--green)}
.step.done .dot::after{content:"✓";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.72rem;font-weight:800}
.step.now{color:var(--navy);font-weight:700}
.step.now .dot{background:var(--navy);border-color:var(--navy);box-shadow:0 0 0 5px var(--navy-soft)}
.step.now .dot::after{content:"";position:absolute;inset:7px;border-radius:50%;background:var(--brass)}

.plan td{vertical-align:top}
.plan tr td:first-child{width:120px}
.linkbtn{background:none;border:none;cursor:pointer;font-size:1.05rem;line-height:1;color:var(--navy);padding:0}
.pager{display:flex;gap:14px;align-items:center;justify-content:center;margin-top:16px}
.captcha-box{display:inline-flex;align-items:center;gap:6px;margin-left:8px;font-size:.85rem;flex-wrap:wrap}
.captcha-box .cap-q{color:var(--ink-soft)}
.captcha-in{width:84px;padding:5px 9px;border:1.5px solid var(--line-2);border-radius:8px;font:inherit;letter-spacing:.12em;text-transform:uppercase;text-align:center}
.att-gallery{display:flex;flex-wrap:wrap;gap:12px;margin-top:6px}
.att-tile{width:150px}
.att-thumb{width:150px;height:108px;object-fit:cover;border-radius:9px;border:1px solid var(--line);background:#f1f4f8;display:block}
.att-thumb.att-file{display:flex;align-items:center;justify-content:center;font-size:2rem;text-decoration:none}
.att-meta{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-top:4px;font-size:.74rem}
.att-meta a{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

.totals{margin-left:auto;width:280px}
.totals .row2{display:flex;justify-content:space-between;padding:5px 0}
.totals .grand{border-top:2px solid var(--ink);margin-top:6px;padding-top:8px;font-family:var(--ff-head);font-weight:800;font-size:1.1rem}

/* ── Responsive: phones & tablets ─────────────────────────────────────────── */
@media(max-width:900px){
  .wrap{padding:20px 16px}
}
@media(max-width:760px){
  /* Top bar: brand on its own row, nav becomes a swipeable strip */
  .topbar .wrap{flex-wrap:wrap;gap:10px;padding:10px 14px}
  .topbar nav{width:100%;margin-left:0;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}
  .topbar nav a{white-space:nowrap;flex:0 0 auto}
  /* Wide tables scroll horizontally instead of overflowing */
  table{display:block;width:100%;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .page-head{flex-wrap:wrap;gap:10px}
  .totals{width:100%}
}
@media(max-width:560px){
  .wrap{padding:16px 12px}
  .card-pad{padding:14px}
  h1{font-size:1.4rem}
  .actions .btn{flex:1 1 auto;text-align:center}
  .appfoot .wrap{flex-direction:column;align-items:flex-start;gap:4px}
}
/* Comfortable tap targets on touch screens */
@media(hover:none){
  .btn,.ar-nav .nav-link,select,input,textarea{min-height:40px}
  .btn--sm{min-height:32px}
}

/* Phone: turn list tables marked .stack into stacked cards (label : value rows). */
@media(max-width:680px){
  table.stack{display:block}
  table.stack thead{display:none}
  table.stack tbody,table.stack tr{display:block}
  table.stack tr{border:1px solid var(--line);border-radius:12px;margin-bottom:10px;padding:6px 12px;background:var(--surface)}
  table.stack td{display:flex;justify-content:space-between;align-items:center;gap:14px;border:0;padding:7px 0;text-align:right;white-space:normal}
  table.stack td::before{content:attr(data-label);color:var(--muted);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.03em;text-align:left;flex:0 0 auto}
  table.stack td:first-child{font-weight:600}
  table.stack td:empty,table.stack td[data-label=""]:empty{display:none}
}
