/* AG REFORMAS - hoja de estilo. Colores: coral #EF5350, gris #9AA0A6, ambar #F4B740 */
:root{
  --coral:#EF5350; --coral-d:#C62828; --gray:#9AA0A6; --amber:#F4B740;
  --rose:#FFE7E5; --rose-l:#FFF4F3; --ink:#22252A; --muted:#7A8087; --line:#ECECEC;
  --bg:#F6F7F9; --card:#fff; --green:#2E9E5B; --red:#D64545; --blue:#3B82C4;
  --radius:12px; --shadow:0 1px 3px rgba(0,0,0,.07),0 4px 14px rgba(0,0,0,.04);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);font-size:15px;line-height:1.45}
a{color:var(--coral);text-decoration:none}
h1,h2{margin:0 0 4px}
.muted{color:var(--muted)} .tiny{font-size:12px} .pos{color:var(--green)} .neg{color:var(--red)} .amber-v{color:#B7791F}
.center{text-align:center} .mt{margin-top:16px} .grow{flex:1} .wrap{flex-wrap:wrap}
.row{display:flex;align-items:center} .gap{gap:10px} .end{justify-content:flex-end} .between{justify-content:space-between;width:100%}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.block{display:block;width:100%} .inline{display:inline} .ag-disp{font-weight:700;font-size:17px}

/* botones */
.ag-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--ink);padding:9px 14px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;white-space:nowrap}
.ag-btn:hover{filter:brightness(.97)}
.ag-btn.primary{background:var(--coral);border-color:var(--coral);color:#fff}
.ag-btn.amber{background:var(--amber);border-color:var(--amber);color:#3A2E00}
.ag-btn.ghost{background:#fff}
.ag-btn.danger{background:#fff;border-color:#F0C9C9;color:var(--red)}
.ag-btn.danger:hover{background:#FDF0F0}
.ag-btn.sm{padding:5px 9px;font-size:12.5px;border-radius:8px}
.ag-btn.big{padding:12px 22px;font-size:15px}

/* inputs */
.ag-in{width:100%;border:1px solid var(--line);border-radius:9px;padding:9px 11px;font-size:14px;background:#fff;color:var(--ink);font-family:inherit}
.ag-in:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px var(--rose)}
.ag-in.n{width:90px;text-align:right} textarea.ag-in{resize:vertical}
.ag-lbl{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin:10px 0 4px}
.ag-check{display:inline-flex;align-items:center;gap:7px;font-size:14px;margin-top:8px;cursor:pointer}

/* tarjetas */
.ag-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.ag-card.pad{padding:16px} .ag-card.soft{background:var(--rose-l);border-color:var(--rose)}
.ag-card.tablewrap{overflow:auto}

/* layout app */
.ag-app{display:flex;min-height:100vh}
.ag-side{width:230px;background:#fff;border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.ag-brand{padding:16px}
.ag-side nav{flex:1;overflow:auto;padding:0 10px}
.ag-nav{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:9px;color:var(--ink);font-weight:600;font-size:14px;margin-bottom:2px}
.ag-nav:hover{background:var(--bg)} .ag-nav.on{background:var(--rose);color:var(--coral-d)}
.ag-nav svg{flex-shrink:0;opacity:.85}
.ag-side-foot{padding:14px;border-top:1px solid var(--line)}
.ag-uname{font-weight:700} .ag-urole{font-size:12px;color:var(--muted);margin-bottom:8px}
.ag-main{flex:1;min-width:0;display:flex;flex-direction:column}
.ag-top{display:flex;align-items:center;justify-content:space-between;padding:12px 22px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5}
.ag-top-right{display:flex;gap:8px;margin-left:auto}
.ag-burger{display:none;font-size:22px;cursor:pointer}
.ag-content{padding:22px;max-width:1180px;width:100%}
.ag-section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px}
.ag-flash{padding:11px 14px;border-radius:10px;margin-bottom:12px;font-weight:600;font-size:14px}
.ag-flash.ok{background:#E7F6EC;color:#1E7A41;border:1px solid #BFE6CC}
.ag-flash.err{background:#FCEBEB;color:#B23232;border:1px solid #F2C9C9}

/* logo */
.ag-logo{display:flex;align-items:center;gap:10px}
.ag-logo-dots{display:flex;gap:4px} .ag-logo-dots.big span{width:16px;height:16px}
.ag-logo-dots.big{gap:6px;margin-bottom:14px}
.ag-logo-dots.big span:nth-child(1){background:var(--coral)} .ag-logo-dots.big span:nth-child(2){background:var(--gray)} .ag-logo-dots.big span:nth-child(3){background:var(--amber)}
.ag-logo-dots.big span{display:inline-block;border-radius:50%}
.ag-logo-name{font-weight:800;letter-spacing:.5px;line-height:1}
.ag-logo-sub{color:var(--muted);font-weight:600;letter-spacing:1px}

/* tablas */
.ag-tbl{width:100%;border-collapse:collapse;font-size:14px}
.ag-tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;padding:9px 10px;border-bottom:1px solid var(--line)}
.ag-tbl td{padding:10px;border-bottom:1px solid var(--line);vertical-align:middle}
.ag-tbl tr:last-child td{border-bottom:none}
.ag-tbl tr:hover td{background:#FAFBFC}
.actions{text-align:right;white-space:nowrap;display:flex;gap:5px;justify-content:flex-end;align-items:center}
.empty{text-align:center;color:var(--muted);padding:26px}

/* badges */
.ag-badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:12px;font-weight:700}
.ag-badge.green{background:#E7F6EC;color:#1E7A41} .ag-badge.red{background:#FCEBEB;color:#B23232}
.ag-badge.amber{background:#FDF3DD;color:#9A6B00} .ag-badge.gray{background:#EEF0F2;color:#5B6168}
.ag-badge.coral{background:var(--rose);color:var(--coral-d)} .ag-badge.blue{background:#E5F0FA;color:#2A6CA8}
.ag-badge.tiny{padding:1px 6px;font-size:10.5px}

/* kpis */
.ag-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.kpi{display:flex;flex-direction:column;gap:3px} .kpi-l{font-size:12.5px;color:var(--muted);font-weight:600}
.kpi-v{font-size:24px;font-weight:800;line-height:1.1}

/* modal */
.ag-modal-bg{position:fixed;inset:0;background:rgba(20,22,26,.45);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:30;overflow:auto}
.ag-modal{background:#fff;border-radius:14px;width:100%;max-width:640px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.ag-modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 18px;border-bottom:1px solid var(--line)}
.ag-modal-body{padding:18px} .ag-x{font-size:24px;color:var(--muted);line-height:1}
.kv{display:flex;justify-content:space-between;padding:5px 0;font-size:14px}
.kv.big{font-size:17px;border-top:1px solid var(--line);margin-top:6px;padding-top:9px}

/* tabs */
.ag-tabs{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.ag-tab{padding:6px 13px;border-radius:20px;background:#fff;border:1px solid var(--line);font-size:13px;font-weight:600;color:var(--muted)}
.ag-tab.on{background:var(--coral);border-color:var(--coral);color:#fff}

/* items presupuesto/factura */
.item-row{margin-bottom:8px;padding:10px!important}
.item-row .row{margin-bottom:6px} .item-row .tiny-cols .ag-in{font-size:13px}
.qty{width:70px} .price{width:100px} .iva{width:60px} .mat{width:100px} .hours{width:60px} .emp{width:130px}

/* control points / progreso */
.ag-progress{height:10px;background:#EEF0F2;border-radius:20px;overflow:hidden;margin-top:6px}
.ag-progress.sm{height:6px;width:80px;display:inline-block;vertical-align:middle}
.ag-progress-bar{height:100%;background:linear-gradient(90deg,var(--amber),var(--coral));border-radius:20px}
.ag-cps{display:flex;flex-wrap:wrap;gap:6px}
.ag-chip{border:1px solid var(--line);background:#fff;border-radius:20px;padding:5px 11px;font-size:13px;font-weight:600;cursor:pointer}
.ag-chip.on{background:#E7F6EC;border-color:#BFE6CC;color:#1E7A41}
.cp-row{margin-bottom:6px}

/* galeria fotos */
.ag-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;margin-top:8px}
.ag-photo{position:relative;border-radius:10px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:#000}
.ag-photo img{width:100%;height:100%;object-fit:cover;display:block}
.ag-photo-cap{position:absolute;left:0;right:0;bottom:0;background:rgba(0,0,0,.55);color:#fff;font-size:11px;padding:3px 6px}
.ag-photo-del{position:absolute;top:4px;right:4px} .ag-photo-del button{background:rgba(0,0,0,.5);color:#fff;border:none;border-radius:50%;width:22px;height:22px;cursor:pointer;font-size:14px}

/* agenda */
.ag-week{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.ag-day{background:#fff;border:1px solid var(--line);border-radius:10px;padding:8px;min-height:130px}
.ag-day.today{border-color:var(--coral);box-shadow:0 0 0 2px var(--rose)}
.ag-day-h{display:flex;align-items:center;gap:4px;font-size:12px;margin-bottom:6px;position:relative}
.ag-day-add{margin-left:auto;color:var(--coral);font-weight:800}
.ag-ev{display:block;font-size:11.5px;padding:4px 6px;border-radius:6px;margin-bottom:4px;background:#EEF0F2;color:var(--ink);line-height:1.25}
.ag-ev.coral{background:var(--rose);color:var(--coral-d)} .ag-ev.blue{background:#E5F0FA;color:#2A6CA8}
.ag-ev.green{background:#E7F6EC;color:#1E7A41} .ag-ev.amber{background:#FDF3DD;color:#9A6B00}
.ag-ev.done{opacity:.5;text-decoration:line-through} .ag-ev span{display:block;opacity:.7}
.ag-row-line{padding:6px 0;border-bottom:1px solid var(--line);display:flex;gap:8px;align-items:center;font-size:14px}
.done-row{opacity:.55} .ag-check-btn{background:none;border:none;font-size:18px;cursor:pointer;color:var(--green)}

/* auth + landing */
.ag-auth{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,var(--rose-l),#fff)}
.ag-auth-card{background:#fff;border-radius:16px;box-shadow:var(--shadow);padding:30px;width:100%;max-width:380px}
.ag-auth-card.wide{max-width:480px} .ag-auth-logo{display:flex;justify-content:center;margin-bottom:18px}
.ag-landing{background:#fff}
.ag-lhead{display:flex;justify-content:space-between;align-items:center;padding:16px 28px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff;z-index:5}
.ag-lhead-right{display:flex;align-items:center;gap:14px}
.ag-hero{background:linear-gradient(135deg,var(--rose),var(--rose-l));padding:64px 28px;text-align:center}
.ag-hero-in{max-width:720px;margin:0 auto} .ag-hero h1{font-size:34px;line-height:1.15} .ag-hero p{font-size:17px;color:var(--muted)}
.ag-hero-cta{display:flex;gap:10px;justify-content:center;margin-top:22px}
.ag-services{padding:48px 28px;max-width:1080px;margin:0 auto} .ag-services h2{font-size:24px;margin-bottom:20px}
.ag-svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px}
.ag-svc-dot{width:34px;height:34px;border-radius:9px;margin-bottom:10px}
.ag-contact{padding:10px 28px 56px;max-width:620px;margin:0 auto}
.ag-lfoot{padding:24px 28px;border-top:1px solid var(--line);text-align:center;color:var(--muted);font-size:13px}
.ag-link{font-weight:600}

/* itemlist / confirm */
.ag-itemlist{list-style:none;padding:0;margin:14px 0;font-size:14px} .ag-itemlist li{padding:6px 0;border-bottom:1px solid var(--line)}
.ag-confirm-done{background:#E7F6EC;border:1px solid #BFE6CC;border-radius:12px;padding:16px;margin-top:14px;color:#1E7A41}

/* factura impresion */
.ag-print-body{background:#fff;padding:0}
.ag-invoice{max-width:800px;margin:0 auto;padding:32px}
.inv-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--coral);padding-bottom:16px}
.inv-meta{text-align:right} .inv-meta h1{color:var(--coral);font-size:26px}
.inv-client{margin:18px 0} .inv-items{margin:14px 0} .inv-items th{background:var(--rose-l)}
.inv-totals{max-width:300px;margin-left:auto;margin-top:10px}
.inv-legal{background:var(--rose-l);border:1px solid var(--rose);border-radius:8px;padding:10px;font-size:12px;color:#7A4A48;margin-top:14px}
.inv-pay{margin-top:14px;font-size:14px}
.inv-seal{display:flex;gap:14px;align-items:center;margin-top:18px;padding-top:14px;border-top:1px dashed var(--line)}
#qr{width:90px;height:90px} #qr img,#qr canvas{width:90px;height:90px}
.ag-print-bar{max-width:800px;margin:16px auto;display:flex;gap:10px;justify-content:flex-end}

@media print{
  .ag-print-bar{display:none} .ag-invoice{padding:0;max-width:100%}
  body{background:#fff}
}
@media(max-width:860px){
  .grid2{grid-template-columns:1fr} .ag-week{grid-template-columns:1fr;gap:6px} .ag-day{min-height:auto}
  .ag-side{position:fixed;left:-240px;z-index:40;transition:.2s} #ag-menu:checked ~ .ag-side{left:0}
  .ag-burger{display:block} .ag-content{padding:14px}
  .ag-kpis{grid-template-columns:1fr 1fr}
}

/* ---- PJAX: barra de progreso + toasts ---- */
#ag-pjax-bar{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,#1A56DB,#E5A11C,#E23A2D);z-index:9999;transition:width .3s ease;opacity:0}
#ag-pjax-bar.on{width:85%;opacity:1}
#ag-toasts{position:fixed;right:18px;bottom:18px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:90vw}
.ag-toast{background:#16181D;color:#fff;padding:13px 18px;border-radius:12px;box-shadow:0 10px 30px rgba(0,0,0,.25);font-size:14px;font-weight:600;opacity:1;transform:translateY(0);transition:.35s;border-left:4px solid #2FA46A}
.ag-toast.err{border-left-color:#E23A2D}
.ag-toast.out{opacity:0;transform:translateY(10px)}

/* ---- galeria admin (site) ---- */
.ag-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}
.ag-photo{position:relative;border-radius:12px;overflow:hidden;aspect-ratio:4/3;background:#eef1f4;box-shadow:0 4px 14px rgba(0,0,0,.08)}
.ag-photo img{width:100%;height:100%;object-fit:cover}
.ag-photo-cap{position:absolute;left:0;right:0;bottom:0;padding:18px 10px 8px;color:#fff;font-size:12px;font-weight:600;background:linear-gradient(transparent,rgba(0,0,0,.7))}
.ag-photo-del{position:absolute;top:6px;right:6px}
.ag-photo-del button{border:none;background:rgba(0,0,0,.6);color:#fff;width:26px;height:26px;border-radius:7px;cursor:pointer;font-size:14px;line-height:1}

/* ---- progreso obra en dashboard ---- */
.ag-progress{display:inline-block;flex:1;height:8px;background:#e9ecf1;border-radius:20px;overflow:hidden;min-width:80px}
.ag-progress.sm{max-width:240px}
.ag-progress-bar{display:block;height:100%;background:linear-gradient(90deg,#1A56DB,#2FA46A);border-radius:20px}
.ag-row-line{display:flex;align-items:center;gap:12px;padding:9px 0;border-bottom:1px solid var(--line,#eef1f4)}
.ag-row-line:last-child{border-bottom:none}
.kpi-v.amber-v{color:#C8841A}
.row.wrap{flex-wrap:wrap}

/* ============ RESPONSIVE MOVIL ============ */
@media(max-width:860px){
  .ag-side{position:fixed;left:-280px;top:0;bottom:0;width:260px;z-index:200;transition:left .25s ease;box-shadow:0 0 40px rgba(0,0,0,.25)}
  #ag-menu:checked ~ .ag-side{left:0}
  #ag-menu:checked ~ .ag-main::before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:150}
  .ag-main{margin-left:0}
  .ag-burger{display:inline-flex !important}
  .grid2{grid-template-columns:1fr !important}
  .ag-kpis{grid-template-columns:1fr 1fr !important}
  .tablewrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tablewrap table{min-width:560px}
  .ag-modal{width:96vw;max-height:92vh;overflow:auto}
  .ag-section-head{flex-wrap:wrap;gap:10px}
  .row.gap{flex-wrap:wrap}
}
@media(max-width:560px){
  .ag-kpis{grid-template-columns:1fr !important}
  .ag-content{padding:14px}
  .ag-btn{padding:11px 16px}
  .ag-form-grid,.grid2{grid-template-columns:1fr !important}
}
