:root{--zinc-950:#09090b;--zinc-900:#18181b;--zinc-800:#27272a;--zinc-700:#3f3f46;--zinc-500:#71717a;--zinc-400:#a1a1aa;--zinc-300:#d4d4d8;--zinc-200:#e4e4e7;--zinc-100:#f4f4f5;--emerald-600:#059669;--emerald-500:#10b981;--emerald-400:#34d399;--teal-400:#2dd4bf;--teal-500:#14b8a6;--red-500:#ef4444;--red-400:#f87171;--amber-500:#f59e0b;--blue-600:#2563eb;--blue-500:#3b82f6;--blue-400:#60a5fa;--slate-500:#64748b;--slate-400:#94a3b8;--white:#ffffff;--purple-500:#a855f7;--purple-400:#c084fc;--indigo-500:#6366f1;--indigo-400:#818cf8;--pink-500:#ec4899;--pink-400:#f472b6;--cyan-500:#06b6d4;--cyan-400:#22d3ee;--yellow-500:#eab308;--yellow-400:#facc15;--orange-500:#f97316;--orange-400:#fb923c;--lime-500:#84cc16;--lime-400:#a3e635;--rose-500:#f43f5e;--rose-400:#fb7185;--sky-500:#0ea5e9;--sky-400:#38bdf8;--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",sans-serif;--card-radius:0.875rem;--card-shadow:0 4px 24px -8px rgba(0,0,0,0.35);--card-shadow-hover:0 12px 40px -12px rgba(0,0,0,0.5),0 0 0 1px rgba(52,211,153,0.15);--space-2:0.5rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-12:3rem;--radius-sm:0.375rem;--radius-md:0.5rem;--radius-lg:0.75rem;--shadow-card:0 4px 24px -8px rgba(0,0,0,0.35);--shadow-card-hover:0 12px 40px -12px rgba(0,0,0,0.5),0 0 0 1px rgba(52,211,153,0.15);--shadow-nav:0 1px 0 0 var(--zinc-700);--transition-fast:150ms ease;--transition-normal:250ms ease;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--font-medium:500;--font-semibold:600;--font-bold:700}*{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;background:var(--zinc-950);color:var(--zinc-100)}body,html{height:100%;margin:0}body{font-family:var(--font-sans);font-size:1rem;line-height:1.6;background:var(--zinc-950);color:var(--zinc-100);min-height:100vh}img{max-width:100%;height:auto;display:block}a{color:inherit}a:focus{outline:none;opacity:.9}.home{justify-content:center;min-height:100vh;padding:2rem 1.5rem;max-width:42rem;margin:0 auto}.home,.home .content{display:flex;flex-direction:column;align-items:center}.home .content{text-align:center;width:100%}.home h1{margin:0 0 1rem;font-size:clamp(2rem,5vw,2.75rem);font-weight:700;line-height:1.2;letter-spacing:-.02em}.gradient-text,.home h1 .gradient-text{background:linear-gradient(to right,var(--emerald-400),var(--teal-400),var(--emerald-500));-webkit-background-clip:text;background-clip:text;color:transparent}.home p{margin:0 0 1rem;color:var(--zinc-400);font-size:1rem;line-height:1.6}.home p:last-of-type{margin-bottom:1.5rem}.portal-card{background:linear-gradient(135deg,rgba(39,39,42,.95),rgba(24,24,27,.98));border:1px solid rgba(63,63,70,.6);border-radius:.75rem;padding:2rem;width:100%;max-width:24rem;box-shadow:0 25px 50px -12px rgba(0,0,0,.5);position:relative;overflow:hidden;transition:border-color .3s ease,box-shadow .3s ease}.portal-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(52,211,153,.06),transparent);transition:left .5s ease}.portal-card:hover{border-color:rgba(52,211,153,.2);box-shadow:0 25px 50px -12px rgba(0,0,0,.5),0 0 0 1px rgba(52,211,153,.08)}.portal-card:hover:before{left:100%}.portal-login-wrap{width:100%;max-width:400px;margin:0 auto}.portal-login-card{background:linear-gradient(135deg,rgba(39,39,42,.95),rgba(24,24,27,.98));border:1px solid var(--zinc-700);border-radius:var(--radius-lg);padding:var(--space-8);width:100%;box-shadow:var(--shadow-card);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.portal-login-card:hover{border-color:rgba(52,211,153,.2);box-shadow:var(--shadow-card-hover)}.portal-login-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;margin:0 auto var(--space-4);border-radius:var(--radius-md);background:rgba(16,185,129,.15);color:var(--emerald-400)}.login-form,.portal-login-form{display:flex;flex-direction:column;align-items:stretch;gap:var(--space-5);width:100%}.login-form h1,.portal-login-form h1{margin:0 0 .25rem;font-size:var(--text-xl);font-weight:var(--font-bold);text-align:center}.login-form p,.portal-login-form p{margin:0 0 .5rem;color:var(--zinc-400);font-size:var(--text-sm);text-align:center}.login-form-error,.portal-login-form-success{color:var(--emerald-400);font-size:var(--text-sm);margin:0}.portal-login-form-error{color:var(--red-400)!important;font-size:var(--text-sm);margin:0;padding:var(--space-2) var(--space-3);background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-md)}.login-form label,.portal-login-form label{display:flex;flex-direction:column;gap:var(--space-2);width:100%;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-400)}.login-form input,.portal-login-form input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--zinc-700);border-radius:var(--radius-md);background:var(--zinc-800);color:var(--zinc-100);font-size:var(--text-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-form input::placeholder,.portal-login-form input::placeholder{color:var(--zinc-500)}.login-form input:focus,.portal-login-form input:focus{outline:none;border-color:var(--emerald-500);box-shadow:0 0 0 3px rgba(16,185,129,.2)}.portal-login-form .btn-primary{margin-top:var(--space-2)}.portal-btn-spinner{animation:portal-spin .8s linear infinite}@keyframes portal-spin{to{transform:rotate(1turn)}}.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:var(--white);background:var(--blue-600);border:none;border-radius:.5rem;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:0 10px 15px -3px rgba(0,0,0,.2)}.btn-primary:hover:not(:disabled){background:var(--blue-500);transform:scale(1.02);box-shadow:0 20px 25px -5px rgba(0,0,0,.25)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-secondary,.logout-btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:var(--blue-400);background:transparent;border:2px solid var(--blue-500);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.btn-secondary:hover,.logout-btn:hover{background:var(--blue-500);color:var(--white)}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.floating-subtle{animation:float 6s ease-in-out infinite}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes portal-section-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.portal-shell-main .portal-card{max-width:none}.home .content>h1,.portal-card:not(.portal-login-card){animation:fade-in .5s ease-out}.home .content>p{animation:fade-in .5s ease-out .05s both}.login-form .btn-primary,.logout-btn,.portal-login-form .btn-primary{animation:fade-in .5s ease-out .1s both}.portal-shell{height:100vh;min-height:100vh;flex-direction:column}.portal-shell,.portal-top-nav{display:flex;background:var(--zinc-950)}.portal-top-nav{position:-webkit-sticky;position:sticky;top:0;z-index:20;align-items:center;justify-content:space-between;width:100%;height:4rem;min-height:64px;padding:0 1.5rem;border-bottom:1px solid var(--zinc-700);box-shadow:var(--shadow-nav);transition:var(--transition-fast)}.portal-top-nav-logo{font-size:1.35rem;font-weight:700;text-decoration:none}.portal-top-nav-logo.gradient-text{color:transparent}.portal-top-nav-left{display:flex;align-items:center;gap:var(--space-3)}.portal-top-nav-logo:hover{color:var(--emerald-400)}.portal-top-nav-right{display:flex;align-items:center;gap:var(--space-4)}.portal-top-nav-menu-btn{display:none;align-items:center;justify-content:center;width:44px;height:44px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--zinc-300);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.portal-top-nav-menu-btn:hover{color:var(--zinc-100);background:var(--zinc-800)}@media (max-width:767px){.portal-top-nav-menu-btn{display:flex}}.portal-profile-dropdown{position:relative}.portal-profile-trigger{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-4);min-height:48px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--zinc-200);font-size:var(--text-base);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.portal-profile-trigger:hover{background:var(--zinc-800);color:var(--zinc-100)}.portal-profile-avatar{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--blue-600);color:var(--white);font-size:var(--text-sm);font-weight:var(--font-semibold);flex-shrink:0}.portal-profile-avatar-sm{width:32px;height:32px;font-size:var(--text-xs)}.portal-profile-email{max-width:220px;font-size:var(--text-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:480px){.portal-profile-email{display:none}}.portal-profile-chevron{flex-shrink:0;opacity:.8;transition:transform var(--transition-fast)}.portal-profile-trigger[aria-expanded=true] .portal-profile-chevron{transform:rotate(180deg)}.portal-profile-menu{position:absolute;top:calc(100% + var(--space-2));right:0;min-width:220px;padding:var(--space-2);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);animation:portal-dropdown-in .2s ease}@keyframes portal-dropdown-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.portal-profile-menu-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3)}.portal-profile-menu-email{font-size:var(--text-sm);color:var(--zinc-300);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portal-profile-menu-divider{height:1px;background:var(--zinc-700);margin:var(--space-2) 0}.portal-profile-menu-item .logout-btn{width:100%;justify-content:flex-start;padding:var(--space-2) var(--space-3);border:none;font-size:var(--text-sm);animation:none}.portal-profile-menu-item .logout-btn:hover{background:var(--zinc-800);color:var(--emerald-400)}.portal-shell-body{display:flex;flex:1 1;overflow:hidden}.portal-side-nav{width:16rem;flex-shrink:0;padding:var(--space-5) 0;border-right:1px solid var(--zinc-700);background:var(--zinc-900);transition:transform var(--transition-normal),visibility var(--transition-normal)}.portal-side-nav-list{list-style:none;margin:0;padding:0 var(--space-6);display:flex;flex-direction:column;gap:var(--space-2)}.portal-side-nav-link{display:flex;align-items:center;gap:var(--space-5);padding:var(--space-5) var(--space-6);min-height:56px;color:var(--zinc-400);text-decoration:none;font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.portal-side-nav-link:hover{color:var(--zinc-100);background:var(--zinc-800)}.portal-side-nav-link-active{color:var(--blue-400);background:var(--zinc-800);border-left:3px solid var(--blue-500)}.portal-side-nav-link svg{flex-shrink:0;width:26px;height:26px;opacity:.9}.portal-side-nav-overlay{display:none;position:fixed;inset:0;z-index:15;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;transition:opacity var(--transition-normal),visibility var(--transition-normal)}.portal-side-nav-overlay.is-open{opacity:1;visibility:visible}@media (max-width:767px){.portal-side-nav-overlay{display:block}.portal-side-nav{position:fixed;top:0;left:0;bottom:0;z-index:16;width:16rem;transform:translateX(-100%);box-shadow:4px 0 24px rgba(0,0,0,.3)}.portal-side-nav.is-open{transform:translateX(0)}}.portal-shell-main{flex:1 1;overflow:auto;padding:2rem;scroll-padding-top:8rem;width:100%}.portal-shell-main>div{width:100%;max-width:none}.portal-dashboard-header{margin-bottom:var(--space-12)}.portal-dashboard h1{margin:0 0 .5rem;font-size:clamp(1.75rem,4vw,2.25rem);font-weight:var(--font-bold)}.portal-dashboard-welcome{margin:0;font-size:var(--text-sm);color:var(--zinc-400)}.portal-dashboard p{margin:0 0 .5rem;color:var(--zinc-400)}.portal-client-dashboard{display:flex;flex-direction:column;width:100%}.portal-client-dashboard-welcome-header{margin-bottom:var(--space-8)}.portal-client-dashboard-welcome-title{margin:0!important;font-size:clamp(1.5rem,4vw,2rem)!important;font-weight:var(--font-bold);color:var(--zinc-100)}.portal-client-dashboard-two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-6);gap:var(--space-6);margin-bottom:var(--space-10);align-items:stretch}@media (max-width:768px){.portal-client-dashboard-two-col{grid-template-columns:1fr}}.portal-client-dashboard-col{min-width:0;display:flex;flex-direction:column}.portal-client-dashboard-col .portal-card.portal-client-dashboard-card,.portal-client-dashboard-col .portal-client-dashboard-card{flex:1 1;min-height:0;display:flex;flex-direction:column}.portal-client-dashboard-section-full{width:100%;min-width:0;max-width:100%;grid-column:1/-1}.portal-client-dashboard-empty-card{padding:var(--space-6);min-height:10rem}.portal-client-dashboard-empty-inline{margin:0;font-size:var(--text-sm);color:var(--zinc-500)}.portal-client-dashboard-quotes-card{padding:var(--space-6);min-height:10rem}.portal-client-dashboard-quotes-list{margin:0;padding-left:var(--space-5);list-style:none;flex:1 1;min-height:0}.portal-client-dashboard-quotes-list li{margin-bottom:var(--space-2)}.portal-client-dashboard-quote-link{color:var(--blue-400);text-decoration:none}.portal-client-dashboard-quote-link:hover{text-decoration:underline}.portal-client-dashboard-empty,.portal-client-dashboard-error{margin:0;padding:var(--space-6);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);color:var(--zinc-400)}.portal-client-dashboard-section{margin-bottom:var(--space-6)}.portal-client-dashboard-section-full.portal-client-dashboard-section{margin-bottom:var(--space-10)}.portal-client-dashboard-section-title{display:flex;align-items:center;gap:var(--space-2);margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-client-dashboard-cards{display:flex;flex-direction:column;gap:var(--space-4)}.portal-client-dashboard-projects-grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-4);gap:var(--space-4);align-items:stretch}.portal-client-dashboard-projects-grid .portal-client-dashboard-project-card{min-height:100%;display:flex;flex-direction:column}.portal-client-dashboard-card{display:block;padding:var(--space-6);text-decoration:none;color:inherit;border-radius:var(--radius-lg);border:1px solid var(--zinc-700);background:var(--zinc-900);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.portal-client-dashboard-card:hover{border-color:var(--zinc-600);box-shadow:var(--shadow-card)}.portal-client-dashboard-upcoming-card{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);align-content:flex-start}.portal-client-dashboard-upcoming-main{display:flex;flex-direction:column;gap:var(--space-1)}.portal-client-dashboard-upcoming-label{font-size:var(--text-sm);color:var(--zinc-500)}.portal-client-dashboard-upcoming-id{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-client-dashboard-upcoming-amount{font-size:1.25rem;font-weight:var(--font-bold);color:var(--emerald-400)}.portal-client-dashboard-upcoming-due{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--zinc-400)}.portal-client-dashboard-upcoming-cta{width:100%;margin-top:var(--space-2);font-size:var(--text-sm);color:var(--blue-400)}.portal-client-dashboard-project-card{display:flex;flex-direction:column;gap:var(--space-3)}.portal-client-dashboard-project-name{margin:0;font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-client-dashboard-project-desc{margin:0;font-size:var(--text-sm);color:var(--zinc-400);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portal-client-dashboard-project-progress{margin-top:auto}.portal-client-dashboard-project-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.35rem;font-size:.75rem;font-weight:500;color:var(--zinc-500)}.portal-client-dashboard-project-progress-value{font-size:.8125rem;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--emerald-400)}.portal-client-dashboard-project-tasks-note{margin:var(--space-2) 0 0;font-size:.75rem;color:var(--zinc-500)}.portal-client-dashboard-project-link{font-size:var(--text-sm);color:var(--blue-400)}.portal-project-detail-readonly-name{margin:0 0 var(--space-2);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--zinc-100)}.portal-project-detail-readonly-desc{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-300);line-height:1.5}.portal-project-task-readonly-done{color:var(--emerald-400)}.portal-project-detail-client-actions .portal-project-detail-section-title{margin-bottom:var(--space-3)}.portal-project-detail-client-action-buttons{display:flex;flex-wrap:wrap;gap:var(--space-3)}.portal-project-detail-client-action-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:var(--font-medium);border-radius:var(--radius-md);border:1px solid var(--zinc-600);background:var(--zinc-800);color:var(--zinc-200);cursor:pointer;transition:background .2s,border-color .2s}.portal-project-detail-client-action-btn:hover{background:var(--zinc-700);border-color:var(--zinc-500);color:var(--zinc-100)}.portal-project-detail-feature-requests-list{margin:0;padding:0;list-style:none}.portal-project-detail-feature-request-item{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);margin-bottom:var(--space-3);background:var(--zinc-800);border:1px solid var(--zinc-700);border-radius:var(--radius-md)}.portal-project-detail-feature-request-content{flex:1 1;min-width:0}.portal-project-detail-feature-request-action{margin:0;flex-shrink:0}.portal-project-detail-feature-request-turn-into-task-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-900);background:var(--emerald-500);border:1px solid var(--emerald-400);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.portal-project-detail-feature-request-turn-into-task-btn:hover{background:var(--emerald-400);border-color:var(--emerald-300)}.portal-project-detail-feature-request-turn-into-task-btn:focus-visible{outline:2px solid var(--emerald-400);outline-offset:2px}.portal-project-detail-feature-request-turn-into-task-btn:active{background:var(--emerald-600)}.portal-project-detail-feature-request-desc{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--zinc-300);line-height:1.5}.portal-project-detail-feature-request-meta{display:block;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--zinc-500)}.portal-tickets-list{display:flex;flex-direction:column;gap:var(--space-8)}.portal-tickets-client-group{margin:0}.portal-tickets-client-name{margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold)}.portal-tickets-client-name a{color:var(--zinc-100);text-decoration:none}.portal-tickets-client-name a:hover{color:var(--emerald-400)}.portal-tickets-project-group{margin-bottom:var(--space-6);padding-left:var(--space-4);border-left:2px solid var(--zinc-700)}.portal-tickets-project-name{margin:0 0 var(--space-3);font-size:var(--text-base);font-weight:var(--font-medium)}.portal-tickets-project-name a{color:var(--zinc-200);text-decoration:none}.portal-tickets-project-name a:hover{color:var(--emerald-400)}.portal-tickets-ticket-list{margin:0;padding:0;list-style:none}.portal-tickets-ticket{margin-bottom:var(--space-3);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-md)}.portal-tickets-ticket-link{display:block;padding:var(--space-4);color:inherit;text-decoration:none}.portal-tickets-ticket-link:hover{color:inherit}.portal-tickets-ticket-link:hover .portal-tickets-ticket-summary{color:var(--blue-400)}.portal-tickets-ticket--critical{border-left:4px solid var(--red-500)}.portal-tickets-ticket--high{border-left:4px solid var(--orange-500)}.portal-tickets-ticket--medium{border-left:4px solid var(--amber-500)}.portal-tickets-ticket--low{border-left:4px solid var(--zinc-500)}.portal-tickets-ticket-head{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.portal-tickets-ticket-summary{font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-tickets-ticket-severity{font-size:var(--text-xs);font-weight:var(--font-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);background:var(--zinc-700);color:var(--zinc-200)}.portal-tickets-ticket-page{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--zinc-400)}.portal-tickets-ticket-desc{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--zinc-300);line-height:1.5}.portal-tickets-ticket-date{display:block;margin-top:var(--space-2);font-size:var(--text-xs);color:var(--zinc-500)}.portal-ticket-detail-page{max-width:52rem}.portal-ticket-detail-back{display:inline-block;margin-bottom:var(--space-4);font-size:var(--text-sm);color:var(--zinc-400);text-decoration:none}.portal-ticket-detail-back:hover{color:var(--blue-400)}.portal-ticket-detail-title{margin:0 0 var(--space-3);font-size:clamp(1.25rem,3vw,1.75rem);font-weight:var(--font-bold);color:var(--zinc-100)}.portal-ticket-detail-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3);margin-bottom:var(--space-8)}.portal-ticket-detail-severity{font-size:var(--text-xs);font-weight:var(--font-medium);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.portal-ticket-detail-severity--critical{background:rgba(239,68,68,.2);color:var(--red-400)}.portal-ticket-detail-severity--high{background:rgba(249,115,22,.2);color:var(--orange-400)}.portal-ticket-detail-severity--medium{background:rgba(245,158,11,.2);color:var(--amber-400)}.portal-ticket-detail-severity--low{background:var(--zinc-700);color:var(--zinc-300)}.portal-ticket-detail-date{font-size:var(--text-sm);color:var(--zinc-500)}.portal-ticket-detail-create-task{margin:0 0 0 auto}.portal-ticket-detail-create-task-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-900);background:var(--emerald-500);border:1px solid var(--emerald-400);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.portal-ticket-detail-create-task-btn:hover{background:var(--emerald-400);border-color:var(--emerald-300)}.portal-ticket-detail-create-task-btn:focus-visible{outline:2px solid var(--emerald-400);outline-offset:2px}.portal-ticket-detail-create-task-btn:active{background:var(--emerald-600)}.portal-ticket-detail-body{display:flex;flex-direction:column;gap:var(--space-8)}.portal-ticket-detail-section-title{margin:0 0 var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-200)}.portal-ticket-detail-dl{margin:0;display:flex;flex-direction:column;gap:var(--space-3)}.portal-ticket-detail-row{display:grid;grid-template-columns:10rem 1fr;grid-gap:var(--space-4);gap:var(--space-4);align-items:baseline}.portal-ticket-detail-row dt{margin:0;font-size:var(--text-sm);color:var(--zinc-500)}.portal-ticket-detail-row dd{margin:0;font-size:var(--text-sm);color:var(--zinc-200)}.portal-ticket-detail-row dd a{color:var(--blue-400);text-decoration:none}.portal-ticket-detail-row dd a:hover{text-decoration:underline}.portal-ticket-detail-description{margin:0;padding:var(--space-4);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-md);font-size:var(--text-sm);color:var(--zinc-300);line-height:1.6;white-space:pre-wrap}.portal-ticket-detail-attachments{margin-top:var(--space-2)}.portal-ticket-detail-attachment{padding:var(--space-4);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-md)}.portal-ticket-detail-screenshot-wrap{margin-bottom:var(--space-4)}.portal-ticket-detail-screenshot-link{display:block;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--zinc-700)}.portal-ticket-detail-screenshot-img{display:block;max-width:100%;height:auto;vertical-align:top}.portal-ticket-detail-attachment-meta{margin:0;font-size:var(--text-sm);color:var(--zinc-400)}.portal-ticket-detail-attachment-download{color:var(--blue-400);text-decoration:none}.portal-ticket-detail-attachment-download:hover{text-decoration:underline}.portal-ticket-detail-attachment-type{color:var(--zinc-500)}.portal-dashboard-kpis{margin-bottom:var(--space-12);animation:portal-section-in .3s ease-out both}.portal-dashboard-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-6);gap:var(--space-6)}@media (max-width:1024px){.portal-dashboard-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.portal-dashboard-kpi-grid{grid-template-columns:1fr}}.portal-dashboard-kpi-card{display:flex;align-items:center;gap:var(--space-6);padding:var(--space-8);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.portal-dashboard-kpi-card:hover{border-color:var(--zinc-600);box-shadow:var(--shadow-card);transform:translateY(-2px)}.portal-dashboard-kpi-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-md)}.portal-dashboard-kpi-card--indigo .portal-dashboard-kpi-icon{background:rgba(99,102,241,.2);color:var(--indigo-400)}.portal-dashboard-kpi-card--indigo .portal-dashboard-kpi-value{color:var(--indigo-400)}.portal-dashboard-kpi-card--cyan .portal-dashboard-kpi-icon{background:rgba(6,182,212,.2);color:var(--cyan-400)}.portal-dashboard-kpi-card--cyan .portal-dashboard-kpi-value{color:var(--cyan-400)}.portal-dashboard-kpi-card--orange .portal-dashboard-kpi-icon{background:rgba(249,115,22,.2);color:var(--orange-400)}.portal-dashboard-kpi-card--orange .portal-dashboard-kpi-value{color:var(--orange-400)}.portal-dashboard-kpi-card--rose .portal-dashboard-kpi-icon{background:rgba(244,63,94,.2);color:var(--rose-400)}.portal-dashboard-kpi-card--rose .portal-dashboard-kpi-value{color:var(--rose-400)}.portal-dashboard-kpi-card--blue .portal-dashboard-kpi-icon{background:rgba(59,130,246,.2);color:var(--blue-400)}.portal-dashboard-kpi-card--blue .portal-dashboard-kpi-value{color:var(--blue-400)}.portal-dashboard-kpi-card--emerald .portal-dashboard-kpi-icon{background:rgba(16,185,129,.2);color:var(--emerald-400)}.portal-dashboard-kpi-card--emerald .portal-dashboard-kpi-value{color:var(--emerald-400)}.portal-dashboard-kpi-card--amber .portal-dashboard-kpi-icon{background:rgba(245,158,11,.2);color:var(--amber-500)}.portal-dashboard-kpi-card--amber .portal-dashboard-kpi-value{color:var(--amber-500)}.portal-dashboard-kpi-card--red .portal-dashboard-kpi-icon{background:rgba(248,113,113,.2);color:var(--red-400)}.portal-dashboard-kpi-card--red .portal-dashboard-kpi-value{color:var(--red-400)}.portal-dashboard-kpi-content{display:flex;flex-direction:column;gap:var(--space-1)}.portal-dashboard-kpi-value{font-size:2.5rem;font-weight:var(--font-bold);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--zinc-100);line-height:1.2}.portal-dashboard-kpi-label{font-size:var(--text-sm);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--zinc-500)}.portal-dashboard-quick{margin-bottom:var(--space-12);animation:portal-section-in .3s ease-out .05s both}.portal-dashboard-quick-title{margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-dashboard-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-6);gap:var(--space-6)}@media (max-width:768px){.portal-dashboard-quick-grid{grid-template-columns:1fr}}.portal-dashboard-quick-card{display:flex;align-items:center;justify-content:center;gap:var(--space-5);padding:var(--space-8) var(--space-10);min-height:64px;background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);color:var(--zinc-200);text-decoration:none;font-size:var(--text-lg);font-weight:var(--font-medium);transition:border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.portal-dashboard-quick-card:hover{border-color:var(--blue-500);color:var(--blue-400);box-shadow:var(--shadow-card)}.portal-dashboard-quick-icon{flex-shrink:0;width:28px;height:28px;color:var(--blue-400)}.portal-dashboard-stats{margin-top:var(--space-12);animation:portal-section-in .3s ease-out .05s both}.portal-dashboard-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-6);gap:var(--space-6);align-items:stretch}@media (max-width:640px){.portal-dashboard-stats-grid{grid-template-columns:1fr}}.portal-dashboard-stat-card{display:flex;flex-direction:column;min-height:12rem;padding:var(--space-6);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.portal-dashboard-stat-card:hover{border-color:var(--zinc-600);box-shadow:var(--shadow-card)}.portal-dashboard-stat-header{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0;margin-bottom:var(--space-3)}.portal-dashboard-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0;border-radius:var(--radius-md)}.portal-dashboard-stat-card--blue .portal-dashboard-stat-icon{background:rgba(59,130,246,.2);color:var(--blue-400)}.portal-dashboard-stat-card--blue .portal-dashboard-stat-value{color:var(--blue-400)}.portal-dashboard-stat-card--emerald .portal-dashboard-stat-icon{background:rgba(16,185,129,.2);color:var(--emerald-400)}.portal-dashboard-stat-card--emerald .portal-dashboard-stat-value{color:var(--emerald-400)}.portal-dashboard-stat-card--indigo .portal-dashboard-stat-icon{background:rgba(99,102,241,.2);color:var(--indigo-400)}.portal-dashboard-stat-card--indigo .portal-dashboard-stat-value{color:var(--indigo-400)}.portal-dashboard-stat-card--progress .portal-dashboard-stat-icon{background:rgba(34,197,94,.2);color:var(--emerald-400)}.portal-dashboard-stat-label{font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--zinc-500)}.portal-dashboard-stat-body{flex:1 1;min-width:0;display:flex;flex-direction:column;gap:0}.portal-dashboard-stat-body--chart{justify-content:stretch}.portal-dashboard-stat-value{flex-shrink:0;font-size:1.75rem;font-weight:var(--font-bold);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--zinc-100);line-height:1.2;margin-bottom:var(--space-4)}.portal-dashboard-stat-mini-chart{flex-shrink:0;display:flex;flex-direction:column;gap:var(--space-2);padding-top:var(--space-3);border-top:1px solid var(--zinc-800)}.portal-dashboard-stat-stacked-bar{display:flex;height:8px;border-radius:4px;overflow:hidden;background:var(--zinc-800)}.portal-dashboard-stat-stacked-segment{height:100%;min-width:2px;transition:width var(--transition-normal)}.portal-dashboard-stat-single-bar{height:8px;border-radius:4px;overflow:hidden;background:var(--zinc-800)}.portal-dashboard-stat-single-fill{display:block;height:100%;background:var(--indigo-500);border-radius:4px}.portal-dashboard-stat-legend{font-size:.7rem;color:var(--zinc-500);line-height:1.3}.portal-dashboard-stat-bar-chart{display:flex;flex-direction:column;gap:var(--space-2);flex:1 1;min-height:0;padding-top:var(--space-3);margin-top:var(--space-2);border-top:1px solid var(--zinc-800)}.portal-dashboard-stat-bar-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xs)}.portal-dashboard-stat-bar-label{flex:0 0 3.5rem;color:var(--zinc-400)}.portal-dashboard-stat-bar-track{flex:1 1;height:6px;border-radius:3px;overflow:hidden;background:var(--zinc-800);min-width:0}.portal-dashboard-stat-bar-fill{display:block;height:100%;border-radius:3px;transition:width var(--transition-normal)}.portal-dashboard-stat-bar-value{flex:0 0 1.5rem;font-weight:var(--font-semibold);color:var(--zinc-200);text-align:right}.portal-dashboard-charts{margin-top:var(--space-12);animation:portal-section-in .3s ease-out .1s both}.portal-dashboard-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-8);gap:var(--space-8);margin-bottom:var(--space-8)}@media (max-width:1024px){.portal-dashboard-charts-grid{grid-template-columns:1fr}}.portal-dashboard-chart-card{padding:var(--space-8);background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg)}.portal-dashboard-chart-title{margin:0 0 var(--space-5);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-dashboard-chart{min-height:200px}.portal-dashboard-chart-empty{display:flex;flex-direction:column;justify-content:center;min-height:240px;padding:var(--space-6) 0}.portal-dashboard-chart-empty-message{margin:0;font-size:var(--text-sm);color:var(--zinc-500);line-height:1.5}.portal-dashboard-progress .portal-dashboard-chart-empty-message{margin-top:var(--space-2)}.portal-dashboard-pipeline-bar{display:flex;height:24px;border-radius:var(--radius-md);overflow:hidden;background:var(--zinc-800)}.portal-dashboard-pipeline-segment{transition:width var(--transition-normal)}.portal-dashboard-pipeline-legend{display:flex;flex-wrap:wrap;gap:var(--space-4);margin-top:var(--space-4);font-size:var(--text-sm);color:var(--slate-400)}.portal-dashboard-pipeline-legend-item{display:inline-flex;align-items:center;gap:var(--space-2)}.portal-dashboard-pipeline-legend-dot{width:10px;height:10px;border-radius:50%}.portal-dashboard-progress-list{display:flex;flex-direction:column;gap:var(--space-4)}.portal-dashboard-progress-item{display:grid;grid-template-columns:1fr auto auto;align-items:center;grid-gap:var(--space-4);gap:var(--space-4)}.portal-dashboard-progress-label{font-size:var(--text-sm);color:var(--zinc-300)}.portal-dashboard-progress-track{height:10px;background:var(--zinc-800);border-radius:5px;overflow:hidden;min-width:120px}.portal-dashboard-progress-fill{height:100%;background:linear-gradient(90deg,var(--blue-600),var(--blue-400));border-radius:5px;transition:width .25s ease-out}.portal-dashboard-progress-value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--blue-400);min-width:3ch}.portal-client-home-content{max-width:32rem}.portal-client-home-card-wrap{max-width:100%}.portal-client-home-card{max-width:none}.portal-client-home-welcome{margin:0 0 var(--space-6);font-size:var(--text-sm);color:var(--zinc-400)}.portal-client-home-section{margin-bottom:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.portal-client-home-section-title{display:flex;align-items:center;gap:var(--space-3);margin:0 0 var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-client-home-section-title svg{color:var(--emerald-400)}.portal-client-home-invoice-list{list-style:none;margin:0;padding:0}.portal-client-home-invoice-item{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:var(--space-2);padding:var(--space-3) 0;border-bottom:1px solid var(--zinc-800)}.portal-client-home-invoice-item:last-child{border-bottom:none}.portal-client-home-invoice-link{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:var(--space-2);width:100%;color:inherit;text-decoration:none}.portal-client-home-invoice-link:hover{color:var(--emerald-400)}.portal-client-home-invoice-id{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-200)}.portal-client-home-invoice-meta{font-size:var(--text-xs);color:var(--zinc-500)}.portal-client-home-empty{display:flex;align-items:center;gap:var(--space-3);margin:0;font-size:var(--text-sm);color:var(--zinc-500)}.portal-client-home-empty svg{flex-shrink:0;color:var(--zinc-600)}.portal-client-home-actions{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.portal-clients-page{position:relative;width:100%;padding-right:11rem}.portal-clients-page-header{margin-bottom:1.5rem}.portal-clients-page-header h1{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,2rem);font-weight:700}.portal-clients-page-header p{margin:0;font-size:.9375rem;color:var(--zinc-400)}.portal-clients-add-btn{position:absolute;top:0;right:0;width:auto}@media (max-width:640px){.portal-clients-page{padding-right:0}.portal-clients-add-btn{position:static;display:inline-block;margin-top:1rem}}.portal-clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(560px,1fr));grid-gap:1.25rem;gap:1.25rem;margin-top:0}.portal-client-card-link{display:block;text-decoration:none;color:inherit;transition:transform .2s ease}.portal-client-card-link:hover{transform:translateY(-2px)}.portal-client-card-link:hover .portal-client-card{border-color:rgba(52,211,153,.25);box-shadow:var(--card-shadow-hover)}.portal-client-card-link:hover .portal-client-card:after{opacity:1}.portal-client-card{position:relative;max-width:none;padding:0;border-radius:var(--card-radius);box-shadow:var(--shadow-card);transition:transform var(--transition-normal),border-color var(--transition-fast),box-shadow var(--transition-fast);overflow:hidden}.portal-client-card:after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;opacity:0;transition:opacity .25s ease;box-shadow:inset 0 0 0 1px rgba(52,211,153,.2)}.portal-client-card-header{padding:1.25rem 1.5rem 0}.portal-client-card-name{margin:0;font-size:1.25rem;font-weight:700;color:var(--zinc-100);letter-spacing:-.02em;line-height:1.25}.portal-client-card-meta{margin-top:.75rem;padding-bottom:1rem;border-bottom:1px solid var(--zinc-700)}.portal-client-card-description{margin:0 0 .5rem;font-size:.875rem;color:var(--zinc-400);line-height:1.5}.portal-client-card-description:last-child{margin-bottom:0}.portal-client-card-address{margin:0;font-style:normal;font-size:.8125rem;color:var(--zinc-500);line-height:1.5}.portal-client-card-address span{display:block}.portal-client-card-kpis{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:.75rem;gap:.75rem;padding:1.25rem 1.5rem}.portal-client-card-kpi{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:rgba(39,39,42,.6);border-radius:.5rem;border:1px solid var(--zinc-700);transition:background .2s ease,border-color .2s ease}.portal-client-card-link:hover .portal-client-card-kpi{background:rgba(39,39,42,.8);border-color:var(--zinc-600)}.portal-client-card-kpi-value{font-size:1.5rem;font-weight:700;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--zinc-100);line-height:1.2}.portal-client-card-kpi--success .portal-client-card-kpi-value{color:var(--emerald-400)}.portal-client-card-kpi--danger .portal-client-card-kpi-value{color:var(--red-400)}.portal-client-card-kpi-label{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--zinc-500)}.portal-client-card-progress{padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--zinc-700);background:rgba(0,0,0,.15)}.portal-client-card-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.portal-client-card-progress-label{font-size:.8125rem;font-weight:500;color:var(--zinc-400)}.portal-client-card-progress-value{font-size:.8125rem;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--emerald-400)}.portal-client-card-progress-value.portal-client-card-progress-muted{color:var(--zinc-500);font-weight:500}.portal-client-card-progress-track{height:8px;background:var(--zinc-800);border-radius:4px;overflow:hidden}.portal-client-card-progress-fill{height:100%;background:linear-gradient(90deg,var(--emerald-600),var(--emerald-400));border-radius:4px;transition:width .25s ease-out}@media (max-width:640px){.portal-client-card-kpis{grid-template-columns:repeat(3,1fr)}}.portal-clients-empty-card{grid-column:1/-1;padding:2rem;background:var(--zinc-900);border:1px dashed var(--zinc-700);border-radius:.75rem;text-align:center}.portal-clients-empty{margin:0;color:var(--zinc-500);font-size:.9375rem}.portal-clients-empty-link{color:var(--emerald-400);text-decoration:underline}.portal-clients-empty-link:hover{color:var(--emerald-300)}.portal-client-detail-page{width:100%;max-width:none}.portal-client-detail{display:flex;flex-direction:column;gap:0}.portal-client-back{display:inline-flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-6);font-size:var(--text-sm);color:var(--zinc-400);text-decoration:none;transition:color var(--transition-fast)}.portal-client-back:hover{color:var(--emerald-400)}.portal-client-detail-hero{width:100%;padding:var(--space-8) 0;margin:0;border-bottom:1px solid var(--zinc-700)}.portal-client-detail-hero-grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-6);gap:var(--space-6)}@media (min-width:768px){.portal-client-detail-hero-grid{grid-template-columns:1fr 1.5fr 1fr;gap:var(--space-8)}}.portal-client-detail-hero .portal-inline-edit-address-fields{display:flex;flex-direction:column;gap:1rem}.portal-client-detail-hero .portal-inline-edit-address-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.portal-client-detail-nav-sentinel{position:absolute;top:0;left:0;width:1px;height:1px;pointer-events:none;visibility:hidden}.portal-client-detail-nav-wrap{position:relative}.portal-client-detail-nav{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-3) 0;margin:0;background:rgba(9,9,11,.98);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:2px solid var(--zinc-700);box-shadow:0 4px 24px -8px rgba(0,0,0,.5);list-style:none}.portal-client-detail-nav.is-fixed{position:fixed;top:4rem;left:16rem;right:0;margin:0;padding-left:2rem;padding-right:2rem}@media (max-width:767px){.portal-client-detail-nav.is-fixed{left:0}}.portal-client-detail-nav-spacer{display:none;height:2.75rem;flex-shrink:0}.portal-client-detail-nav-spacer.is-visible{display:block}.portal-client-detail-nav-link{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--zinc-400);text-decoration:none;border-radius:var(--radius-md);transition:color var(--transition-fast),background var(--transition-fast)}.portal-client-detail-nav-link:hover{color:var(--zinc-100);background:var(--zinc-800)}.portal-client-detail-nav-link-active{color:var(--blue-400);background:var(--zinc-800);border-left:3px solid var(--blue-500);padding-left:calc(var(--space-5) - 3px)}.portal-client-detail-nav-link[href]:focus-visible{outline:2px solid var(--blue-500)}.portal-client-detail-nav-count{font-size:.75rem;padding:.2rem .5rem;background:var(--zinc-700);border-radius:999px;color:var(--zinc-300)}.portal-client-detail-section{min-height:100vh;padding:var(--space-8) 0;border-bottom:1px solid var(--zinc-700);animation:portal-section-in .25s ease-out both;scroll-margin-top:5.5rem}.portal-client-detail-section:last-of-type{border-bottom:none;padding-bottom:0}.portal-client-detail-section-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.portal-client-detail-section-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--zinc-100)}.portal-client-detail-cards{display:flex;flex-direction:column;gap:var(--space-4)}.portal-client-detail-projects-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-4);gap:var(--space-4)}@media (max-width:1000px){.portal-client-detail-projects-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.portal-client-detail-projects-grid{grid-template-columns:1fr}}.portal-client-detail-quotes-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-4);gap:var(--space-4)}@media (max-width:1200px){.portal-client-detail-quotes-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.portal-client-detail-quotes-grid{grid-template-columns:1fr}}.portal-client-detail-invoice-search-wrap{margin-bottom:1.25rem}.portal-client-detail-invoice-search-label{display:block;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-400);margin-bottom:.5rem}.portal-client-detail-invoice-search-input{width:100%;max-width:24rem;padding:var(--space-2) var(--space-3);font-size:var(--text-base);color:var(--zinc-100);background:var(--zinc-800);border:1px solid var(--zinc-700);border-radius:var(--radius-md)}.portal-client-detail-invoice-search-input::placeholder{color:var(--zinc-500)}.portal-client-detail-invoice-search-input:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 2px rgba(59,130,246,.25)}.portal-client-detail-invoices-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--space-4);gap:var(--space-4)}@media (max-width:1200px){.portal-client-detail-invoices-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.portal-client-detail-invoices-grid{grid-template-columns:1fr}}.portal-client-detail-quote-card-wrap{position:relative;display:flex;flex-direction:column;min-height:100%}.portal-client-detail-quote-card-wrap--accepted .portal-client-detail-quote-card{background:linear-gradient(135deg,rgba(5,150,105,.15),rgba(24,24,27,.98) 50%);border-color:rgba(16,185,129,.35)}.portal-client-detail-quote-card-wrap--accepted .portal-client-detail-quote-card:hover{border-color:rgba(16,185,129,.5)}.portal-client-detail-quote-watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:2.75rem;font-weight:800;color:rgba(16,185,129,.42);letter-spacing:.08em;transform:rotate(-12deg);z-index:1;text-shadow:0 0 20px rgba(16,185,129,.15)}.portal-client-detail-quote-card{position:relative;z-index:0;flex:1 1;min-height:0;display:flex;flex-direction:column;gap:.75rem}.portal-client-detail-quote-card-link{display:flex;flex-direction:column;gap:.5rem;min-width:0;flex:1 1;text-decoration:none;color:inherit}.portal-client-detail-quote-card-link:hover{color:inherit}.portal-client-detail-quote-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.portal-client-detail-invoice-card-wrap{position:relative;display:flex;flex-direction:column;min-height:100%}.portal-client-detail-invoice-watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;font-size:2.75rem;font-weight:800;color:rgba(16,185,129,.42);letter-spacing:.08em;transform:rotate(-12deg);z-index:1;text-shadow:0 0 20px rgba(16,185,129,.15)}.portal-client-detail-invoice-card{position:relative;z-index:0;flex:1 1;min-height:0;display:flex;flex-direction:column;gap:.75rem}.portal-client-detail-invoice-card-link{display:flex;flex-direction:column;gap:.5rem;min-width:0;flex:1 1;text-decoration:none;color:inherit}.portal-client-detail-invoice-card-link:hover{color:inherit}.portal-client-detail-invoice-card-actions{display:flex;flex-wrap:wrap;gap:.5rem}.portal-client-detail-error{margin:.75rem 0 0;padding:.5rem .75rem;background:rgba(239,68,68,.15);color:var(--red-400);border-radius:var(--radius-sm);font-size:var(--text-sm)}.portal-client-detail-section-btn--disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.portal-client-detail-members-hint{font-size:var(--text-sm);color:var(--zinc-500)}.portal-client-detail-members-error{margin-bottom:var(--space-4)}.portal-client-detail-members-card{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-8)}.portal-client-detail-members-invite-block,.portal-client-detail-members-list-block{display:flex;flex-direction:column;gap:var(--space-3)}.portal-client-detail-members-subtitle{margin:0;font-size:var(--text-base);font-weight:600;color:var(--zinc-200)}.portal-client-detail-add-member-form{margin:0}.portal-client-detail-add-member-row{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.portal-client-detail-add-member-input{flex:1 1;min-width:200px;padding:.6rem .75rem;background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-md);color:var(--zinc-100);font-size:1rem}.portal-client-detail-add-member-input:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 2px rgba(59,130,246,.25)}.portal-client-detail-add-member-btn{flex-shrink:0}.portal-client-detail-invite-link-wrap{margin:var(--space-3) 0 0;font-size:var(--text-sm)}.portal-client-detail-invite-link-label{display:block;color:var(--zinc-400);margin-bottom:.35rem}.portal-client-detail-invite-link-row{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:flex-start}.portal-client-detail-invite-link{flex:1 1;min-width:0;padding:.5rem .75rem;background:var(--zinc-800);border-radius:var(--radius-sm);font-size:.875rem;word-break:break-all}.portal-client-detail-invite-copy-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .75rem}.portal-client-detail-members-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-3)}.portal-client-detail-member-card{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);background:var(--zinc-800);border:1px solid var(--zinc-700);border-radius:var(--radius-md);transition:border-color .15s ease}.portal-client-detail-member-card:hover{border-color:var(--zinc-600)}.portal-client-detail-member-card-main{display:flex;align-items:center;gap:var(--space-3);min-width:0}.portal-client-detail-member-icon{flex-shrink:0;color:var(--zinc-500)}.portal-client-detail-member-card--user .portal-client-detail-member-icon{color:var(--emerald-500)}.portal-client-detail-member-card--pending .portal-client-detail-member-icon{color:var(--amber-500)}.portal-client-detail-member-info{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2);min-width:0}.portal-client-detail-member-email{font-size:.9375rem;font-weight:500;color:var(--zinc-100)}.portal-client-detail-member-badge{font-size:.7rem;font-weight:500;padding:.2rem .5rem;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.02em;background:var(--zinc-700);color:var(--zinc-300)}.portal-client-detail-member-badge--pending{background:rgba(245,158,11,.25);color:var(--amber-400)}.portal-client-detail-member-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.portal-client-detail-member-action-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .65rem;font-size:.8125rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s ease,opacity .15s ease}.portal-client-detail-member-action-btn:disabled{opacity:.6;cursor:not-allowed}.portal-client-detail-member-action-btn--reset{background:var(--blue-600);color:var(--zinc-100)}.portal-client-detail-member-action-btn--reset:hover:not(:disabled){background:var(--blue-500)}.portal-client-detail-member-action-btn--resend{background:var(--emerald-600);color:var(--zinc-100)}.portal-client-detail-member-action-btn--resend:hover:not(:disabled){background:var(--emerald-500)}.portal-client-detail-member-action-btn--copy{background:var(--zinc-600);color:var(--zinc-100)}.portal-client-detail-member-action-btn--copy:hover:not(:disabled){background:var(--zinc-500)}.portal-client-detail-member-action-btn--remove{background:rgba(239,68,68,.2);color:var(--red-400)}.portal-client-detail-member-action-btn--remove:hover:not(:disabled){background:rgba(239,68,68,.35)}.portal-client-detail-members-empty{margin:0;padding:var(--space-4);font-size:var(--text-sm);color:var(--zinc-500);background:var(--zinc-800);border-radius:var(--radius-md);border:1px dashed var(--zinc-600)}.portal-quote-recipients{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.portal-quote-recipient-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem}.portal-quote-form-note{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-400)}.portal-start-invoicing-recipients{margin-bottom:var(--space-6)}.portal-start-invoicing-recipients-list{display:flex;flex-direction:column;gap:var(--space-2);margin-top:var(--space-2)}.portal-start-invoicing-recipient-item{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem}.portal-sign-up-page{min-height:60vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.portal-sign-up-card{max-width:24rem;width:100%;padding:var(--space-8)}.portal-sign-up-title{margin:0 0 var(--space-4);font-size:1.5rem;font-weight:700;color:var(--zinc-100)}.portal-sign-up-text{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-400)}.portal-sign-up-form{display:flex;flex-direction:column;gap:var(--space-4)}.portal-sign-up-label{font-size:var(--text-sm);font-weight:500;color:var(--zinc-300)}.portal-sign-up-input{padding:.5rem .75rem;background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-md);color:var(--zinc-100);font-size:1rem;width:100%}.portal-sign-up-error{margin:0;font-size:var(--text-sm);color:var(--red-400)}.portal-sign-up-submit{margin-top:var(--space-2)}.portal-client-detail-card-item{display:block;width:100%;padding:var(--space-6) var(--space-8);text-decoration:none;color:inherit;transition:border-color .2s,box-shadow .2s;transition:transform var(--transition-fast),border-color var(--transition-fast),box-shadow var(--transition-fast)}.portal-client-detail-card-item:hover{transform:translateY(-2px);border-color:rgba(52,211,153,.25);box-shadow:var(--shadow-card-hover)}.portal-client-detail-project-card{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-6) var(--space-8);width:100%;min-height:100%}.portal-client-detail-project-card-link{display:flex;flex-direction:column;gap:.5rem;min-width:0;width:100%;flex:1 1;min-height:0;text-decoration:none;color:inherit}.portal-client-detail-project-card-link:hover{color:inherit}.portal-client-detail-project-card-desc{margin:0;width:100%;font-size:.875rem;color:var(--zinc-400);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.portal-client-detail-project-card-progress{margin-top:.25rem;width:100%}.portal-client-detail-project-card-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.35rem}.portal-client-detail-project-card-progress-label{font-size:.75rem;font-weight:500;color:var(--zinc-500)}.portal-client-detail-project-card-progress-value{font-size:.8125rem;font-weight:600;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;color:var(--emerald-400)}.portal-client-detail-project-card--archive .portal-client-detail-project-card-desc,.portal-client-detail-project-card--archive .portal-client-detail-project-card-progress{margin-top:0}.portal-client-detail-project-card--archive{display:flex;flex-direction:column;gap:.5rem}.portal-client-detail-project-card--archive .portal-client-detail-project-card-progress{margin-top:auto}.portal-client-detail-project-card-actions{width:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-gap:.5rem;gap:.5rem}.portal-client-detail-project-card-actions--2cols{grid-template-columns:repeat(2,1fr)}.portal-client-detail-card-btn{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.5rem .6rem;font-size:.8125rem;font-weight:500;border:none;border-radius:var(--radius-sm);cursor:pointer;min-width:0}.portal-client-detail-card-btn:disabled{opacity:.6;cursor:not-allowed}.portal-client-detail-card-btn-complete{color:var(--zinc-900);background:var(--emerald-500)}.portal-client-detail-card-btn-complete:hover:not(:disabled){background:var(--emerald-400)}.portal-client-detail-card-btn-incomplete{color:var(--zinc-300);background:var(--zinc-700);border:1px solid var(--zinc-600)}.portal-client-detail-card-btn-incomplete:hover:not(:disabled){background:var(--zinc-600);color:var(--zinc-200)}.portal-client-detail-card-btn-paid{color:var(--zinc-900);background:var(--emerald-500)}.portal-client-detail-card-btn-paid:hover:not(:disabled){background:var(--emerald-400)}.portal-client-detail-card-btn-archive{color:var(--zinc-900);background:var(--orange-500)}.portal-client-detail-card-btn-archive:hover:not(:disabled){background:var(--orange-400)}.portal-client-detail-card-btn-delete{color:var(--zinc-100);background:var(--red-500)}.portal-client-detail-card-btn-delete:hover:not(:disabled){background:var(--red-400)}.portal-client-detail-archive-btn{flex-shrink:0;display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .65rem;font-size:.8125rem;color:var(--zinc-900);background:var(--orange-500);border:none;border-radius:var(--radius-sm)}.portal-client-detail-archive-btn:hover:not(:disabled){background:var(--orange-400)}.portal-client-detail-card-title{margin:0 0 var(--space-2);font-size:var(--text-xl);font-weight:600;color:var(--zinc-100)}.portal-client-detail-card-meta{margin:0 0 var(--space-1);font-size:var(--text-base);color:var(--zinc-400)}.portal-client-detail-card-desc{margin:0;font-size:var(--text-sm);color:var(--zinc-500);line-height:1.5}.portal-client-detail-empty{margin:0;padding:1.5rem;font-size:.9375rem;color:var(--zinc-500);background:var(--zinc-800);border-radius:.5rem;border:1px dashed var(--zinc-600)}.portal-client-detail-empty a{color:var(--emerald-400);text-decoration:underline}.portal-empty-state{padding:var(--space-8);text-align:center;background:var(--zinc-800);border:1px dashed var(--zinc-600);border-radius:var(--radius-md)}.portal-empty-state-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;margin:0 auto var(--space-4);border-radius:var(--radius-md);background:var(--zinc-700);color:var(--zinc-500)}.portal-empty-state-heading{margin:0 0 var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-300)}.portal-empty-state-body{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-500);line-height:1.5}.portal-empty-state-action{margin-top:var(--space-4)}.portal-client-detail-cards>.portal-empty-state{grid-column:1/-1}.portal-client-detail-section-btn{display:inline-flex;align-items:center;gap:var(--space-2);width:auto}.portal-client-detail-card{padding:1.5rem 1.75rem}.portal-client-detail-card-header{margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid var(--zinc-700)}.portal-client-detail-name{margin:0 0 .25rem;font-size:clamp(1.25rem,3vw,1.5rem);font-weight:700;color:var(--zinc-100)}.portal-inline-edit{margin-bottom:var(--space-4);transition:opacity var(--transition-normal)}.portal-inline-edit:last-child{margin-bottom:0}.portal-inline-edit-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-400)}.portal-inline-edit-display{display:flex;align-items:flex-start;gap:var(--space-3);min-height:44px}.portal-inline-edit-value{flex:1 1;font-size:var(--text-base);color:var(--zinc-200)}.portal-inline-edit-value-block{white-space:pre-wrap;word-break:break-word}.portal-inline-edit-placeholder{color:var(--zinc-500);font-style:italic}.portal-inline-edit-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;min-width:44px;min-height:44px;padding:0;background:transparent;border:none;border-radius:var(--radius-md);color:var(--zinc-400);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast)}.portal-inline-edit-btn:hover{color:var(--emerald-400);background:var(--zinc-800)}.portal-inline-edit-btn-edit{flex-shrink:0}.portal-inline-edit-btn-save{color:var(--emerald-400)}.portal-inline-edit-btn-save:hover:not(:disabled){background:rgba(16,185,129,.2)}.portal-inline-edit-btn-cancel{color:var(--zinc-400)}.portal-inline-edit-btn-cancel:hover{color:var(--red-400);background:rgba(248,113,113,.1)}.portal-inline-edit-btn:disabled{opacity:.6;cursor:not-allowed}.portal-inline-edit-row{display:flex;align-items:center;gap:var(--space-3)}.portal-inline-edit-row .portal-inline-edit-input{flex:1 1;min-width:0}.portal-inline-edit-row-textarea{align-items:flex-start}.portal-inline-edit-row-textarea .portal-inline-edit-input{min-height:80px}.portal-inline-edit-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.portal-inline-edit-address-fields{display:flex;flex-direction:column;gap:var(--space-3)}.portal-inline-edit-address-fields .portal-inline-edit-actions{margin-top:var(--space-2)}.portal-inline-edit-address-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-3);gap:var(--space-3)}.portal-client-detail-id{margin:0;font-size:.875rem;color:var(--zinc-500)}.portal-client-address-block{font-style:normal;color:var(--zinc-300);font-size:.9375rem;line-height:1.6}.portal-client-address-block span{display:block}.portal-client-no-address{margin:0;font-size:.9375rem;color:var(--zinc-500);font-style:italic}.portal-new-project-page{width:100%;max-width:none}.portal-new-project-page .portal-card{max-width:none}.portal-new-project-card{padding:var(--space-6) var(--space-8)}.portal-new-project-form-grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-8);gap:var(--space-8)}@media (min-width:900px){.portal-new-project-form-grid{grid-template-columns:1fr 1fr;align-items:start}}.portal-new-project-form-main,.portal-new-project-form-tasks{min-width:0}.portal-new-project-task-row{display:grid;grid-template-columns:1fr auto auto auto;grid-gap:var(--space-3);gap:var(--space-3);align-items:center;margin-top:var(--space-3)}.portal-new-project-task-date{width:10.5rem}@media (max-width:640px){.portal-new-project-task-row{grid-template-columns:1fr}.portal-new-project-task-date{width:100%}}.portal-new-project-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:1.5rem}.portal-new-project-header h1{margin:0 0 .35rem;font-size:1.5rem;font-weight:700}.portal-new-project-client{margin:0;font-size:.875rem;color:var(--zinc-500)}.portal-new-project-close{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;flex-shrink:0;color:var(--zinc-400);border-radius:var(--radius-md);transition:color .2s,background .2s}.portal-new-project-close:hover{color:var(--zinc-100);background:var(--zinc-700)}.portal-new-project-footer{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.portal-new-project-submit{min-height:3rem;padding:var(--space-4) var(--space-8);font-size:var(--text-base);font-weight:var(--font-semibold);min-width:12rem}.portal-new-project-no-quotes{margin:0 0 1rem;color:var(--zinc-400);font-size:.9375rem}.portal-new-project-actions{display:flex;flex-wrap:wrap;gap:.75rem}.portal-project-detail,.portal-project-detail-page{width:100%;max-width:none}.portal-project-detail{display:flex;flex-direction:column;gap:var(--space-8)}.portal-project-detail-page-header{padding:var(--space-6) 0;border-bottom:1px solid var(--zinc-700)}.portal-project-detail-page-header-inner{max-width:none}.portal-project-detail-page-header .portal-inline-edit:last-of-type{margin-bottom:0}.portal-project-detail-section{width:100%}.portal-project-detail-section-title{margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-project-detail-invoices-removed{padding:var(--space-4);background:rgba(251,191,36,.12);border:1px solid var(--amber-500);border-radius:var(--radius-md)}.portal-project-detail-invoices-removed-text{margin:0;font-size:var(--text-sm);color:var(--zinc-200)}.portal-project-detail-invoices-section{margin-bottom:var(--space-6)}.portal-project-detail-invoices-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.portal-project-detail-invoice-link{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--zinc-800);color:var(--zinc-100);border-radius:var(--radius-md);text-decoration:none;font-size:.9375rem}.portal-project-detail-invoice-link:hover{background:var(--zinc-700)}.portal-project-detail-edit-description{margin-top:var(--space-4)}.portal-project-detail-name{margin:0 0 .5rem;font-size:1.5rem;font-weight:700;color:var(--zinc-100)}.portal-project-detail-description{margin:0 0 .5rem;font-size:.9375rem;color:var(--zinc-400);line-height:1.5}.portal-project-detail-quote{margin:0;font-size:.875rem;color:var(--zinc-500)}.portal-project-detail-progress-section .portal-project-detail-progress{margin-bottom:0}.portal-project-detail-progress-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--zinc-400)}.portal-project-timeline-section{margin:var(--space-6) 0;padding:var(--space-5);background:var(--zinc-800);border-radius:var(--radius-lg);border:1px solid var(--zinc-700)}.portal-project-timeline-dates{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-500)}.portal-project-timeline-wrapper{overflow-x:auto;overflow-y:visible;margin:0 calc(-1 * var(--space-2));padding:0 var(--space-2);border-radius:var(--radius-md)}.portal-project-timeline{display:grid;width:max-content;min-width:100%;grid-gap:1px;gap:1px;background:var(--zinc-700);border:1px solid var(--zinc-700);border-radius:var(--radius-md);padding:0}.portal-project-timeline-cell{min-width:0;background:var(--zinc-900);padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.portal-project-timeline-sticky-col{position:-webkit-sticky;position:sticky;left:0;z-index:2;box-shadow:2px 0 4px rgba(0,0,0,.15)}.portal-project-timeline-day-row.portal-project-timeline-sticky-col,.portal-project-timeline-month-row.portal-project-timeline-sticky-col{background:var(--zinc-800)}.portal-project-timeline-task-label.portal-project-timeline-sticky-col{background:var(--zinc-900)}.portal-project-timeline-day-row,.portal-project-timeline-month-row{background:var(--zinc-800)}.portal-project-timeline-month-header{font-weight:600;color:var(--zinc-300);text-align:center;font-size:var(--text-sm)}.portal-project-timeline-day-header{font-weight:var(--font-medium);color:var(--zinc-400);white-space:nowrap;text-align:center;font-size:var(--text-sm);min-width:32px;box-sizing:border-box}.portal-project-timeline-spacer{min-height:.75rem;background:var(--zinc-900);grid-column:1/-1}.portal-project-timeline-right-col{background:var(--zinc-900);min-width:0}.portal-project-timeline-header{background:var(--zinc-800)}.portal-project-timeline-task-label{min-width:200px;padding:var(--space-2) var(--space-3)}.portal-project-timeline-bar-wrap{padding:var(--space-1);min-width:0}.portal-project-timeline-bar{background:var(--emerald-600);color:var(--zinc-100);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:var(--font-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:2rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;cursor:-webkit-grab;cursor:grab;-webkit-user-select:none;-moz-user-select:none;user-select:none}.portal-project-timeline-bar:active{cursor:-webkit-grabbing;cursor:grabbing}.portal-project-timeline-bar--dragging{opacity:.85;box-shadow:0 2px 8px rgba(0,0,0,.3)}.portal-project-timeline-bar-label{min-width:0;overflow:hidden;text-overflow:ellipsis}.portal-project-timeline-bar-edit-btn{flex-shrink:0;padding:.2rem;color:inherit;background:rgba(255,255,255,.2);border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;align-items:center;justify-content:center}.portal-project-timeline-bar-edit-btn:hover{background:rgba(255,255,255,.3)}.portal-project-timeline-bar--done{background:var(--zinc-600);color:var(--zinc-400);text-decoration:line-through}.portal-project-timeline-today-line{grid-row:1/-1;background:var(--blue-500);width:2px;min-width:2px;max-width:2px;justify-self:center;pointer-events:none;z-index:1}.portal-project-timeline-edit-popover{margin-top:1rem;padding:1rem;background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-md)}.portal-project-detail-progress-value{font-weight:700;color:var(--emerald-400);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.portal-project-task-cards{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-4)}.portal-project-task-card{margin:0;padding:var(--space-4);background:var(--zinc-800);border:1px solid var(--zinc-700);border-radius:var(--radius-md);width:100%;box-sizing:border-box}.portal-project-task-card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap}.portal-project-task-card-checkbox-label{display:flex;align-items:center;gap:var(--space-3);cursor:pointer;flex:1 1;min-width:0}.portal-project-task-card-name{font-size:1.125rem;font-weight:600;color:var(--zinc-100)}.portal-project-task-card-name--done{color:var(--zinc-500);text-decoration:line-through}.portal-project-task-card-description{margin:var(--space-2) 0 0;padding:0;font-size:var(--text-sm);color:var(--zinc-400);line-height:1.5;white-space:pre-wrap}.portal-project-task-card-dates-row{margin:var(--space-2) 0 0;display:flex;flex-wrap:wrap;gap:var(--space-4);font-size:var(--text-sm);color:var(--zinc-500)}.portal-project-task-card-date-item{display:inline}.portal-project-task-card-actions{display:flex;align-items:center;gap:var(--space-2)}.portal-project-task-card-action-btn{padding:.35rem .75rem;font-size:.875rem;color:var(--zinc-400);background:var(--zinc-700);border:1px solid var(--zinc-600);border-radius:var(--radius-sm);cursor:pointer}.portal-project-task-card-action-btn:hover{color:var(--zinc-200);border-color:var(--zinc-500)}.portal-project-task-card-remove{color:var(--red-400);border-color:var(--zinc-700)}.portal-project-task-card-remove:hover{color:var(--red-300);background:rgba(239,68,68,.1)}.portal-project-task-card-form{display:flex;flex-direction:column;gap:var(--space-3)}.portal-project-task-card-input{font-size:1rem}.portal-project-task-card-input,.portal-project-task-card-textarea{width:100%;padding:.5rem .75rem;background:var(--zinc-900);border:1px solid var(--zinc-600);border-radius:var(--radius-sm);color:var(--zinc-100);box-sizing:border-box}.portal-project-task-card-textarea{font-size:.9375rem;resize:vertical;min-height:4rem}.portal-project-task-card-dates{display:flex;flex-wrap:wrap;gap:var(--space-4)}.portal-project-task-card-date-label{display:flex;flex-direction:column;gap:.25rem;font-size:var(--text-sm);color:var(--zinc-400)}.portal-project-task-card-date{padding:.35rem .5rem;font-size:.875rem;background:var(--zinc-900);border:1px solid var(--zinc-600);border-radius:var(--radius-sm);color:var(--zinc-100)}.portal-project-task-card-form-actions{display:flex;gap:var(--space-2)}.portal-project-add-task{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.portal-project-add-task-form{padding:var(--space-4);background:var(--zinc-800);border:1px dashed var(--zinc-600);border-radius:var(--radius-md)}.portal-project-add-task-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:.5rem 1rem;font-size:1rem}.portal-project-detail-tasks-title{margin:0 0 1rem;font-size:1rem;font-weight:600;color:var(--zinc-100)}.portal-project-detail-task-list{list-style:none;margin:0;padding:0}.portal-project-detail-task-item{margin:0;padding:.5rem 0;border-bottom:1px solid var(--zinc-800)}.portal-project-detail-task-item:last-child{border-bottom:none}.portal-project-detail-task-label{display:flex;align-items:center;gap:.75rem;cursor:pointer;font-size:.9375rem}.portal-project-detail-task-checkbox{width:1.25rem;height:1.25rem;accent-color:var(--emerald-500);cursor:pointer}.portal-project-detail-task-text{color:var(--zinc-200)}.portal-project-detail-task-text--done{color:var(--zinc-500);text-decoration:line-through}.portal-project-detail-header-actions{margin-top:1.25rem;display:flex;flex-wrap:wrap;align-items:center;gap:1rem}.portal-project-detail-header-actions-group{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.5rem}.portal-project-detail-complete-badge{font-weight:600;color:var(--emerald-400)}.btn-project-complete{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;color:var(--zinc-900);background:var(--emerald-500);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-project-complete:hover:not(:disabled){background:var(--emerald-400)}.btn-project-complete:disabled{opacity:.7;cursor:not-allowed}.btn-project-incomplete{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9375rem;color:var(--zinc-300);background:var(--zinc-700);border:1px solid var(--zinc-600);border-radius:var(--radius-md);cursor:pointer}.btn-project-incomplete:hover:not(:disabled){background:var(--zinc-600);color:var(--zinc-200)}.btn-project-archive{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;color:var(--zinc-900);background:var(--orange-500);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-project-archive:hover:not(:disabled){background:var(--orange-400)}.btn-project-archive:disabled{opacity:.7;cursor:not-allowed}.btn-project-delete{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;color:var(--zinc-100);background:var(--red-500);border:none;border-radius:var(--radius-md);cursor:pointer}.btn-project-delete:hover:not(:disabled){background:var(--red-400)}.btn-project-delete:disabled{opacity:.7;cursor:not-allowed}.btn-project-invoice{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;color:var(--zinc-100);background:var(--blue-600);border:none;border-radius:var(--radius-md);cursor:pointer;text-decoration:none}.btn-project-invoice:hover{background:var(--blue-500)}.portal-project-detail-progress-note{margin:0 0 .5rem;font-size:var(--text-sm);color:var(--zinc-500)}.portal-project-detail-error{margin:0 0 1rem;padding:.5rem .75rem;background:rgba(239,68,68,.15);color:var(--red-400);border-radius:var(--radius-sm);font-size:var(--text-sm)}.portal-project-detail-task-item{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.portal-project-detail-task-label{flex:1 1;min-width:0}.portal-project-detail-task-actions{display:flex;align-items:center;gap:.5rem}.portal-project-detail-task-action-btn{padding:.25rem .5rem;font-size:.8125rem;color:var(--zinc-400);background:transparent;border:1px solid var(--zinc-600);border-radius:var(--radius-sm);cursor:pointer}.portal-project-detail-task-action-btn:hover{color:var(--zinc-200);border-color:var(--zinc-500)}.portal-project-detail-task-remove{padding:.25rem;color:var(--red-400);border-color:var(--zinc-700)}.portal-project-detail-task-remove:hover{color:var(--red-300);background:rgba(239,68,68,.1)}.portal-project-detail-task-edit-form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;width:100%}.portal-project-detail-task-edit-input{min-width:12rem;font-size:.9375rem}.portal-project-detail-task-edit-date,.portal-project-detail-task-edit-input{padding:.375rem .5rem;background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-sm);color:var(--zinc-100)}.portal-project-detail-task-edit-date{font-size:.875rem}.portal-project-detail-add-task{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--zinc-800)}.portal-project-detail-add-task-btn{display:inline-flex;align-items:center;gap:.5rem}.portal-client-form-page{width:100%;max-width:none}.portal-client-form-page .portal-quote-card{max-width:none}.portal-client-form-page-header{margin-bottom:1.5rem}.portal-client-form-page-header h1{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,2rem);font-weight:700}.portal-client-form-page-header p{margin:0;font-size:.9375rem;color:var(--zinc-400)}.portal-client-form .portal-quote-card{margin-bottom:0}.portal-client-form-card{padding:1.5rem 1.75rem}.portal-client-address-fields{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}.portal-client-field-full{grid-column:1/-1}@media (max-width:640px){.portal-client-address-fields{grid-template-columns:1fr}}.portal-client-form-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-4)}.portal-client-form-footer .btn-secondary{width:auto}.portal-client-form-footer .portal-quote-submit{width:auto;min-width:10rem}.portal-quote-page{width:100%;max-width:none;margin:0;padding:0}.portal-quote-page .portal-quote-card{max-width:none}.portal-quote-page-header{margin-bottom:1.5rem;text-align:center}.portal-quote-page-header h1{margin:0 0 .5rem;font-size:clamp(1.5rem,4vw,2rem);font-weight:700}.portal-quote-page-header p{margin:0;font-size:.9375rem;color:var(--zinc-400)}.portal-quote-form{display:flex;flex-direction:column;gap:1.5rem}.portal-quote-form-error{padding:.75rem 1rem;background:rgba(248,113,113,.1);border:1px solid rgba(248,113,113,.3);border-radius:.5rem}.portal-quote-page--redesign .portal-quote-form-card{padding:1.75rem 2rem}.portal-quote-page--redesign .portal-quote-form-card .portal-quote-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:2rem 3rem;gap:2rem 3rem;align-items:start}@media (max-width:960px){.portal-quote-page--redesign .portal-quote-form-card .portal-quote-grid{grid-template-columns:1fr;gap:0 0}}.portal-quote-page--redesign .portal-quote-column{display:flex;flex-direction:column;gap:0}.portal-quote-page--redesign .portal-quote-column .portal-quote-section{padding:1rem 0;margin:0;border-bottom:1px solid var(--zinc-700);border-radius:0;background:transparent;box-shadow:none}.portal-quote-page--redesign .portal-quote-column .portal-quote-section:last-child{border-bottom:none;padding-bottom:0}.portal-quote-page--redesign .portal-quote-section-title{min-height:1.75rem;margin-bottom:.5rem}.portal-quote-page--redesign .portal-quote-field,.portal-quote-page--redesign .portal-quote-section .portal-quote-field:last-child,.portal-quote-page--redesign .portal-quote-section .portal-quote-recipients,.portal-quote-page--redesign .portal-quote-section .portal-quote-signatories{margin-bottom:0}.portal-quote-type-info{margin-top:.75rem;padding:1rem 1.25rem;background:var(--zinc-800);border-radius:.5rem}.portal-quote-type-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:.25rem 1.5rem;gap:.25rem 1.5rem;margin:0 0 1rem;font-size:.875rem}.portal-quote-type-dl dt{color:var(--zinc-500);font-weight:500}.portal-quote-type-dl dd{margin:0;color:var(--zinc-200)}.portal-quote-inclusions{margin-top:.75rem;padding:.75rem 1rem;background:var(--zinc-800);border-radius:.5rem}.portal-quote-inclusions-label{font-size:.8125rem;font-weight:600;color:var(--zinc-400)}.portal-quote-inclusions-text{margin:.25rem 0 0;font-size:.875rem;color:var(--zinc-300);line-height:1.5}.portal-quote-total-discount-note{display:block;font-size:.8125rem;color:var(--zinc-500);margin-top:.25rem}.portal-quote-feature-block{margin-bottom:1rem;padding:.75rem;background:var(--zinc-800);border-radius:.5rem}.portal-quote-feature-block .portal-quote-feature-row{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.portal-quote-feature-desc{margin-top:0;font-size:.875rem;min-height:2.5rem}.portal-quote-field-hint{display:block;margin-top:.25rem;font-size:.8125rem;color:var(--zinc-500)}.portal-quote-checkbox-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;font-size:.9375rem;color:var(--zinc-200)}.portal-quote-checkbox-label input{width:1.125rem;height:1.125rem;accent-color:var(--emerald-500)}.portal-quote-bottom-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:1.5rem;width:100%;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--zinc-700)}.portal-quote-bottom-row .portal-quote-total-box{display:inline-flex;align-items:baseline;gap:.75rem;padding:1rem 1.25rem;background:var(--zinc-800);border:1px solid var(--emerald-500);border-radius:.5rem}.portal-quote-bottom-row .portal-quote-total-label{font-size:1rem;font-weight:600;color:var(--zinc-300)}.portal-quote-bottom-row .portal-quote-total-value{font-size:1.5rem;font-weight:700;color:var(--emerald-400)}.portal-quote-bottom-row .portal-quote-discount-field{margin-bottom:0;min-width:8rem}.portal-quote-bottom-row .portal-quote-discount-field label{display:block;margin-bottom:.375rem;font-size:.875rem;color:var(--zinc-400)}.portal-quote-bottom-row .portal-quote-discount-field .portal-quote-input{width:100%;max-width:7rem}.portal-quote-bottom-row .portal-quote-submit{margin-left:auto}@media (max-width:640px){.portal-quote-bottom-row{flex-direction:column;align-items:stretch}.portal-quote-bottom-row .portal-quote-submit{margin-left:0}}.portal-quote-card{background:linear-gradient(135deg,rgba(39,39,42,.95),rgba(24,24,27,.98));border:1px solid var(--zinc-700);border-radius:.75rem;padding:1.5rem 1.75rem;box-shadow:0 4px 6px -1px rgba(0,0,0,.3)}.portal-quote-section{margin-bottom:1.75rem;padding-bottom:1.5rem;border-bottom:1px solid var(--zinc-700)}.portal-quote-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.portal-quote-section-title{display:flex;align-items:center;gap:var(--space-3);margin:0 0 var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-quote-section-icon{flex-shrink:0;color:var(--emerald-400)}.portal-quote-section-title-accent{font-size:var(--text-xs);font-weight:var(--font-bold);color:var(--emerald-400);letter-spacing:.05em}.portal-quote-section-desc{margin:0 0 1rem;font-size:.8125rem;color:var(--zinc-500);line-height:1.5}.portal-quote-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}@media (max-width:640px){.portal-quote-row{grid-template-columns:1fr}}.portal-quote-content-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:1rem;gap:1rem}@media (max-width:768px){.portal-quote-content-grid{grid-template-columns:1fr}}.portal-quote-field{margin-bottom:1rem}.portal-quote-field:last-child{margin-bottom:0}.portal-quote-field label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-400);letter-spacing:.02em}.portal-form-label-with-icon{display:inline-flex!important;align-items:center;gap:var(--space-2)}.portal-form-label-with-icon svg{flex-shrink:0;color:var(--emerald-400)}.portal-quote-input{width:100%;padding:.5rem .75rem;border:1px solid var(--zinc-700);border-radius:.5rem;background:var(--zinc-800);color:var(--zinc-100);font-size:.9375rem;transition:border-color .2s}.portal-quote-input:focus{outline:none;border-color:var(--emerald-500)}.portal-quote-summary{margin:.25rem 0 0;font-size:.75rem;color:var(--zinc-500)}.portal-quote-breakdown{background:var(--zinc-800);border:1px solid var(--zinc-700);border-radius:.5rem;padding:1rem 1.25rem;font-size:.9375rem;line-height:1.5}.portal-quote-breakdown-row{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;padding:.25rem 0}.portal-quote-breakdown-desc{flex:1 1;color:var(--zinc-200)}.portal-quote-breakdown-amount{flex-shrink:0;color:var(--zinc-100);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.portal-quote-breakdown-total{margin-top:.5rem;padding-top:.75rem;border-top:1px solid var(--zinc-600);font-weight:600;font-size:1rem}.portal-quote-breakdown-total .portal-quote-breakdown-amount{font-weight:700;color:var(--emerald-400)}.portal-quote-textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--zinc-700);border-radius:.5rem;background:var(--zinc-800);color:var(--zinc-100);font-size:.9375rem;font-family:inherit;resize:vertical;min-height:4rem;transition:border-color .2s}.portal-quote-textarea:focus{outline:none;border-color:var(--emerald-500)}.portal-quote-features-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem}.portal-quote-add-feature{padding:.35rem .75rem;font-size:.8125rem;font-weight:500;color:var(--emerald-400);background:transparent;border:1px solid var(--emerald-500);border-radius:.375rem;cursor:pointer;transition:background .2s,color .2s}.portal-quote-add-feature:hover{background:var(--emerald-500);color:white}.portal-quote-signatories{display:flex;flex-direction:column;gap:var(--space-3)}.portal-quote-signatory-row{display:flex;gap:var(--space-3);align-items:center}.portal-quote-signatory-input{flex:1 1}.portal-quote-add-signatory{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:500;color:var(--emerald-400);background:transparent;border:1px solid var(--emerald-500);border-radius:var(--radius-md);cursor:pointer;transition:background .2s,color .2s}.portal-quote-add-signatory:hover{background:var(--emerald-500);color:white}.portal-quote-feature-row{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}.portal-quote-feature-label{flex:1 1}.portal-quote-feature-amount{width:5.5rem}.portal-quote-remove-feature{padding:.35rem .5rem;font-size:.75rem;color:var(--zinc-500);background:transparent;border:none;cursor:pointer}.portal-quote-remove-feature:hover:not(:disabled){color:var(--zinc-100)}.portal-quote-remove-feature:disabled{cursor:not-allowed;opacity:.5}.portal-quote-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:.75rem}.portal-quote-total-card{display:flex;align-items:baseline;gap:.75rem}.portal-quote-total-label{font-size:.875rem;font-weight:500;color:var(--zinc-400)}.portal-quote-total-value{font-size:1.5rem;font-weight:700;color:var(--emerald-400)}.portal-quote-submit{width:auto;min-width:10rem}.portal-quote-detail-page{width:100%;max-width:none}.portal-quote-detail-top{margin-bottom:var(--space-6)}.portal-quote-detail-top-right{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:var(--space-3)}.portal-quote-detail-top-link{color:var(--zinc-300);text-decoration:none;font-size:var(--text-sm)}.portal-quote-detail-top-link:hover{color:var(--zinc-100)}.portal-quote-detail-top-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);border:1px solid var(--zinc-600);background:var(--zinc-800);color:var(--zinc-200);cursor:pointer;transition:background .2s,color .2s,border-color .2s}.portal-quote-detail-top-btn:hover:not(:disabled){background:var(--zinc-700);color:var(--zinc-100)}.portal-quote-detail-top-btn-primary{background:var(--emerald-500);color:var(--zinc-950);border-color:var(--emerald-500)}.portal-quote-detail-top-btn-primary:hover:not(:disabled){background:var(--emerald-400);border-color:var(--emerald-400)}.portal-quote-detail-top-btn-danger{border-color:var(--red-600);color:var(--red-400)}.portal-quote-detail-top-btn-danger:hover:not(:disabled){background:var(--red-600);color:var(--zinc-100);border-color:var(--red-600)}.portal-quote-detail-body{display:flex;flex-direction:column;gap:0}.portal-quote-detail-row{display:grid;grid-template-columns:1fr;grid-gap:var(--space-6);gap:var(--space-6);align-items:start}@media (min-width:768px){.portal-quote-detail-row{grid-template-columns:1fr 1fr;gap:var(--space-10);column-gap:var(--space-12)}}.portal-quote-detail-col-left,.portal-quote-detail-col-right{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-4) 0}@media (min-width:768px){.portal-quote-detail-col-left{padding:var(--space-4) var(--space-6) var(--space-4) 0}.portal-quote-detail-col-right{padding:var(--space-4) 0 var(--space-4) var(--space-6)}}.portal-quote-detail-sep{margin:var(--space-8) 0;border:none;border-top:1px solid var(--zinc-700)}.portal-quote-detail-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.portal-quote-detail-main-title{margin:0;font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--zinc-100)}.portal-quote-detail-actions-col{flex-direction:column;width:100%;max-width:22rem}.portal-quote-detail-actions-col,.portal-quote-detail-actions-row{display:flex;align-items:stretch;gap:var(--space-3)}.portal-quote-detail-actions-row .portal-quote-detail-action-btn{flex:1 1;min-width:0;justify-content:center}.portal-quote-detail-actions-col .portal-quote-detail-action-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);min-height:2.5rem;font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);text-decoration:none;cursor:pointer;border:1px solid var(--zinc-600);background:var(--zinc-800);color:var(--zinc-200);transition:background .2s,color .2s,border-color .2s;white-space:nowrap;box-sizing:border-box}.portal-quote-detail-actions-col .portal-quote-detail-action-btn:hover{background:var(--zinc-700);color:var(--zinc-100)}.portal-quote-detail-action-btn-full{width:100%}.portal-quote-detail-actions-col .portal-quote-detail-action-btn-primary{background:var(--emerald-500);color:var(--zinc-950);border-color:var(--emerald-500)}.portal-quote-detail-actions-col .portal-quote-detail-action-btn-primary:hover{background:var(--emerald-400);border-color:var(--emerald-400)}.portal-quote-detail-block{margin:0}.portal-quote-detail-block-title{margin:0 0 var(--space-2);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-quote-detail-block-value{margin:0 0 var(--space-3);font-size:var(--text-sm);color:var(--zinc-200)}.portal-quote-detail-info-field{margin-top:var(--space-4)}.portal-quote-detail-info-field .portal-quote-textarea{margin-bottom:0}.portal-quote-detail-info-text{margin-top:var(--space-4);margin-bottom:0}.portal-quote-detail-status{font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-1) var(--space-3);border-radius:var(--radius-md)}.portal-quote-detail-status-in-principle{background:var(--zinc-700);color:var(--zinc-300)}.portal-quote-detail-status-agreed{background:rgba(16,185,129,.2);color:var(--emerald-400)}.portal-quote-detail-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:center}.portal-quote-detail-action-btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border-radius:var(--radius-md);text-decoration:none;cursor:pointer;border:1px solid transparent;transition:background .2s,color .2s,border-color .2s;white-space:nowrap}.portal-quote-detail-action-btn.btn-primary{background:var(--emerald-500);color:var(--zinc-950);border-color:var(--emerald-500)}.portal-quote-detail-action-btn.btn-primary:hover:not(:disabled){background:var(--emerald-400);border-color:var(--emerald-400)}.portal-quote-detail-action-btn.btn-secondary{background:var(--zinc-800);color:var(--zinc-200);border-color:var(--zinc-600)}.portal-quote-detail-action-btn.btn-secondary:hover:not(:disabled){background:var(--zinc-700);color:var(--zinc-100)}.portal-quote-detail-action-btn--danger:hover:not(:disabled){background:var(--red-600);border-color:var(--red-600);color:var(--zinc-100)}.portal-quote-detail-btn{display:inline-flex;align-items:center;gap:var(--space-3)}.portal-quote-detail-btn-lg{padding:var(--space-5) var(--space-8);font-size:var(--text-lg);font-weight:var(--font-semibold);min-height:3.25rem;min-width:10rem}.portal-quote-detail-form{display:flex;flex-direction:column;gap:var(--space-8)}.portal-quote-detail-two-col{display:grid;grid-template-columns:1fr;grid-gap:var(--space-8);gap:var(--space-8)}@media (min-width:768px){.portal-quote-detail-two-col{grid-template-columns:1fr 1fr;align-items:start;gap:var(--space-10)}}.portal-quote-detail-col{min-width:0}.portal-quote-detail-grid{display:grid;grid-template-columns:1fr;grid-gap:var(--space-8);gap:var(--space-8)}@media (min-width:900px){.portal-quote-detail-grid{grid-template-columns:1fr minmax(320px,380px);align-items:start}}.portal-quote-detail-main,.portal-quote-detail-sidebar{min-width:0}@media (min-width:900px){.portal-quote-detail-sidebar{position:-webkit-sticky;position:sticky;top:var(--space-6)}}.portal-quote-detail-section{padding:var(--space-6) 0;border-bottom:1px solid var(--zinc-700)}.portal-quote-detail-section:last-of-type{border-bottom:none}.portal-quote-detail-section-title{margin:0 0 var(--space-4);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-quote-detail-section-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-3);margin-bottom:var(--space-4)}.portal-quote-detail-section-head .portal-quote-detail-section-title{margin:0}.portal-quote-detail-edit-trigger{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--emerald-400);background:transparent;border:1px solid var(--emerald-500);border-radius:var(--radius-md);cursor:pointer;transition:background .2s,color .2s}.portal-quote-detail-edit-trigger:hover{background:var(--emerald-500);color:var(--zinc-950)}.portal-quote-detail-fields{display:flex;flex-direction:column;gap:var(--space-5)}.portal-quote-detail-fields .portal-quote-field{margin-bottom:0}.portal-quote-detail-view{display:flex;flex-direction:column;gap:var(--space-5)}.portal-quote-detail-view-title{margin:0;font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--zinc-100)}.portal-quote-detail-view-block{margin:0;font-size:var(--text-base);line-height:1.65;color:var(--zinc-200)}.portal-quote-detail-view-block p{margin:0 0 var(--space-3)}.portal-quote-detail-view-block p:last-child{margin-bottom:0}.portal-quote-detail-view-pre{white-space:pre-wrap;margin:0;font-size:var(--text-sm);color:var(--zinc-200);line-height:1.55}.portal-quote-detail-view-block p.portal-quote-detail-view-pre{white-space:pre-wrap}.portal-quote-detail-view-block strong{color:var(--zinc-100);font-weight:var(--font-semibold)}.portal-quote-detail-signatory-list{margin:var(--space-2) 0 0;padding-left:var(--space-5)}.portal-quote-detail-signatory-list li{margin-bottom:var(--space-1)}.portal-quote-detail-client-name{margin:0 0 var(--space-1);font-weight:var(--font-medium);font-size:var(--text-base)}.portal-quote-detail-client-address{margin:0;font-size:var(--text-sm);color:var(--zinc-500);line-height:1.5}.portal-quote-detail-type-dl{display:grid;grid-template-columns:auto 1fr;grid-gap:var(--space-1) var(--space-6);gap:var(--space-1) var(--space-6);margin:0 0 var(--space-4);font-size:var(--text-sm)}.portal-quote-detail-type-dl dt{color:var(--zinc-500);font-weight:500}.portal-quote-detail-type-dl dd{margin:0;color:var(--zinc-200)}.portal-quote-detail-included-summary{margin:0;font-size:var(--text-sm);color:var(--zinc-400);line-height:1.55}.portal-quote-detail-view-empty{color:var(--zinc-500);font-style:italic;margin:0}.portal-quote-detail-tcs{font-size:var(--text-sm);max-height:12rem;overflow-y:auto}.portal-quote-detail-section--cost .portal-quote-breakdown-total{font-size:var(--text-lg);font-weight:var(--font-semibold);padding-top:var(--space-3);margin-top:var(--space-2);border-top:1px solid var(--zinc-700)}.portal-quote-detail-form-actions{margin-top:var(--space-4)}.portal-quote-modal-overlay{position:fixed;inset:0;z-index:50;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.portal-quote-modal{background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);padding:var(--space-8);max-width:28rem;width:100%}.portal-quote-modal h2{margin:0 0 var(--space-6);font-size:var(--text-lg)}.portal-quote-modal .portal-quote-field{margin-bottom:var(--space-4)}.portal-quote-sign-link{margin:var(--space-4) 0;padding:var(--space-4);background:var(--zinc-800);border-radius:var(--radius-md);font-size:var(--text-sm)}.portal-quote-sign-link a{color:var(--blue-400);word-break:break-all}.portal-quote-sign-note{margin:var(--space-2) 0 0;color:var(--zinc-500);font-size:.8125rem}.portal-quote-modal-actions{display:flex;gap:var(--space-3);margin-top:var(--space-6);justify-content:flex-end}.portal-quote-print{padding:var(--space-8);max-width:50rem;margin:0 auto}.portal-quote-print-no-print{margin-bottom:var(--space-6)}.portal-quote-print-back{color:var(--blue-400);text-decoration:none}.portal-quote-print-back:hover{text-decoration:underline}.portal-quote-print-hint{margin:var(--space-2) 0 0;font-size:var(--text-sm);color:var(--zinc-500)}.portal-quote-print-doc{background:var(--zinc-900);color:var(--zinc-100);padding:var(--space-8);border-radius:var(--radius-lg);border:1px solid var(--zinc-700)}.portal-quote-print-header{margin-bottom:var(--space-8);padding-bottom:var(--space-4);border-bottom:2px solid var(--zinc-700)}.portal-quote-print-brand{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-6);margin-bottom:var(--space-4)}.portal-quote-print-logo{font-size:1.5rem;font-weight:700;color:var(--zinc-200);margin:0}.portal-quote-print-logo-img{display:block;max-height:3rem;width:auto;object-fit:contain}.portal-quote-print-provider{margin:0}.portal-quote-print-provider-name{margin:0 0 var(--space-1);font-size:var(--text-base);font-weight:600;color:var(--zinc-100)}.portal-quote-print-provider-address{margin:0 0 var(--space-1);font-size:var(--text-sm);color:var(--zinc-400);line-height:1.4}.portal-quote-print-provider-website{margin:0;font-size:var(--text-sm)}.portal-quote-print-provider-website a{color:var(--blue-400);text-decoration:underline}.portal-quote-print-title{margin:0;font-size:1.5rem;font-weight:700;color:var(--zinc-100)}.portal-quote-print-sign-link{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.portal-quote-print-sign-link a{color:var(--blue-400);word-break:break-all}.portal-quote-print-to{margin-bottom:var(--space-6)}.portal-quote-print-section h2,.portal-quote-print-to h2{margin:0 0 var(--space-2);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--zinc-500)}.portal-quote-print-client-name{margin:0 0 var(--space-1);font-weight:600;color:var(--zinc-100)}.portal-quote-print-address{font-style:normal;font-size:var(--text-sm);color:var(--zinc-400);line-height:1.5}.portal-quote-print-address span{display:block}.portal-quote-print-section{margin-bottom:var(--space-6)}.portal-quote-print-text{margin:0;font-size:var(--text-sm);color:var(--zinc-300);line-height:1.6}.portal-quote-print-terms{white-space:pre-wrap}.portal-quote-print-breakdown{list-style:none;margin:0 0 var(--space-4);padding:0}.portal-quote-print-breakdown li{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--zinc-700);font-size:var(--text-sm)}.portal-quote-print-feature-desc{display:block;font-size:.875rem;font-weight:400;color:var(--zinc-400);margin-top:.25rem}.portal-quote-print-discount{color:var(--zinc-400)}.portal-quote-print-total{display:flex;justify-content:space-between;font-size:1.25rem;font-weight:700;padding:var(--space-4) 0;color:var(--zinc-100)}@media print{.portal-quote-print-no-print{display:none!important}.portal-quote-print{padding:0}.portal-quote-print-doc{box-shadow:none;border:none}}.portal-invoice-print-row{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--zinc-700);font-size:var(--text-sm);color:var(--zinc-300)}.portal-invoice-print-row.portal-invoice-print-meta{color:var(--zinc-500);font-size:.8125rem}.portal-invoice-payment{margin-top:var(--space-6);padding-top:var(--space-6);border-top:2px solid var(--zinc-700)}.portal-invoice-payment-methods{display:flex;flex-wrap:wrap;gap:var(--space-8)}.portal-invoice-payment-method{flex:1 1;min-width:200px}.portal-invoice-payment-method-title{margin:0 0 var(--space-2);font-size:1rem;font-weight:600;color:var(--zinc-100)}.portal-invoice-payment-qr{margin:var(--space-3) 0}.portal-invoice-payment-qr img{display:block;width:180px;height:180px;object-fit:contain}.portal-invoice-print-other-list{margin:var(--space-2) 0 0;padding-left:1.25rem;font-size:var(--text-sm);color:var(--zinc-300);line-height:1.6}.portal-start-invoicing-page{max-width:42rem}.portal-start-invoicing-card{padding:var(--space-8)}.portal-start-invoicing-title{margin:0 0 var(--space-2);font-size:1.5rem;font-weight:700;color:var(--zinc-100)}.portal-start-invoicing-intro{margin:0 0 var(--space-6);font-size:var(--text-sm);color:var(--zinc-400);line-height:1.5}.portal-start-invoicing-summary{margin-bottom:var(--space-6);padding:var(--space-4);background:var(--zinc-800);border-radius:var(--radius-md);border:1px solid var(--zinc-700)}.portal-start-invoicing-summary-row{display:flex;flex-direction:column;gap:.25rem;margin-bottom:var(--space-2)}.portal-start-invoicing-summary-row:last-child{margin-bottom:0}.portal-start-invoicing-summary-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--zinc-500)}.portal-start-invoicing-summary-value{font-size:var(--text-base);color:var(--zinc-200)}.portal-start-invoicing-desc{white-space:pre-wrap}.portal-start-invoicing-form{margin-top:var(--space-4)}.portal-start-invoicing-section-title{margin:0 0 var(--space-2);font-size:1.125rem;font-weight:600;color:var(--zinc-100)}.portal-start-invoicing-hint{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--zinc-500)}.portal-start-invoicing-hint-error{color:var(--red-400)}.portal-start-invoicing-lines{list-style:none;margin:0 0 var(--space-4);padding:0}.portal-start-invoicing-line{display:grid;grid-template-columns:2rem 8rem 1fr 6rem 5rem 2rem;align-items:center;grid-gap:var(--space-3);gap:var(--space-3);margin-bottom:var(--space-2)}.portal-start-invoicing-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.portal-start-invoicing-ref{min-width:0}.portal-start-invoicing-line-num{font-weight:600;color:var(--zinc-500);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.portal-start-invoicing-input{padding:.5rem .6rem;font-size:.9375rem;background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-sm);color:var(--zinc-100)}.portal-start-invoicing-date{min-width:0}.portal-start-invoicing-pct{text-align:right}.portal-start-invoicing-line-amount{font-size:.9375rem;font-weight:600;color:var(--emerald-400);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.portal-start-invoicing-remove{padding:.35rem;color:var(--zinc-500);background:transparent;border:1px solid var(--zinc-600);border-radius:var(--radius-sm);cursor:pointer}.portal-start-invoicing-remove:hover:not(:disabled){color:var(--red-400);border-color:var(--zinc-500)}.portal-start-invoicing-remove:disabled{opacity:.4;cursor:not-allowed}.portal-start-invoicing-add{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:var(--space-4)}.portal-start-invoicing-error{margin:0 0 var(--space-4);padding:.5rem .75rem;background:rgba(239,68,68,.15);color:var(--red-400);border-radius:var(--radius-sm);font-size:var(--text-sm)}.portal-start-invoicing-actions{margin-top:var(--space-6);padding-top:var(--space-4);border-top:1px solid var(--zinc-700);display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.portal-start-invoicing-submit:disabled{opacity:.5;cursor:not-allowed}.portal-start-invoicing-submit-hint{font-size:var(--text-sm);color:var(--zinc-500)}.quote-sign-page{min-height:100vh;padding:var(--space-8);background:var(--zinc-950);color:var(--zinc-100);text-align:left}.quote-sign{max-width:42rem;margin:0 auto;text-align:left}.quote-sign-doc{background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);padding:var(--space-8);margin-bottom:var(--space-8);text-align:left}.quote-sign-header{margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:1px solid var(--zinc-700)}.quote-sign-brand{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--space-6);margin-bottom:var(--space-4)}.quote-sign-logo{font-size:1.25rem;font-weight:700;color:var(--zinc-400);margin:0}.quote-sign-logo-img{display:block;max-height:3rem;width:auto;object-fit:contain}.quote-sign-provider{margin:0}.quote-sign-provider-name{margin:0 0 var(--space-1);font-size:var(--text-base);font-weight:600;color:var(--zinc-200)}.quote-sign-provider-address{margin:0 0 var(--space-1);font-size:var(--text-sm);color:var(--zinc-500);line-height:1.4}.quote-sign-provider-website{margin:0;font-size:var(--text-sm)}.quote-sign-provider-website a{color:var(--emerald-400);text-decoration:underline}.quote-sign-header h1,.quote-sign-title{margin:0;font-size:var(--text-xl);font-weight:700}.quote-sign-accepted-wrap .quote-sign-doc.quote-sign-accepted{text-align:center;padding:var(--space-12)}.quote-sign-accepted h1{font-size:var(--text-xl)}.quote-sign-accepted p{margin:0 0 var(--space-4)}.quote-sign-view-signed-btn{display:inline-flex;align-items:center;padding:var(--space-3) var(--space-6);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--zinc-950);background:var(--emerald-400);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .2s,transform .1s}.quote-sign-view-signed-btn:hover{background:var(--emerald-300)}.quote-sign-signed-section{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--zinc-700)}.quote-sign-signed-section .quote-sign-text{color:var(--zinc-200)}.quote-sign-agree{margin-top:var(--space-4)}.quote-sign-checkbox-label{display:flex;align-items:flex-start;gap:var(--space-3);cursor:pointer;font-weight:var(--font-medium);color:var(--zinc-200)}.quote-sign-checkbox{margin-top:.25rem;width:1.25rem;height:1.25rem;accent-color:var(--emerald-500)}.quote-sign-section,.quote-sign-to{margin-bottom:var(--space-6)}.quote-sign-section h2,.quote-sign-to h2{margin:0 0 var(--space-2);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--zinc-500)}.quote-sign-client-name{margin:0 0 var(--space-1);font-weight:600}.quote-sign-address{font-style:normal;font-size:var(--text-sm);color:var(--zinc-400);line-height:1.5}.quote-sign-address span{display:block}.quote-sign-text{margin:0;font-size:var(--text-sm);color:var(--zinc-300);line-height:1.6}.quote-sign-terms{white-space:pre-wrap}.quote-sign-breakdown{list-style:none;margin:0 0 var(--space-4);padding:0}.quote-sign-breakdown li{display:flex;justify-content:space-between;padding:var(--space-2) 0;border-bottom:1px solid var(--zinc-700);font-size:var(--text-sm)}.quote-sign-feature-desc{display:block;font-size:.875rem;font-weight:400;color:var(--zinc-400);margin-top:.25rem}.quote-sign-discount{color:var(--zinc-400)}.quote-sign-total{display:flex;justify-content:space-between;font-size:1.25rem;font-weight:700;padding:var(--space-4) 0;color:var(--zinc-100)}.quote-sign-form{background:var(--zinc-900);border:1px solid var(--zinc-700);border-radius:var(--radius-lg);padding:var(--space-8);text-align:left}.quote-sign-form h2{margin:0 0 var(--space-4);font-size:var(--text-lg)}.quote-sign-field{margin-bottom:var(--space-4)}.quote-sign-field label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--zinc-300)}.quote-sign-input{width:100%;padding:var(--space-3) var(--space-4);background:var(--zinc-800);border:1px solid var(--zinc-600);border-radius:var(--radius-md);color:var(--zinc-100);font-size:var(--text-base)}.quote-sign-input:focus{outline:none;border-color:var(--blue-500)}.quote-sign-error{margin:0 0 var(--space-4);font-size:var(--text-sm);color:var(--red-400)}.quote-sign-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);font-size:var(--text-base);font-weight:var(--font-semibold)}.quote-sign-accepted{max-width:28rem;margin:0 auto;padding:var(--space-12);text-align:center}.quote-sign-accepted h1{margin:0 0 var(--space-4);font-size:1.5rem;font-weight:700;color:var(--emerald-400)}.quote-sign-accepted p{margin:0;color:var(--zinc-400)}