/* COMPONENTS — forms, buttons, modals, dropdowns, login */
/* Auto-split from index.html */

/* ══ FORM ══ */
.form-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px;}
.form-row.full{flex-wrap:nowrap;}
.form-group{display:flex;flex-direction:column;flex:1;min-width:100px;}
.form-group.half{flex:0 0 calc(50% - 5px);}
label,.lbl{
  font-size:10px;color:var(--text3);font-weight:700;
  margin-bottom:5px;letter-spacing:.8px;text-transform:uppercase;
}
input,select,textarea{
  background:var(--card2);border:1.5px solid var(--border);border-radius:8px;
  padding:10px 12px;color:var(--text);font-size:13.5px;outline:none;
  width:100%;font-family:'Inter',sans-serif;
  transition:border-color .2s,box-shadow .2s;
  -webkit-appearance:none;
}
input:focus,select:focus{
  border-color:var(--green);background:#fff;
  box-shadow:0 0 0 3px rgba(42,122,42,0.12);
}
input::placeholder{color:var(--text3);}
input[readonly]{opacity:.6;cursor:default;background:var(--bg);}
select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%238a9b8a' d='M5 6L0 0h10z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;
}

/* ══ BUTTONS ══ */
.btn{
  padding:9px 16px;border-radius:6px;border:1.5px solid transparent;cursor:pointer;
  font-weight:600;font-size:12px;color:#fff;transition:all .15s;
  letter-spacing:.2px;font-family:'Inter',sans-serif;
  display:inline-flex;align-items:center;justify-content:center;gap:5px;
  white-space:nowrap;
}
.btn:active{transform:scale(.97);}
.btn:disabled{opacity:.5;cursor:default;}

/* Primary — filled green */
.btn-primary,.btn-p{
  background:var(--green);border-color:var(--green);color:#fff;
}
.btn-primary:hover,.btn-p:hover{background:var(--green-dark);border-color:var(--green-dark);}

/* Secondary — outlined green */
.btn-secondary,.btn-g{
  background:#fff;color:var(--green);border:1.5px solid var(--green);
}
.btn-secondary:hover{background:var(--green-light);}

/* Danger — now themed green (outlined) instead of red */
.btn-danger,.btn-d{
  background:#fff;color:var(--green);border:1.5px solid var(--green);
}
.btn-danger:hover{background:var(--green-light);}

