*{box-sizing:border-box;margin:0;padding:0}:root,[data-theme=dark]{color-scheme:dark;--bg: #000000;--bg-elevated: #16181c;--bg-soft: #0a0a0b;--surface: #202327;--surface-strong: #2d3033;--text: #e7e9ea;--text-muted: #71767b;--border: #2f3336;--accent: #1d9bf0;--accent-strong: #1a8cd8;--shadow: rgba(0, 0, 0, .6);--error: #f4212e;--success: #00ba7c;--body-gradient: linear-gradient(180deg, #000000 0%, #000000 50%, #050505 100%)}[data-theme=light]{color-scheme:light;--bg: #ffffff;--bg-elevated: #ffffff;--bg-soft: #f7f9fa;--surface: #f2f4f6;--surface-strong: #e6ecf0;--text: #0f1419;--text-muted: #536471;--border: #cfd9de;--accent: #1d9bf0;--accent-strong: #1a8cd8;--shadow: rgba(15, 20, 25, .08);--error: #d22d2d;--success: #00734a;--body-gradient: linear-gradient(180deg, #ffffff 0%, #f7f9fa 100%)}html,body,#root{min-height:100%}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--body-gradient);color:var(--text);scroll-behavior:smooth}a{color:inherit}.muted{color:var(--text-muted)}.centered{display:flex;align-items:center;justify-content:center;min-height:60vh}.button{display:inline-block;background-color:var(--accent);color:#202124;font-size:1rem;font-weight:600;padding:10px 20px;border-radius:8px;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:background-color .2s ease,color .2s ease,transform .2s ease,box-shadow .2s ease}.button:hover{background-color:var(--accent-strong);transform:translateY(-1px);box-shadow:0 8px 18px #8ab4f838}.button-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}.button-ghost:hover{background:var(--surface);color:var(--text)}button{font:inherit;background-color:var(--accent);color:#202124;padding:10px 20px;border:1px solid transparent;border-radius:8px;cursor:pointer;font-weight:600}button:hover{background-color:var(--accent-strong)}button:disabled{opacity:.6;cursor:not-allowed}.public-shell{display:flex;flex-direction:column;min-height:100vh}.navbar{position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;background:#202124;border-bottom:1px solid rgba(95,99,104,.5);box-shadow:0 10px 30px var(--shadow);padding:0 2rem;height:5rem}.nav-logo{height:4rem}.nav-menu{display:flex;align-items:center;gap:1.5rem;list-style:none}.nav-menu a{text-decoration:none;color:var(--text)}.nav-menu a:hover{color:var(--accent)}main{flex:1}.band{padding:5rem 2rem;text-align:center}.band h2{font-size:2rem;margin:1rem 0}.band-dark{background:var(--bg)}.band-accent{background:linear-gradient(180deg,#3e5875,#31465e)}.band-light{background:var(--surface);padding:2.5rem 2rem}.trust-band{text-align:center}.trust-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem;max-width:1100px;margin:0 auto}.trust-value{font-size:2.25rem;font-weight:700;color:var(--accent);line-height:1}.trust-label{font-size:.9rem;color:var(--text-muted);margin-top:.4rem;text-transform:uppercase;letter-spacing:.04em}.hero{min-height:70vh;background-image:linear-gradient(#1212128c,#1212128c),url(/media/windows1.png);background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem}.hero h1{color:#fff;font-size:clamp(2rem,5vw,3.5rem);font-weight:800;text-shadow:0 8px 28px rgba(0,0,0,.45);max-width:900px;margin:0 auto}.hero-inner{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:900px}.hero-area{display:inline-flex;align-items:center;background:#ffffff2e;color:#fff;padding:.4rem 1rem;border-radius:999px;font-size:.9rem;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.hero-sub{color:#f4f4f4;font-size:clamp(1rem,1.6vw,1.25rem);text-shadow:0 2px 12px rgba(0,0,0,.5);max-width:700px;margin:0;line-height:1.5}.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:.5rem}.hero-trust{color:#e0e0e0;font-size:.9rem;margin:.5rem 0 0;text-shadow:0 2px 12px rgba(0,0,0,.5)}.button-ghost-light{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.6)}.button-ghost-light:hover{background:#ffffff1f;border-color:#fff}.tag{display:inline-block;background-color:var(--surface-strong);padding:8px 18px;border-radius:999px;border:1px solid rgba(174,203,250,.18);font-size:.9rem}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:3rem;max-width:1200px;margin:0 auto;align-items:center;text-align:left}.two-col .copy{display:flex;flex-direction:column;gap:1rem;align-items:flex-start}.band-image{width:100%;max-height:480px;object-fit:cover;border-radius:12px;box-shadow:0 14px 28px #0000004d}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;max-width:1200px;margin:0 auto}.feature{display:flex;flex-direction:column;align-items:center;gap:.75rem}.feature img{width:60px;height:60px}.service-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:1200px;margin:2rem auto 0;text-align:left}.service-card{background:var(--bg-elevated);border:1px solid rgba(95,99,104,.32);border-radius:12px;box-shadow:0 16px 40px var(--shadow);padding:1.5rem;display:flex;flex-direction:column;gap:.75rem}.service-card img{width:100%;height:200px;object-fit:cover;border-radius:8px}.review-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem;max-width:1100px;margin:2rem auto 0;text-align:left}.review{background:#0000002e;padding:1.5rem;border-radius:12px}.review cite{display:block;margin-top:1rem;font-style:normal;color:var(--text-muted)}.site-footer{background:#17181b;padding:3rem 2rem 2rem;text-align:center}.footer-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem;max-width:1200px;margin:0 auto;text-align:left}.footer-cols ul{list-style:none}.footer-cols a{text-decoration:none}.footer-cols a:hover{color:var(--accent)}.footer-logo{width:80px;height:80px;margin-bottom:1rem}.footer-copy{margin-top:2rem;color:var(--text-muted);font-size:.875rem}.auth-page{display:flex;justify-content:center;padding:4rem 1.5rem}.form-container{width:100%;max-width:480px;background:var(--bg-elevated);border:1px solid rgba(95,99,104,.35);border-radius:16px;box-shadow:0 18px 40px var(--shadow);padding:2rem}.form-container h2{margin-bottom:.5rem}.form-container p{margin-bottom:1rem}label{display:block;margin-bottom:6px;font-size:.9rem;color:var(--text)}input,textarea,select{width:100%;padding:10px 12px;margin-bottom:1rem;background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:8px;font:inherit}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #8ab4f82e}.form-error{color:var(--error);background:#f28b8214;border:1px solid rgba(242,139,130,.3);border-radius:8px;padding:10px 12px;margin-bottom:1rem}.form-success{color:var(--success);background:#81c99514;border:1px solid rgba(129,201,149,.3);border-radius:8px;padding:10px 12px;margin-bottom:1rem;word-break:break-all}.cta-row{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1rem}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;overflow:hidden;flex-shrink:0;font-weight:600;-webkit-user-select:none;user-select:none;border:1px solid rgba(95,99,104,.32)}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.user-chip{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text)}.user-chip:hover{color:var(--accent)}.user-chip-meta{display:flex;flex-direction:column;line-height:1.15}.user-chip-name{font-size:.9rem;font-weight:600}.user-chip-role{font-size:.75rem;color:var(--text-muted);text-transform:capitalize}.user-chip-row{display:flex;align-items:center;gap:.4rem}.user-chip-row>.user-chip{flex:1;min-width:0}.user-chip-settings{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;color:var(--text-muted);text-decoration:none}.user-chip-settings:hover{background:var(--surface);color:var(--text)}.kv{display:grid;grid-template-columns:max-content 1fr;gap:.4rem 1.25rem;margin:0}.kv dt{color:var(--text-muted)}.kv dd{margin:0}.job-cost-bar{display:flex;height:8px;background:var(--surface);border-radius:999px;overflow:hidden;border:1px solid rgba(95,99,104,.32)}.job-cost-bar-fill{background:var(--accent);height:100%}.job-cost-bar-fill.over{background:var(--error)}.job-cost-bar-overflow{background:#f28b8299;height:100%;border-left:1px dashed rgba(255,255,255,.4)}.hp-field{position:absolute;left:-10000px;top:auto;width:1px;height:1px;overflow:hidden}.inline-form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:flex-end}.inline-form input,.inline-form select{margin-bottom:0;flex:1;min-width:180px}.row-between{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;flex-wrap:wrap}.header-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.toolbar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;padding:.5rem 0;background:transparent;border:0}.toolbar>input,.toolbar>select,.toolbar>label{margin-bottom:0;width:auto}.toolbar input[type=search]{min-width:200px;flex:1 1 200px;max-width:320px}.toolbar select{min-width:140px;flex:0 0 auto}.toolbar-spacer{flex:1}.emoji-picker{position:relative;display:inline-block}.emoji-trigger{padding:.4rem .5rem}.emoji-popover{position:absolute;bottom:calc(100% + 6px);left:0;z-index:30;display:grid;grid-template-columns:repeat(5,32px);gap:4px;padding:8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 24px var(--shadow)}.emoji-option{width:32px;height:32px;padding:0;background:transparent;border:0;border-radius:6px;font-size:1.15rem;line-height:1;cursor:pointer;color:var(--text)}.emoji-option:hover{background:var(--surface)}.attachment-input{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.attachment-pending{display:flex;flex-wrap:wrap;gap:4px}.attachment-pending-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 6px 2px 8px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:.8rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-pending-pill button{display:inline-flex;align-items:center;justify-content:center;background:transparent;border:0;color:var(--text-muted);cursor:pointer;padding:0}.attachment-pending-pill button:hover{color:var(--text)}.attachment-gallery{display:flex;gap:6px;flex-wrap:wrap;margin-top:.5rem}.attachment-thumb{display:inline-block;border-radius:8px;overflow:hidden;border:1px solid var(--border)}.attachment-thumb img{display:block;width:120px;height:120px;object-fit:cover}.attachment-thumb:hover{border-color:var(--accent)}.composer-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.channels-shell{display:grid!important;grid-template-columns:220px minmax(0,1fr);gap:1rem;align-items:start}.channels-sidebar{position:sticky;top:1rem}.channel-list{list-style:none;display:flex;flex-direction:column;gap:2px;padding:0;margin:0}.channel-link{display:flex;align-items:center;gap:.4rem;width:100%;padding:.4rem .6rem;background:transparent;border:0;border-radius:6px;color:var(--text-muted);font:inherit;text-align:left;cursor:pointer}.channel-link:hover{background:var(--surface);color:var(--text)}.channel-link.active{background:var(--surface-strong);color:var(--text);font-weight:600}.channel-link>svg{flex-shrink:0;opacity:.7}.channel-link.active>svg{opacity:1}.channel-admin-row{display:flex;gap:.25rem;padding:.25rem .6rem .25rem 1.6rem}.channels-main{display:flex;flex-direction:column;gap:1rem;min-width:0}@media (max-width: 800px){.channels-shell{grid-template-columns:1fr}.channels-sidebar{position:static}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:100}.modal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:1.25rem 1.5rem;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 50px var(--shadow)}.calendar-cell.clickable{cursor:pointer}.calendar-cell.clickable:hover{background:var(--surface)}.calendar-cell.clickable.today:hover{background:#8ab4f82e}.photo-strip{display:flex;gap:.5rem;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:.5rem}.photo-strip-item{flex:0 0 auto;width:200px;text-decoration:none;color:inherit;scroll-snap-align:start;border-radius:8px;overflow:hidden;border:1px solid var(--border);background:var(--bg-elevated);display:flex;flex-direction:column}.photo-strip-item:hover{border-color:var(--accent)}.photo-strip-item img{width:100%;height:140px;object-fit:cover;display:block}.photo-strip-caption{padding:.4rem .6rem;display:flex;flex-direction:column;gap:2px;font-size:.85rem}.chat-stream{display:flex;flex-direction:column;gap:.25rem}.chat-msg{padding:.5rem .75rem;border-radius:6px;position:relative}.chat-msg:hover{background:var(--surface)}.chat-msg-meta{display:flex;align-items:baseline;gap:.5rem;font-size:.85rem;margin-bottom:.15rem}.chat-msg-author{font-weight:600;color:var(--text)}.chat-msg-role{font-size:.75rem;text-transform:capitalize}.chat-msg-time{font-size:.75rem}.chat-msg-actions{margin-left:auto;display:flex;gap:.25rem;opacity:0;transition:opacity .1s}.chat-msg:hover .chat-msg-actions{opacity:1}.chat-msg-body{white-space:pre-wrap;word-break:break-word;color:var(--text)}@media (max-width: 700px){.chat-msg-actions{opacity:1}}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.button-small{padding:4px 10px;font-size:.85rem;margin-top:.5rem}.upload-form{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center;margin-bottom:1rem}.upload-form input[type=file]{flex:1;min-width:200px;padding:6px}.upload-form input[type=text]{flex:2;min-width:200px;margin-bottom:0}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.gallery-item{background:var(--surface);border-radius:10px;overflow:hidden;border:1px solid rgba(95,99,104,.32)}.gallery-item img{width:100%;height:180px;object-fit:cover;display:block}.gallery-item figcaption{padding:.6rem .75rem;font-size:.875rem}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.8rem;text-transform:capitalize;background:var(--surface-strong);color:var(--text);border:1px solid rgba(95,99,104,.4)}.badge-paid{background:#81c9952e;border-color:#81c99566;color:var(--success)}.badge-overdue{background:#f28b822e;border-color:#f28b8266;color:var(--error)}.badge-sent{background:#8ab4f82e;border-color:#8ab4f866;color:var(--accent)}.badge-void{background:#5f636840;color:var(--text-muted)}.badge-draft,.badge-pending{background:var(--surface-strong);color:var(--text-muted)}.badge-approved{background:#81c9952e;border-color:#81c99566;color:var(--success)}.badge-change-requested{background:#f28b822e;border-color:#f28b8266;color:var(--error)}.invoice-form{display:flex;flex-direction:column;gap:0;margin-bottom:1rem}.invoice-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1.5rem}.stat-label{color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.75rem;font-weight:700;margin-top:.25rem}.messages-page{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;height:calc(100vh - 4rem);max-height:800px}.messages-sidebar{display:flex;flex-direction:column;min-width:0;overflow-y:auto}.messages-main{background:var(--bg-elevated);border:1px solid rgba(95,99,104,.32);border-radius:12px;display:flex;flex-direction:column;min-height:0}.messages-header{padding:1rem 1.25rem;border-bottom:1px solid rgba(95,99,104,.32)}.messages-header h2{margin:0 0 .25rem}.messages-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;text-align:center}.message-stream{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:.75rem}.bubble{max-width:70%;padding:.6rem .9rem;border-radius:12px;white-space:pre-wrap}.bubble.mine{align-self:flex-end;background:var(--accent);color:#202124}.bubble.theirs{align-self:flex-start;background:var(--surface);color:var(--text)}.bubble-time{font-size:.75rem;opacity:.7;margin-top:.25rem}.message-composer{display:flex;gap:.75rem;padding:.75rem;border-top:1px solid rgba(95,99,104,.32);align-items:flex-end}.message-composer textarea{flex:1;margin-bottom:0;resize:vertical;min-height:60px}.thread-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.thread-item{width:100%;text-align:left;background:var(--bg-elevated);color:var(--text);border:1px solid rgba(95,99,104,.32);border-radius:10px;padding:.75rem;cursor:pointer;transition:background .15s}.thread-item:hover{background:var(--surface)}.thread-item.active{background:var(--surface-strong);border-color:var(--accent)}.thread-preview{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.875rem;margin-top:.25rem}.thread-time{font-size:.75rem;margin-top:.25rem}.unread-dot{background:var(--accent);color:#202124;border-radius:999px;padding:1px 8px;font-size:.75rem;font-weight:700;min-width:22px;display:inline-block;text-align:center}.link-button{background:none;border:none;padding:0;color:var(--accent);cursor:pointer;font:inherit;text-align:left}.link-button:hover{text-decoration:underline}.calendar-card{padding:0;overflow:hidden;min-width:0}.calendar-with-aside{display:grid;grid-template-columns:minmax(0,1450px) minmax(0,1fr);gap:1.25rem;align-items:start}.calendar-with-aside>.calendar-card{max-width:none}.calendar-aside{padding:1rem 1.25rem}.calendar-aside h2{font-size:1.05rem;margin-bottom:.5rem}@media (max-width: 1100px){.calendar-with-aside{grid-template-columns:1fr}}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));background:#5f636852;gap:1px;min-width:0}.calendar-dow{background:var(--bg-elevated);padding:.5rem;font-size:.8rem;color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em}.calendar-cell{background:var(--bg-elevated);min-height:110px;padding:.4rem;display:flex;flex-direction:column;gap:.2rem;font-size:.8rem}.calendar-cell.muted-cell{background:var(--bg);opacity:.5}.calendar-cell.today{background:#8ab4f81f}.calendar-card-full{display:flex;flex-direction:column;height:calc(100vh - 180px)}.calendar-card-full .calendar-grid{flex:1;grid-template-rows:auto repeat(6,1fr)}.calendar-card-full .calendar-cell{min-height:0;overflow:hidden}.calendar-day-num{font-weight:600;font-size:1rem;margin-bottom:.25rem}.calendar-event{display:block;max-width:100%;background:var(--accent);color:#202124;border-radius:4px;padding:1px 6px;text-decoration:none;font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event:hover{background:var(--accent-strong)}.calendar-event-time{font-weight:700;margin-right:4px}.calendar-more{font-size:.7rem}@media (max-width: 700px){.calendar-cell{min-height:60px;padding:.25rem;font-size:.7rem}.calendar-day-num{font-size:.8rem}}.saved-views{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:.5rem}.saved-view-chip{display:inline-flex;align-items:center;background:var(--surface-strong);border:1px solid rgba(95,99,104,.4);border-radius:999px;overflow:hidden;font-size:.85rem}.saved-view-chip button{background:transparent;color:var(--text);border:none;padding:4px 12px;cursor:pointer;font:inherit}.saved-view-chip button:hover{background:var(--surface)}.saved-view-remove{padding:4px 10px!important;border-left:1px solid rgba(95,99,104,.4)!important;color:var(--text-muted)!important}.saved-view-remove:hover{color:var(--error)!important}.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable:hover{color:var(--accent)}.pagination{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:.75rem;border-top:1px solid rgba(95,99,104,.25)}.pagination button:disabled{opacity:.4}.contract-body{background:var(--surface);border:1px solid rgba(95,99,104,.32);border-radius:8px;padding:1.25rem;white-space:pre-wrap;font-family:ui-serif,Georgia,Times New Roman,serif;font-size:.95rem;line-height:1.55;max-height:600px;overflow-y:auto}@media (max-width: 800px){.messages-page{grid-template-columns:1fr;height:auto;max-height:none}.messages-main{min-height:60vh}}.portal-shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh;zoom:.8}.portal-sidebar{background:var(--bg-elevated);border-right:1px solid rgba(95,99,104,.35);padding:1rem 1rem .75rem;display:flex;flex-direction:column;gap:1rem;position:sticky;top:0;align-self:start;height:100vh}.portal-sidebar nav{flex:1;overflow-y:auto;min-height:0}.portal-brand{display:flex;align-items:center;gap:.75rem;text-decoration:none;color:var(--text);font-weight:600}.portal-brand img{width:56px;height:56px}.portal-brand span{font-size:1.15rem}.portal-sidebar nav{display:flex;flex-direction:column;gap:.25rem}.portal-sidebar nav a{display:flex;align-items:center;gap:.7rem;padding:.6rem .75rem;border-radius:8px;text-decoration:none;color:var(--text)}.portal-sidebar nav a>svg{flex-shrink:0;color:var(--text-muted)}.portal-sidebar nav a:hover{background:var(--surface)}.portal-sidebar nav a:hover>svg{color:var(--text)}.portal-sidebar nav a.active{background:var(--surface-strong);color:var(--accent)}.portal-sidebar nav a.active>svg{color:var(--accent)}.portal-user{margin-top:auto;display:flex;flex-direction:column;gap:.5rem}.portal-user-name{font-weight:600}.portal-user-role{font-size:.85rem;color:var(--text-muted);text-transform:capitalize}.portal-main{padding:2rem;overflow-x:auto}.phase-chips{display:flex;flex-wrap:wrap;gap:.5rem}.phase-chips .is-active{background:var(--surface-strong);color:var(--accent)}@media print{.portal-sidebar,.nav-menu,.navbar,.global-search-backdrop,button,.button,.button-ghost,input[type=checkbox],select,.form-row,.form-actions{display:none!important}body,.portal-shell{background:#fff!important;color:#000!important}.portal-main{padding:0!important}.card{background:#fff!important;border:none!important;box-shadow:none!important;page-break-inside:avoid}.table th,.table td{color:#000!important;border-color:#999!important}.badge{border:1px solid #666!important;background:transparent!important;color:#000!important}.muted{color:#444!important}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}a[href^="/"]:after,a[href^="#"]:after{content:""}}.global-search-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:flex;align-items:flex-start;justify-content:center;padding-top:12vh}.global-search-panel{width:min(680px,92vw);background:var(--bg-elevated);border:1px solid rgba(95,99,104,.4);border-radius:12px;box-shadow:0 20px 50px #0009;overflow:hidden}.global-search-panel input[type=search]{width:100%;padding:1rem 1.25rem;border:none;background:transparent;color:var(--text);font-size:1.05rem;outline:none}.global-search-results{max-height:60vh;overflow-y:auto;border-top:1px solid rgba(95,99,104,.32)}.global-search-hit{display:grid;grid-template-columns:80px 1fr;align-items:center;gap:.75rem;width:100%;padding:.6rem 1rem;background:transparent;border:none;text-align:left;color:var(--text);cursor:pointer;border-bottom:1px solid rgba(95,99,104,.18)}.global-search-hit.is-active{background:var(--surface-strong);color:var(--accent)}.global-search-hit:hover{background:var(--surface)}.global-search-kind{font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.global-search-title{font-weight:600}.global-search-sub{font-size:.85rem;grid-column:2}.global-search-panel kbd{background:var(--surface-strong);padding:0 .3rem;border-radius:4px;font-size:.85em}.bulk-toolbar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.payment-instructions{background:var(--bg-elevated);border:1px solid rgba(95,99,104,.3);border-radius:8px;padding:1rem}.payment-instructions h3{margin-bottom:.5rem}.payment-methods{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-top:.75rem}.payment-method{background:var(--surface);padding:.75rem;border-radius:6px;border:1px solid rgba(95,99,104,.2)}.payment-method-title{font-weight:600;margin-bottom:.4rem;color:var(--accent)}.payments-panel{display:flex;flex-direction:column;gap:1rem;padding:.5rem 0}.payments-summary{display:flex;gap:2rem;flex-wrap:wrap;padding-bottom:.5rem;border-bottom:1px solid rgba(95,99,104,.25)}.payments-summary .stat-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.payments-summary .stat-value{font-size:1.25rem;font-weight:600}.payment-form{background:var(--bg-elevated);padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:.5rem}.payment-form .form-actions{display:flex;gap:.5rem}.estimator-visual{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:1.5rem}.estimator-canvas svg{display:block}.hotspot-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.hotspot-list .is-active{background:var(--surface-strong);color:var(--accent)}.estimator-side h2{margin-top:0}@media (max-width: 1100px){.estimator-visual{grid-template-columns:1fr}}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.dashboard header h1{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.card{background:transparent;border:0;border-radius:0;padding:.5rem 0;box-shadow:none}@media (min-width: 900px){.dashboard-paneled .card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:0 10px 24px var(--shadow)}.dashboard-paneled .card.calendar-card{padding:0}.dashboard-paneled .card.calendar-aside{padding:1rem 1.25rem}}.card h2{margin-bottom:.75rem}.card h3{margin:.75rem 0 .5rem}.list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.list li{padding-bottom:.75rem;border-bottom:1px solid rgba(95,99,104,.25)}.list li:last-child{border-bottom:none;padding-bottom:0}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;padding:.6rem .75rem;border-bottom:1px solid rgba(95,99,104,.25)}.table th{font-size:.85rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.meta-grid{display:grid;grid-template-columns:max-content 1fr;column-gap:1.5rem;row-gap:.5rem;margin:0}.meta-grid dt{color:var(--text-muted);font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;align-self:center}.meta-grid dd{margin:0;word-break:break-word}.meta-grid dd code{font-size:.85rem;background:var(--surface-strong);padding:.1rem .4rem;border-radius:4px}.process-steps{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.process-steps li{display:grid;grid-template-columns:56px 1fr;gap:1rem;align-items:start;background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.25rem}.process-steps h3{margin:0 0 .4rem}.process-steps p{margin:0;line-height:1.6}.process-num{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center}.sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;z-index:100;background:var(--bg);border-top:1px solid var(--border);padding:.6rem .75rem calc(.6rem + env(safe-area-inset-bottom)) .75rem;gap:.5rem;box-shadow:0 -2px 12px #0000001f}.sticky-cta .button{flex:1;text-align:center;padding:.65rem .5rem}.service-hero{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin-bottom:1.5rem}.service-hero img{width:100%;border-radius:12px;aspect-ratio:4 / 3;object-fit:cover}.service-hero h1{margin:.4rem 0 1rem;font-size:2.25rem}.service-bullets{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.5rem 1.5rem}.service-bullets li{padding-left:1.5rem;position:relative;line-height:1.5}.service-bullets li:before{content:"✓";position:absolute;left:0;color:var(--accent);font-weight:700}.service-faqs>div{border-top:1px solid var(--border);padding:1rem 0}.service-faqs>div:first-child{border-top:0;padding-top:0}.service-faqs dt{font-weight:600;margin-bottom:.4rem}.service-faqs dd{margin:0;color:var(--text-muted);line-height:1.6}.service-card-link{display:flex;flex-direction:column;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease}.service-card-link:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000014}.service-card-cta{margin-top:auto;padding-top:.75rem;font-size:.9rem;color:var(--accent);font-weight:600}.portfolio-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}.portfolio-chips .is-active{background:var(--accent);color:#fff;border-color:var(--accent)}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.portfolio-card{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.portfolio-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px #00000014;border-color:var(--accent)}.portfolio-card-img{aspect-ratio:4 / 3;background:var(--surface-strong);overflow:hidden;display:flex;align-items:center;justify-content:center}.portfolio-card-img img{width:100%;height:100%;object-fit:cover;display:block}.portfolio-card-placeholder{font-size:3rem;color:var(--text-muted)}.portfolio-card-body{padding:1rem;display:flex;flex-direction:column;gap:.4rem;flex:1}.portfolio-card-body h3{margin:0;font-size:1.1rem}.portfolio-meta{display:flex;gap:.75rem;font-size:.85rem;color:var(--text-muted);margin-top:auto;padding-top:.5rem}.portfolio-tag{display:inline-block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;background:var(--surface-strong);color:var(--accent);padding:.15rem .55rem;border-radius:999px}.portfolio-tag-small{position:absolute;bottom:.4rem;left:.4rem;font-size:.65rem;text-transform:uppercase;background:#0009;color:#fff;padding:.1rem .4rem;border-radius:4px;letter-spacing:.04em}.portfolio-hero{border-radius:12px;overflow:hidden;background:var(--surface-strong);max-height:560px;display:flex;align-items:center;justify-content:center}.portfolio-hero img{width:100%;max-height:560px;object-fit:cover;display:block}.portfolio-ba{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.portfolio-ba figure{margin:0;border-radius:8px;overflow:hidden;background:var(--surface-strong)}.portfolio-ba img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;cursor:zoom-in}.portfolio-ba figcaption{font-size:.85rem;color:var(--text-muted);padding:.5rem .75rem;text-transform:uppercase;letter-spacing:.05em}.portfolio-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.portfolio-gallery-item{position:relative;border:0;padding:0;background:var(--surface-strong);border-radius:8px;overflow:hidden;cursor:zoom-in;aspect-ratio:1}.portfolio-gallery-item img{width:100%;height:100%;object-fit:cover;display:block}.portfolio-testimonial blockquote{margin:0;font-size:1.15rem;line-height:1.6;font-style:italic}.portfolio-testimonial cite{display:block;margin-top:.75rem;font-style:normal;font-size:.9rem;color:var(--text-muted)}.portfolio-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000eb;z-index:1000;display:flex;align-items:center;justify-content:center;padding:2rem;cursor:zoom-out}.portfolio-lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:4px}.portfolio-lightbox-caption{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);color:#fff;background:#0009;padding:.5rem 1rem;border-radius:4px;font-size:.9rem}@media (max-width: 900px){.two-col,.portal-shell{grid-template-columns:1fr}.portal-sidebar{flex-direction:row;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem;padding:.75rem 1rem}.portal-brand{order:0;flex:0 1 auto}.portal-user{order:1;margin-top:0;flex-direction:row;align-items:center;gap:.5rem}.portal-sidebar nav{order:2;flex-basis:100%;width:100%;flex-direction:row;flex-wrap:wrap}.portal-user .user-chip-meta,.portal-user>.button.button-ghost{display:none}.user-chip-row>.user-chip>.avatar{width:40px!important;height:40px!important}.form-row{flex-direction:column;gap:.5rem}.form-row>div{flex:1 1 100%}.invoice-stats{flex-direction:column;gap:.75rem}.card .table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.card .table thead,.card .table tbody,.card .table tr{display:table;width:100%;table-layout:fixed}.row-between{flex-direction:column;align-items:flex-start;gap:.75rem}.row-between>*{width:100%}.dashboard{gap:1rem}.toolbar{gap:.5rem}.toolbar>input,.toolbar>select,.toolbar>label{flex:1 1 100%;min-width:0;max-width:none}.toolbar input[type=search]{max-width:none}.toolbar>.toolbar-spacer{display:none}.toolbar>.button,.toolbar>button,.toolbar>a.button{width:100%}.header-actions{width:100%;flex-wrap:wrap}.header-actions>*{flex:1 1 auto}.composer-toolbar{flex-wrap:wrap}.contract-body{white-space:pre-wrap;word-wrap:break-word;word-break:break-word}}@media (max-width: 600px){.navbar{padding:0 1rem;height:4rem}.nav-logo{height:2.5rem}.nav-menu{gap:.75rem}.nav-menu li:nth-child(2),.nav-menu li:nth-child(3){display:none}.band{padding:3rem 1rem}.card,.portal-main{padding:1rem}.dashboard{gap:.75rem}.dashboard header h1{font-size:1.25rem}.card h2{font-size:1.05rem}.card h3{font-size:.95rem}.header-actions{flex-direction:column;align-items:stretch}.header-actions>*{width:100%}input,textarea,select{padding:8px 10px}.portal-sidebar{position:sticky;top:0;z-index:10;background:var(--bg);max-height:50vh;overflow-y:auto}.table button+button{margin-left:0;margin-top:.25rem;display:inline-block}.sticky-cta{display:flex}.public-shell{padding-bottom:5rem}.portfolio-ba{grid-template-columns:1fr}.portfolio-lightbox{padding:.5rem}.service-hero{grid-template-columns:1fr;gap:1rem}.service-hero h1{font-size:1.75rem}}
