:root{--fyb-teal: #4085c6;--fyb-darkblue: #0f2840;--fyb-midblue: #083d6e;--fyb-cloud: #f8f9fa;--fyb-border: #dce4eb;--fyb-text: #0f2840}*{box-sizing:border-box}body{margin:0;font-family:Avenir Next,Segoe UI,sans-serif;color:var(--fyb-text);background:radial-gradient(circle at top right,#e6f1fb,#f8fbff 45%,#f2f6fa)}.app-root{min-height:100vh;display:grid;grid-template-columns:260px 1fr}.sidebar{background:linear-gradient(170deg,var(--fyb-darkblue),var(--fyb-midblue));color:#fff;padding:2rem 1rem;display:flex;flex-direction:column}.sidebar-logo{width:180px;max-width:100%;margin-bottom:.5rem}.sidebar-subtitle{font-size:.85rem;opacity:.85;margin-bottom:1.6rem}.nav-item{display:block;color:#ffffffd9;text-decoration:none;padding:.7rem .8rem;border-radius:.6rem;margin-bottom:.35rem}.nav-item-active{background:#4085c659;color:#fff}.sidebar-nav{flex:1}.sidebar-footer{border-top:1px solid rgba(255,255,255,.2);padding-top:.8rem;margin-top:.8rem}.sidebar-user-name{font-size:.9rem;font-weight:600}.sidebar-user-email{font-size:.76rem;opacity:.9;margin-bottom:.6rem;word-break:break-word}.sidebar-logout-btn{width:100%;border-color:#ffffff73;color:#fff;background:transparent}.content{padding:2rem}.header-row{display:flex;justify-content:space-between;gap:1rem;align-items:flex-start}.lead-search-row{margin-top:.7rem;display:flex;gap:.5rem}.city-autocomplete{position:relative;width:100%}.city-autocomplete-list{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:40;border:1px solid #c8d8e5;border-radius:8px;background:#fff;box-shadow:0 8px 18px #0f28401f;max-height:220px;overflow-y:auto}.city-autocomplete-item{padding:.5rem .65rem;font-size:.88rem;color:var(--fyb-text)}.city-autocomplete-btn{width:100%;text-align:left;border:0;background:#fff;cursor:pointer}.city-autocomplete-btn:hover{background:#f3f7fb}.legacy-add-btn{border:0;background:#4085c6;color:#fff;border-radius:8px;padding:.62rem .95rem;font-weight:600;cursor:pointer;box-shadow:0 6px 14px #4085c659}h1{margin:0;font-size:1.8rem}h2{margin-top:2rem;font-size:1.2rem}.subtitle{color:#294961}.card-grid{display:grid;gap:1rem;margin-top:1.3rem;grid-template-columns:repeat(4,minmax(140px,1fr))}.card{background:#fff;border:1px solid var(--fyb-border);border-radius:12px;padding:1rem;box-shadow:0 8px 24px #0f28400f}.form-card{margin-top:1rem}.split-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.metric-label{font-size:.8rem;color:#456}.metric-value{font-size:1.6rem;font-weight:700;margin-top:.2rem}.table-wrap{overflow-x:auto;border:1px solid var(--fyb-border);border-radius:12px;background:#fff;margin-top:1rem}.pagination-row{display:flex;justify-content:flex-end;gap:.5rem;padding:.65rem}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.85rem;border-bottom:1px solid #edf1f5}th{background:#f3f7fb;color:#274860}input,select{width:100%;border:1px solid #c8d8e5;border-radius:8px;padding:.55rem .65rem;font-size:.9rem;background:#fff}textarea{width:100%;border:1px solid #c8d8e5;border-radius:8px;padding:.55rem .65rem;font-size:.9rem;background:#fff;resize:vertical;font-family:inherit}.form-grid{display:grid;gap:.65rem;grid-template-columns:repeat(2,minmax(140px,1fr))}.form-grid button{grid-column:1 / -1}.primary-btn{border:0;background:linear-gradient(145deg,var(--fyb-teal),#2f6ea8);color:#fff;padding:.55rem .85rem;border-radius:9px;cursor:pointer}.primary-btn:disabled{opacity:.55;cursor:not-allowed}.danger-btn{border:0;background:#c73434;color:#fff;padding:.55rem .85rem;border-radius:9px;cursor:pointer}.danger-btn:disabled{opacity:.55;cursor:not-allowed}.ghost-btn{border:1px solid #9ab5cc;color:var(--fyb-darkblue);background:#fff;padding:.5rem .75rem;border-radius:9px;cursor:pointer;text-decoration:none}.inline-form{margin-top:.5rem;display:flex;gap:.5rem}.small-text{font-size:.78rem;color:#4f6779}.pill{display:inline-flex;align-items:center;border-radius:999px;font-size:.72rem;background:#e9f2fb;color:#21507b;padding:.12rem .45rem}.list{margin:0;padding-left:1rem;display:grid;gap:.5rem}.profit-box{margin-top:.7rem;border-radius:10px;background:#eef5fc;border:1px solid #cfe0f0;padding:.7rem;display:grid;gap:.3rem}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1a297a;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto;z-index:30}.modal-card{width:min(920px,100%);background:#fff;border-radius:12px;border:1px solid #cde0f1;padding:1rem}.modal-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.modal-header h2{margin-top:0}.contact-builder{grid-column:1 / -1;border:1px dashed #b4cadf;border-radius:10px;padding:.8rem}.contact-builder h3{margin:0 0 .6rem;font-size:1rem}.contact-grid{margin-bottom:.7rem}.contact-chip-list{margin-top:.7rem;display:grid;gap:.5rem}.contact-chip{display:flex;justify-content:space-between;align-items:center;gap:.5rem;border:1px solid #d9e7f4;background:#f8fbff;border-radius:8px;padding:.55rem}.lead-link{color:#1f5a8b;font-weight:600;text-decoration:none}.inline-link-btn{display:inline-flex;align-items:center;justify-content:center}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(120px,1fr));gap:.75rem}.lead-top-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:1rem;margin-top:1rem}.lead-main-card{min-height:100%;display:flex;flex-direction:column}.lead-comments-card{margin-top:1rem}.lead-card-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.lead-card-header h2{margin-top:0}.lead-tags-footer{margin-top:auto;padding-top:.9rem;border-top:1px solid #e2edf6}.detail-edit-form{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(140px,1fr));gap:.6rem}.detail-edit-form button{grid-column:1 / -1}.contact-edit-form{margin-top:1rem;border-top:1px solid #e2edf6;padding-top:.75rem}.contact-edit-form h3{margin:0 0 .55rem;font-size:.95rem}.comment-form{display:grid;gap:.6rem;margin-top:.5rem}.comment-list{margin-top:1rem;display:grid;gap:.7rem}.comment-item{border:1px solid #d9e6f2;border-radius:8px;padding:.65rem;background:#fbfdff}.comment-item p{margin:.5rem 0 0;white-space:pre-wrap}.comment-link{color:#1f5a8b;text-decoration:underline}.comment-edit-box{margin-top:.5rem;display:grid;gap:.6rem}.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top right,#e6f1fb,#f8fbff 45%,#f2f6fa);padding:1rem}.login-card{width:min(460px,100%);background:#fff;border:1px solid #d7e5f2;border-radius:14px;padding:1.3rem;box-shadow:0 18px 45px #0d233714}.google-button-slot{margin-top:.9rem;min-height:46px}.auth-error{border:1px solid #f2c8c8;background:#fff3f3;color:#8f2323;border-radius:8px;padding:.55rem .65rem;margin-top:.7rem}.global-error-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;border:1px solid #f2c8c8;background:#fff3f3;color:#8f2323;border-radius:10px;padding:.6rem .75rem;margin-bottom:1rem}.input-error{border-color:#d83f3f!important;background:#fff8f8!important}.field-error{color:#b42318;font-size:.78rem;margin-top:-.25rem}.comment-head{display:flex;align-items:center;justify-content:space-between;gap:.8rem}.tags-wrap{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}.tag-chip{border:1px solid #a9c5dd;background:#eaf4ff;color:#19486f;border-radius:999px;padding:.2rem .6rem;font-size:.76rem;cursor:pointer}.tag-chip-static{cursor:default}.field-wrap{display:flex;flex-direction:column;gap:.3rem}.field-label{font-size:.82rem;font-weight:600;color:#274860}.quote-doc{background:#fff;max-width:760px;margin:2rem auto 0;padding:2rem 2.5rem 2.5rem;border:1px solid var(--fyb-border);border-radius:12px;box-shadow:0 8px 28px #0f284012;font-size:.93rem;line-height:1.7;color:#1a2e3f}.quote-page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;position:relative;overflow:hidden}.quote-logo{width:180px;height:auto;display:block}.quote-deco-circles{position:relative;width:110px;height:80px;flex-shrink:0}.quote-deco-circle{position:absolute;border-radius:50%}.quote-deco-circle--blue{width:80px;height:80px;background:var(--fyb-teal);top:0;right:20px}.quote-deco-circle--dark{width:60px;height:60px;background:var(--fyb-darkblue);top:10px;right:0}.quote-meta-strip{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.82rem;color:#4a6a84;margin-bottom:.75rem}.quote-meta-key{color:#8aaabb}.quote-divider{border:none;border-top:1.5px solid var(--fyb-teal);margin:.75rem 0 1.25rem}.quote-addressee{margin-bottom:1.25rem}.quote-addressee-contact{font-size:.85rem;color:#5a7a95}.quote-addressee-company{font-size:1.05rem;font-weight:700;color:var(--fyb-darkblue)}.quote-body-text{margin:0 0 .85rem;text-align:justify;color:#1a2e3f}.quote-route-block{margin:.5rem 0 1rem}.quote-route-line{margin:0 0 .5rem;color:#1a2e3f}.quote-price-highlight{color:var(--fyb-darkblue);font-size:1rem}.quote-ul{margin:.25rem 0 .75rem;padding-left:1.3rem;color:#2c4a62}.quote-ul li{margin-bottom:.25rem;font-size:.9rem}.quote-notes-inline{background:#f8fbff;border-left:3px solid var(--fyb-teal);padding:.5rem .8rem;border-radius:0 6px 6px 0}.quote-sig-block-right{margin-top:2.5rem;text-align:right}.quote-sig-name-blue{font-weight:600;font-size:.9rem;color:var(--fyb-teal)}.quote-sig-title-blue{font-size:.82rem;color:var(--fyb-teal)}.quote-footer{margin-top:2rem;padding-top:.6rem;border-top:1px solid #dde8f2;font-size:.72rem;color:#8aabb8;text-align:center}@media print{.no-print,.mobile-header,.sidebar,.sidebar-overlay,.global-error-banner{display:none!important}.app-root{display:block}.content{padding:0;margin:0}.quote-page-wrap{padding:0}.quote-doc{margin:0;padding:.8cm 1.4cm 1cm;border:none;border-radius:0;box-shadow:none;max-width:100%;font-size:10pt;line-height:1.55;color:#000;overflow:hidden}.quote-deco-circle--blue{background:#4085c6!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.quote-deco-circle--dark{background:#0f2840!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.quote-divider{border-top-color:#4085c6!important;margin:.3rem 0 .6rem!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.quote-logo{width:150px!important}.quote-deco-circles{width:90px!important;height:70px!important}.quote-deco-circle--blue{width:70px!important;height:70px!important}.quote-deco-circle--dark{width:52px!important;height:52px!important;top:10px!important}.quote-page-header{margin-bottom:.8rem!important}.quote-meta-strip{font-size:8.5pt!important;margin-bottom:.5rem!important}.quote-addressee{margin-bottom:.8rem!important}.quote-body-text{margin-bottom:.6rem!important}.quote-route-block{margin:.3rem 0 .7rem!important}.quote-ul{margin:.2rem 0 .6rem!important;padding-left:1.1rem!important}.quote-ul li{font-size:9.5pt!important;margin-bottom:.2rem!important}.quote-sig-block-right{margin-top:1.5rem!important}.quote-sig-name-blue,.quote-sig-title-blue{color:#4085c6!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.quote-footer{margin-top:1rem!important;padding-top:.4rem!important;font-size:7.5pt!important}.quote-price-highlight{font-size:10pt}@page{margin:.8cm 1.2cm;size:A4 portrait}}.mobile-header{display:none}.hamburger-btn{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}.hamburger-icon,.hamburger-icon:before,.hamburger-icon:after{display:block;width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .2s,opacity .2s}.hamburger-icon{position:relative}.hamburger-icon:before,.hamburger-icon:after{content:"";position:absolute;left:0}.hamburger-icon:before{top:-7px}.hamburger-icon:after{top:7px}.hamburger-icon--open{background:transparent}.hamburger-icon--open:before{transform:translateY(7px) rotate(45deg)}.hamburger-icon--open:after{transform:translateY(-7px) rotate(-45deg)}.sidebar-overlay{display:none}@media (max-width: 900px){.app-root{grid-template-columns:1fr}.mobile-header{display:flex;align-items:center;gap:.75rem;background:linear-gradient(170deg,var(--fyb-darkblue),var(--fyb-midblue));padding:.6rem 1rem;position:sticky;top:0;z-index:20}.mobile-logo{height:28px;width:auto}.sidebar{position:fixed;top:0;left:0;bottom:0;width:280px;max-width:85vw;z-index:30;transform:translate(-100%);transition:transform .25s ease;overflow-y:auto;padding:1.5rem 1rem}.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0a1a2980;z-index:25}.sidebar .sidebar-logo{display:none}.nav-item{padding:.85rem .8rem;font-size:1rem}.content{padding:1rem}.card-grid{grid-template-columns:repeat(2,minmax(120px,1fr))}.split-grid,.form-grid,.detail-grid,.lead-top-grid,.detail-edit-form{grid-template-columns:1fr}.header-row{flex-direction:column;align-items:stretch}.header-row .legacy-add-btn,.header-row .primary-btn,.header-row .ghost-btn{width:100%;text-align:center}}@media (max-width: 600px){h1{font-size:1.4rem}.card-grid{grid-template-columns:1fr}button,.primary-btn,.danger-btn,.ghost-btn,.legacy-add-btn,.nav-item{min-height:44px}input,select,textarea{font-size:1rem;min-height:44px;padding:.7rem .75rem}.pagination-row{justify-content:space-between;padding:.75rem}.pagination-row button{flex:1}.lead-search-row{flex-direction:column}.modal-overlay{padding:0;align-items:flex-end}.modal-card{width:100%;border-radius:16px 16px 0 0;max-height:92dvh;overflow-y:auto;padding:1.25rem 1rem}th,td{padding:.65rem .6rem;font-size:.85rem}.metric-value{font-size:1.35rem}.content{padding:.75rem}}