/* Share button — outlined slate */
.btn-share{
  background:#fff;color:#444;border:1.5px solid #aaa;
}
.btn-share:hover{background:#f5f5f5;}

/* Email button — now themed green (outlined) instead of red */
.btn-email{
  background:#fff;color:var(--green);border:1.5px solid var(--green);
}
.btn-email:hover{background:var(--green-light);}

/* Keep .btn-wa for backward compat but unused */
.btn-wa{background:#25d366;border-color:#25d366;color:#fff;}

.btn-row,.brow{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px;align-items:stretch;}
.btn-row .btn{flex:1;min-width:54px;font-size:12px;padding:9px 6px;}

/* ══ CUSTOM DROPDOWN (replaces native select for customer) ══ */
.custom-select-wrap{position:relative;width:100%;}
.custom-select-display{
  background:var(--card2);border:1.5px solid var(--border);border-radius:8px;
  padding:10px 36px 10px 12px;color:var(--text);font-size:13.5px;
  width:100%;font-family:'Inter',sans-serif;cursor:pointer;
  transition:border-color .2s,box-shadow .2s;
  display:flex;align-items:center;justify-content:space-between;
  user-select:none;min-height:44px;box-sizing:border-box;
  position:relative;
}
.custom-select-display::after{
  content:'';position:absolute;right:12px;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-top:6px solid #8a9b8a;border-bottom:none;
  pointer-events:none;
}
.custom-select-display.open{
  border-color:var(--green);background:#fff;
  box-shadow:0 0 0 3px rgba(42,122,42,0.12);
}
.custom-select-display.open::after{
  border-top:none;border-bottom:6px solid var(--green);
}
.custom-select-list{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:9999;
  background:#fff;border:1.5px solid var(--green);border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,0.15);max-height:260px;overflow-y:auto;
  display:none;
}
.custom-select-list.open{display:block;}
.custom-select-option{
  padding:11px 14px;font-size:13.5px;color:var(--text);cursor:pointer;
  border-bottom:1px solid var(--border);transition:background .12s;
  display:flex;align-items:center;gap:8px;
}
.custom-select-option:last-child{border-bottom:none;}
.custom-select-option:hover,.custom-select-option:active{background:var(--green-light);}
.custom-select-option.selected{
  background:var(--green);color:#fff;font-weight:700;
}
.custom-select-option.placeholder{color:var(--text3);}
/* Group header — customer name when it has multiple branches */
.cust-group-header{
  padding:8px 14px 4px;font-size:11px;font-weight:800;
  color:var(--green-dark);text-transform:uppercase;letter-spacing:.5px;
  background:var(--green-light);border-bottom:1px solid var(--border);
  cursor:default;
}
/* Branch sub-items — indented under group header */
.cust-branch-option{
  padding-left:26px !important;font-size:13px;color:var(--text);
}
/* Hidden real select — still in DOM for form reads */
.custom-select-wrap select{display:none;}
.inv-wrap{overflow-x:auto;margin-bottom:8px;}
.inv-table{width:100%;border-collapse:collapse;font-size:12px;min-width:580px;}
.inv-table th{background:var(--green);color:#fff;font-weight:600;padding:9px 6px;text-align:left;white-space:nowrap;font-size:11px;letter-spacing:.4px;}
.inv-table td{padding:7px 5px;border-bottom:1px solid #f0f0f0;vertical-align:middle;}
.inv-table tr:nth-child(even) td{background:#fafcfa;}
.inv-table input,.inv-table select{
  border:1px solid var(--border);border-radius:6px;padding:5px 6px;
  font-size:12px;width:100%;background:#fff;
}
.inv-table tfoot td{font-weight:600;padding:8px 6px;background:var(--card2);}
.add-row-btn{
  width:100%;padding:10px;background:#fff;border:2px dashed var(--border2);
  border-radius:8px;color:var(--green);font-weight:700;cursor:pointer;
  margin-top:8px;font-size:13px;font-family:'Inter',sans-serif;transition:all .12s;
}
.add-row-btn:hover{border-color:var(--green);background:var(--green-light);}
.del-btn{background:none;border:none;cursor:pointer;color:var(--danger);font-size:15px;padding:2px 5px;}

/* ══ INVOICE PREVIEW ══ */
.inv-preview{/* → see invoice-template.css */}
.inv-header-grid{/* → see invoice-template.css */}
.inv-header-left{/* → see invoice-template.css */}
.inv-header-right{/* → see invoice-template.css */}
.inv-company-impact{/* → see invoice-template.css */}
.inv-center-block{/* → see invoice-template.css */}
.inv-title-big{/* → see invoice-template.css */}
.inv-num-center{/* → see invoice-template.css */}
.inv-footer{/* → see invoice-template.css */}
.inv-footer-grid{/* → see invoice-template.css */}
.prev-table{/* → see invoice-template.css */}
.prev-table th{/* → see invoice-template.css */}
.prev-table td{/* → see invoice-template.css */}
.prev-table tfoot td{/* → see invoice-template.css */}

/* ══ LOGIN ══ */
.login-screen{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:100vh;padding:32px 20px;
  background:linear-gradient(160deg,var(--green-dark) 0%,var(--green-mid) 100%);
}
.login-card{
  background:#fff;border-radius:16px;padding:24px;width:100%;max-width:360px;
  box-shadow:0 8px 32px rgba(0,0,0,0.25);
}
.login-logo-wrap{text-align:center;margin-bottom:24px;}
.login-logo-icon{
  width:72px;height:72px;background:var(--green-light);border:2px solid var(--border);
  border-radius:18px;display:flex;align-items:center;justify-content:center;
  font-size:40px;margin:0 auto 12px;
}
.divider{display:flex;align-items:center;gap:10px;margin:14px 0;color:var(--text3);font-size:12px;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--border);}
.google-btn{
  width:100%;padding:11px;background:#fff;border:1.5px solid var(--border);
  border-radius:8px;display:flex;align-items:center;justify-content:center;
  gap:10px;font-size:13px;font-weight:700;cursor:pointer;color:var(--text);
  font-family:'Inter',sans-serif;
}

/* ══ TOAST ══ */
.toast{
  position:fixed;bottom:74px;left:50%;transform:translateX(-50%);
  background:var(--green-dark);color:#fff;padding:10px 22px;border-radius:24px;
  font-size:13px;font-weight:600;z-index:9999;display:none;
  white-space:nowrap;box-shadow:0 4px 16px rgba(0,0,0,0.22);
}

/* ══ MODAL (bottom sheet) ══ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:500;display:none;align-items:flex-end;justify-content:center;}
.modal-overlay.open{display:flex;}
.modal{background:#fff;border-radius:20px 20px 0 0;padding:20px 16px 40px;width:100%;max-width:430px;max-height:88vh;overflow-y:auto;}
.modal-title{font-size:16px;font-weight:800;margin-bottom:16px;color:var(--text);padding-bottom:12px;border-bottom:1px solid var(--border);}
.modal-close{float:right;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text3);line-height:1;}

/* ══ OFFLINE ══ */
.offline-banner{background:#e65100;color:#fff;text-align:center;padding:7px;font-size:12px;font-weight:700;display:none;letter-spacing:.3px;}
.offline-banner.show{display:block;}

/* ══ SPINNER ══ */
.spinner{display:inline-block;width:15px;height:15px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ══ SPLIT SAVE BUTTON ══ */
.save-btn-wrap{position:relative;display:flex;flex:1;min-width:54px;}
.save-btn-main{
  flex:1;border-radius:6px 0 0 6px !important;
  border-right:none !important;
  /* Override btn-primary to outlined green */
  background:#fff !important;color:var(--green) !important;
  border:1.5px solid var(--green) !important;
  font-weight:700;
}
.save-btn-main:hover{background:var(--green-light) !important;}
.save-btn-arrow{
  background:#fff;border:1.5px solid var(--green);border-left:none;
  border-radius:0 6px 6px 0;padding:9px 9px;cursor:pointer;color:var(--green);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:background .15s;
}
.save-btn-arrow:hover{background:var(--green-light);}
.save-btn-arrow svg{pointer-events:none;}
.save-dropdown{
  position:absolute;top:calc(100% + 4px);left:0;min-width:160px;z-index:9999;
  background:#fff;border:1.5px solid var(--green);border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,0.15);display:none;
}
.save-dropdown.open{display:block;}
.save-dropdown-item{
  padding:12px 14px;font-size:13px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:8px;color:var(--text);
  border-bottom:1px solid var(--border);transition:background .12s;
}
.save-dropdown-item:last-child{border-bottom:none;}
.save-dropdown-item:hover{background:var(--green-light);}

/* ══ GENERIC CUSTOM SELECT (used for all dropdowns) ══ */
.gcs-wrap{position:relative;width:100%;}
.gcs-display{
  background:var(--card2);border:1.5px solid var(--border);border-radius:8px;
  padding:10px 36px 10px 12px;color:var(--text);font-size:13.5px;
  width:100%;font-family:'Inter',sans-serif;cursor:pointer;
  transition:border-color .2s,box-shadow .2s;
  display:flex;align-items:center;justify-content:space-between;
  user-select:none;min-height:44px;box-sizing:border-box;position:relative;
}
.gcs-display::after{
  content:'';position:absolute;right:12px;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-top:6px solid #8a9b8a;border-bottom:none;
  pointer-events:none;
}
.gcs-display.open{border-color:var(--green);background:#fff;box-shadow:0 0 0 3px rgba(42,122,42,0.12);}
.gcs-display.open::after{border-top:none;border-bottom:6px solid var(--green);}
.gcs-list{
  position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:9999;
  background:#fff;border:1.5px solid var(--green);border-radius:8px;
  box-shadow:0 8px 24px rgba(0,0,0,0.15);max-height:260px;overflow-y:auto;display:none;
}
.gcs-list.open{display:block;}
.gcs-option{
  padding:11px 14px;font-size:13.5px;color:var(--text);cursor:pointer;
  border-bottom:1px solid var(--border);transition:background .12s;
  display:flex;align-items:center;gap:8px;
}
.gcs-option:last-child{border-bottom:none;}
.gcs-option:hover,.gcs-option:active{background:var(--green-light);}
.gcs-option.selected{background:var(--green);color:#fff;font-weight:700;}
.gcs-option.placeholder{color:var(--text3);}
.gcs-group-header{
  padding:8px 14px 4px;font-size:11px;font-weight:800;
  color:var(--green-dark);text-transform:uppercase;letter-spacing:.5px;
  background:var(--green-light);border-bottom:1px solid var(--border);cursor:default;
}
.gcs-wrap select{display:none;}
/* ══ HAMBURGER MENU ══ */
.hamburger-btn{
  background:none;border:none;cursor:pointer;padding:6px;
  display:flex;flex-direction:column;gap:4px;align-items:center;justify-content:center;
  border-radius:6px;transition:background .15s;flex-shrink:0;
}
.hamburger-btn:hover{background:var(--green-light);}
.hamburger-btn span{display:block;width:20px;height:2px;background:var(--green-dark);border-radius:2px;transition:all .2s;}

.side-menu-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:500;display:none;
}
.side-menu-overlay.open{display:block;}
.side-menu{
  position:fixed;top:0;left:-260px;bottom:0;width:260px;
  background:#fff;z-index:501;box-shadow:4px 0 24px rgba(0,0,0,0.18);
  transition:left .28s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
}
.side-menu.open{left:0;}
.side-menu-header{
  background:var(--green);padding:20px 18px 16px;
  display:flex;align-items:center;gap:12px;
}
.side-menu-header img{width:38px;height:38px;border-radius:50%;object-fit:contain;}
.side-menu-header-text{color:#fff;}
.side-menu-header-text .sm-title{font-size:14px;font-weight:800;line-height:1.2;}
.side-menu-header-text .sm-sub{font-size:10px;opacity:.8;margin-top:2px;}
.side-menu-items{flex:1;overflow-y:auto;padding:8px 0;}
.side-menu-item{
  display:flex;align-items:center;gap:14px;padding:14px 20px;
  font-size:14px;font-weight:600;color:var(--text);cursor:pointer;
  border-bottom:1px solid var(--border);transition:background .12s;
}
.side-menu-item:hover{background:var(--green-light);color:var(--green-dark);}
.side-menu-item svg{flex-shrink:0;color:var(--green);}
.side-menu-item.danger{color:var(--danger);}
.side-menu-item.danger svg{color:var(--danger);}
.side-menu-divider{height:1px;background:var(--border);margin:6px 0;}

