*{box-sizing:border-box}
:root{
  --bg:#f3f7fc;
  --panel:#ffffff;
  --panel-soft:#f8fbff;
  --border:#d9e3ef;
  --text:#0f172a;
  --muted:#64748b;
  --primary:#2563eb;
  --primary-dark:#1d4ed8;
  --primary-soft:#eff6ff;
  --danger:#dc2626;
  --danger-soft:#fff1f2;
  --shadow:0 16px 34px rgba(15,23,42,.07);
}
html,body{margin:0;padding:0;max-width:100%;overflow-x:hidden}
body{
  font-family:Inter,"Segoe UI",Roboto,Arial,sans-serif;
  background:linear-gradient(180deg,#f8fbff 0%,var(--bg) 100%);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}

.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.box,.login-card{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--border);border-radius:22px;padding:28px;box-shadow:var(--shadow)}
.box h2{margin:0 0 16px}
.box input,.box select,.box textarea,.box button,.box .btn{width:100%;margin-top:12px}

.container{display:grid;grid-template-columns:272px minmax(0,1fr);min-height:100vh;align-items:start}
.goalync-sidebar{position:sticky;top:0;height:100vh;padding:18px 16px;background:linear-gradient(180deg,#09111f 0%,#10213f 52%,#15355f 100%);color:#fff;border-right:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:18px;overflow:hidden}
.goalync-sidebar-mobilebar{display:block}
.goalync-brand-block{display:flex;align-items:center;gap:14px;padding:14px;border-radius:20px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.10)}
.goalync-brand-logo-wrap{width:58px;height:58px;flex:0 0 58px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;padding:8px;box-shadow:0 10px 24px rgba(2,6,23,.18)}
.goalync-brand-logo{width:100%;height:100%;object-fit:contain}
.goalync-brand-text strong{display:block;font-size:18px;line-height:1.1;letter-spacing:-.01em}
.goalync-brand-text span{display:block;margin-top:4px;font-size:12px;color:rgba(255,255,255,.76);line-height:1.4}
.goalync-menu-toggle{display:none}
.goalync-sidebar-menu{display:grid;gap:8px;overflow:auto;padding-right:2px}
.goalync-sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;color:#dbe7f5;font-weight:700;border:1px solid transparent;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}
.goalync-sidebar-link:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(2px)}
.goalync-sidebar-link.active{background:#fff;color:#0f172a;border-color:#fff;box-shadow:0 10px 22px rgba(2,6,23,.16)}
.goalync-sidebar-icon{width:20px;min-width:20px;text-align:center;font-size:17px;line-height:1}
.goalync-sidebar-text{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.goalync-sidebar-footer{margin-top:auto;padding:14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09)}
.goalync-sidebar-footer span{display:block;font-weight:700}
.goalync-sidebar-footer small{display:block;margin-top:5px;color:rgba(255,255,255,.75);line-height:1.45}

.main{min-width:0;padding:18px}
.content,.main>.content{width:100%;min-width:0}
.content>*{max-width:100%}

.app-header{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border:1px solid var(--border);border-radius:22px;box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px;overflow:hidden}
.app-header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.app-header-title-group h1{margin:0;font-size:22px;line-height:1.15;letter-spacing:-.02em}
.app-header-subtitle{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.45}
.app-company-chip{display:flex;align-items:center;gap:10px;background:var(--panel-soft);border:1px solid var(--border);border-radius:16px;padding:10px 12px;min-width:0;max-width:100%}
.app-company-chip-logo,.app-company-chip-fallback{width:42px;height:42px;flex:0 0 42px;border-radius:12px;object-fit:contain;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:4px;color:var(--primary);font-weight:800}
.app-company-chip-text{min-width:0;flex:1 1 auto}
.app-company-chip-text strong{display:block;max-width:220px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}
.app-company-chip-text span{display:block;margin-top:3px;color:var(--muted);font-size:12px}
.app-logout-btn{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;background:var(--danger-soft);color:#b91c1c;border:1px solid #fecaca;border-radius:10px;font-size:13px;font-weight:700;white-space:nowrap}
.app-module-nav{display:none!important}

.page-box,.page-card,.settings-box,.section,.card,.panel,.payments-shell,.cp-shell,.pp-shell,.qp-shell,.ip-shell,.metric-card,.quick-card,.tip-card,.recent-box{background:linear-gradient(180deg,#ffffff 0%,#fbfdff 100%);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:18px}
.alert{margin:0 0 14px;padding:12px 14px;border-radius:12px;font-weight:700}.alert.success,.success{background:#dcfce7;color:#166534}.alert.error,.error{background:#fee2e2;color:#991b1b}

button,.btn,input[type="submit"],.content button,.content a.btn{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:8px 13px;border:none;border-radius:10px;background:linear-gradient(180deg,var(--primary) 0%,var(--primary-dark) 100%);color:#fff;font-size:13px;font-weight:700;cursor:pointer;box-shadow:0 8px 18px rgba(37,99,235,.18)}
button:hover,.btn:hover,input[type="submit"]:hover{filter:brightness(.98)}
.content input,.content textarea,.content select,input:not([type="checkbox"]):not([type="radio"]),textarea,select{width:100%;max-width:100%;padding:10px 12px;border:1px solid #d6dfeb;border-radius:10px;background:#fff;color:var(--text)}
.content input:focus,.content textarea:focus,.content select:focus,input:focus,textarea:focus,select:focus{outline:none;border-color:#93c5fd;box-shadow:0 0 0 4px rgba(37,99,235,.10)}

.table-wrap,.table-scroll,.table-responsive,.cp-table-wrap,.pp-table-wrap,.qp-table-wrap,.ip-table-wrap,.payments-table-wrap{width:100%;max-width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:separate;border-spacing:0;background:#fff}
th,td{padding:10px 12px;border-bottom:1px solid #edf2f7;border-left:none;border-right:none;vertical-align:middle;font-size:13px}
th{background:#f8fafc;color:#334155;text-align:left;font-size:12px;letter-spacing:.04em}
tr:last-child td{border-bottom:none}
.table a,.recent-table a,.qp-table a,.ip-table a,.pp-table a,.cp-table a{color:var(--primary-dark);font-weight:700}

.status-badge,.status-pill{display:inline-flex;align-items:center;justify-content:center;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700}
.form-error{margin:0 0 14px;padding:10px 12px;border-radius:12px;background:#fef2f2;color:#b91c1c;border:1px solid #fecaca;font-weight:700}
.panel-body,.cp-body,.pp-body,.qp-body,.ip-body{min-width:0;overflow:hidden}
.recent-table{table-layout:fixed}.main,.content{overflow-x:hidden}

@media (max-width: 980px){
  .container{display:block;min-height:auto}
  .goalync-sidebar{position:relative;height:auto;min-height:0;padding:12px 12px 0;overflow:visible;border-right:none;border-bottom:none;gap:12px}
  .goalync-sidebar-mobilebar{display:flex;align-items:center;justify-content:space-between;gap:12px}
  .goalync-brand-block{flex:1 1 auto;padding:12px;border-radius:16px}
  .goalync-brand-logo-wrap{width:46px;height:46px;flex-basis:46px;border-radius:12px}
  .goalync-brand-text strong{font-size:17px}
  .goalync-menu-toggle{display:inline-flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;width:46px;height:46px;border-radius:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.08);box-shadow:none;padding:0}
  .goalync-menu-toggle span{display:block;width:18px;height:2px;border-radius:999px;background:#fff}
  .goalync-sidebar-menu{display:none;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:none;overflow:visible;padding-right:0}
  .goalync-sidebar.is-open .goalync-sidebar-menu{display:grid}
  .goalync-sidebar-link{padding:12px;border-radius:12px;transform:none!important}
  .goalync-sidebar-link:hover{transform:none}
  .goalync-sidebar-text{white-space:normal;overflow:visible;text-overflow:clip;line-height:1.2;font-size:12px}
  .goalync-sidebar-footer{display:none}
  .main{padding:12px}
  .app-header{padding:14px 16px;border-radius:18px}
  .app-header-top{flex-direction:column;align-items:stretch;gap:12px}
  .app-company-chip{width:100%}
}

@media (max-width: 640px){
  .main{padding:10px}
  .goalync-sidebar{padding:10px 10px 0}
  .goalync-sidebar-menu{grid-template-columns:1fr}
  .goalync-sidebar-link{min-height:46px}
  .goalync-sidebar-icon{font-size:15px;width:16px;min-width:16px}
  .goalync-brand-text strong{font-size:16px}
  .goalync-brand-text span{font-size:11px}
  .app-header-title-group h1{font-size:20px}
  .app-header-subtitle{font-size:12px}
  .app-company-chip{padding:9px 10px;gap:8px;align-items:flex-start}
  .app-company-chip-logo,.app-company-chip-fallback{width:36px;height:36px;flex-basis:36px;border-radius:10px}
  .app-company-chip-text strong{max-width:none;font-size:13px;white-space:normal}
  .app-company-chip-text span{font-size:11px}
  .app-logout-btn{padding:7px 10px;font-size:11px}
  button,.btn,input[type="submit"],.content button,.content a.btn{min-height:34px;padding:7px 10px;font-size:12px;border-radius:9px}
  .hero-actions,.page-actions,.quotation-actions,.invoice-actions,.cp-right,.pp-right,.qp-right,.ip-right{display:flex!important;flex-wrap:wrap!important;gap:8px!important}
  .hero-actions>*,.page-actions>*,.quotation-actions>*,.invoice-actions>*,.cp-right>*,.pp-right>*,.qp-right>*,.ip-right>*{flex:1 1 calc(50% - 8px)!important;min-width:0!important}
  .dashboard-grid,.metric-grid,.quick-grid,.form-grid{grid-template-columns:1fr!important}
  .table-wrap,.table-scroll,.table-responsive,.cp-table-wrap,.pp-table-wrap,.qp-table-wrap,.ip-table-wrap,.payments-table-wrap{overflow-x:auto!important;overflow-y:hidden!important}
  .cp-table,.pp-table,.qp-table,.ip-table,.payments-table,table:not(.recent-table){min-width:720px}
  .recent-table{min-width:640px!important;table-layout:auto}
}

@media (max-width: 420px){
  .main{padding:8px}
  .app-header{padding:12px 13px}
  .hero-actions>*,.page-actions>*,.quotation-actions>*,.invoice-actions>*,.cp-right>*,.pp-right>*,.qp-right>*,.ip-right>*{flex:1 1 100%!important}
}

.btn-primary{background:linear-gradient(180deg,#2563eb 0%,#1d4ed8 100%)!important;color:#fff!important}
.btn-secondary{background:linear-gradient(180deg,#64748b 0%,#475569 100%)!important;color:#fff!important}
.btn-danger{background:linear-gradient(180deg,#ef4444 0%,#dc2626 100%)!important;color:#fff!important}
.btn-add,.save-btn,.primary-btn{background:linear-gradient(180deg,#2563eb 0%,#1d4ed8 100%)!important;color:#fff!important}
.a-view,.a-edit,.a-delete,.btn-row{display:inline-flex;align-items:center;justify-content:center}

.goalync-plan-badge{display:inline-flex;align-items:center;gap:6px;margin-bottom:4px;padding:4px 8px;border-radius:999px;font-size:11px;font-weight:800;letter-spacing:.02em}.goalync-plan-badge.is-active{background:#dcfce7;color:#166534}.goalync-plan-badge.is-readonly{background:#fef3c7;color:#92400e}
/* desktop zoomed-out feel */
@media (min-width: 1180px){html{font-size:14px}body{letter-spacing:-.01em}.main{padding:14px}.app-header{padding:14px 16px}th,td{padding:8px 10px;font-size:12px}button,.btn,input[type="submit"],.content button,.content a.btn{min-height:32px;padding:7px 11px;font-size:12px}.content input,.content textarea,.content select,input:not([type="checkbox"]):not([type="radio"]),textarea,select{padding:8px 10px;font-size:13px}}

/* Goalync current package mappings */
.topbar,.layout,.sidebar{display:none!important}
.flash{padding:12px 14px;border-radius:12px;margin:0 0 14px;font-weight:700}
.flash.success{background:#dcfce7;color:#166534}
.flash.error{background:#fee2e2;color:#991b1b}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-grid .full{grid-column:1/-1}
.roomy-grid{gap:16px 18px}
.small{font-size:13px;color:#64748b}
.workspace-subcard{background:#f8fafc;border:1px solid #e2e8f0;border-radius:16px;padding:16px;margin:16px 0}
.customer-editor-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.document-top-grid.wide-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.checkbox-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}
.checkbox-grid label{display:flex;gap:8px;align-items:center;border:1px solid #d6dfeb;border-radius:12px;padding:10px 12px;background:#fff}
.template-pair-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.template-choice{display:flex;gap:12px;align-items:center;justify-content:space-between;border:1px solid #d6dfeb;border-radius:16px;padding:14px;margin-bottom:12px;background:#fff}
.template-choice-body{display:flex;flex-direction:column;gap:5px;flex:1}
.doc-list{display:grid;gap:12px}
.doc-list-row{display:grid;grid-template-columns:1.2fr 1fr .7fr 1fr;gap:16px;align-items:center;padding:16px;border:1px solid #d6dfeb;border-radius:16px;background:#fff}
.doc-row-actions{display:flex;gap:10px;justify-content:flex-end;align-items:center}
.item-stack{display:grid;gap:12px}.item-card{background:#fff;border:1px solid #d6dfeb;border-radius:16px;padding:14px}.item-card-grid{display:grid;grid-template-columns:2fr 2fr repeat(4,1fr);gap:12px}
.compact-grid{grid-template-columns:repeat(2,minmax(0,280px))}
.company-logo-chip,.goalync-brand-logo,.app-company-chip-logo{object-fit:contain}
.goalync-brand-logo-fallback,.app-company-chip-fallback{display:flex;align-items:center;justify-content:center;font-weight:800;color:#1d4ed8;background:#fff;width:100%;height:100%;border-radius:inherit}
.template-choice a.btn, .doc-row-actions a.btn, .toolbar .btn{width:auto!important}
@media(max-width:1100px){.grid-2,.template-pair-grid,.customer-editor-grid,.document-top-grid.wide-4,.doc-list-row,.item-card-grid{grid-template-columns:1fr}}
@media(max-width:760px){.form-grid,.compact-grid,.checkbox-grid{grid-template-columns:1fr}}
