*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}body{min-height:100dvh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}:root{--color-bg: #f7f7f8;--color-bg-elevated: #ffffff;--color-surface: #ffffff;--color-surface-hover: #f0f0f2;--color-border: #d8d9de;--color-border-subtle: #e8e9ed;--color-accent: #c9872e;--color-accent-dim: #a87025;--color-accent-glow: rgba(201, 135, 46, .14);--color-accent-soft: rgba(201, 135, 46, .07);--color-success: #3a9e5c;--color-success-dim: rgba(58, 158, 92, .1);--color-warning: #c9872e;--color-danger: #d14d40;--color-danger-dim: rgba(209, 77, 64, .1);--color-info: #3b7fc4;--color-info-dim: rgba(59, 127, 196, .1);--color-text: #1a1d23;--color-text-secondary: #50545e;--color-text-muted: #8b8e96;--color-text-inverse: #ffffff;--font-body: "DM Sans", system-ui, -apple-system, sans-serif;--font-display: "Instrument Serif", Georgia, serif;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--leading-tight: 1.2;--leading-normal: 1.5;--leading-loose: 1.7;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);--shadow-lg: 0 10px 30px rgba(0,0,0,.1), 0 4px 10px rgba(0,0,0,.06);--shadow-glow: 0 0 20px rgba(201, 135, 46, .12);--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .12s;--duration-normal: .2s;--duration-slow: .35s;--z-dropdown: 100;--z-modal: 200;--z-toast: 300;--max-width: 520px;--nav-height: 60px}body{font-family:var(--font-body);font-size:var(--text-base);color:var(--color-text);background:var(--color-bg);overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:256px 256px;z-index:9999}#app{max-width:var(--max-width);margin:0 auto;min-height:100dvh;position:relative;padding-bottom:calc(var(--nav-height) + var(--space-4))}.page-enter{animation:pageIn var(--duration-slow) var(--ease-out) forwards}@keyframes pageIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.stagger-item{opacity:0;animation:staggerIn var(--duration-slow) var(--ease-out) forwards}@keyframes staggerIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:var(--max-width);height:var(--nav-height);background:#ffffffd9;border-top:1px solid var(--color-border-subtle);box-shadow:0 -2px 10px #0000000a;display:flex;align-items:center;justify-content:space-around;z-index:var(--z-dropdown);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);padding-bottom:env(safe-area-inset-bottom,0)}.nav-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);transition:all var(--duration-normal) var(--ease-out);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--weight-medium);letter-spacing:.02em;position:relative}.nav-btn svg{width:22px;height:22px;transition:transform var(--duration-normal) var(--ease-spring)}.nav-btn.active{color:var(--color-accent)}.nav-btn.active svg{transform:scale(1.1)}.nav-btn:active{transform:scale(.92)}.nav-badge{position:absolute;top:2px;right:8px;background:var(--color-danger);color:#fff;font-size:10px;font-weight:var(--weight-bold);min-width:18px;height:18px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;line-height:1}.page-header{padding:var(--space-6) var(--space-5) var(--space-4)}.page-title{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:var(--weight-normal);line-height:var(--leading-tight);color:var(--color-text)}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.section-label{font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-2) var(--space-5)}.toast{position:fixed;top:var(--space-4);left:50%;transform:translate(-50%) translateY(-100px);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text);box-shadow:var(--shadow-lg);z-index:var(--z-toast);transition:transform var(--duration-slow) var(--ease-spring);max-width:calc(100% - var(--space-8));text-align:center}.toast.show{transform:translate(-50%) translateY(0)}.toast.toast-success{border-color:var(--color-success);background:linear-gradient(135deg,var(--color-surface),var(--color-success-dim))}.toast.toast-error{border-color:var(--color-danger);background:linear-gradient(135deg,var(--color-surface),var(--color-danger-dim))}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state svg{width:56px;height:56px;color:var(--color-text-muted);opacity:.4;margin-bottom:var(--space-4)}.empty-state p{color:var(--color-text-muted);font-size:var(--text-sm);max-width:240px;line-height:var(--leading-loose)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.home-page{padding:0 var(--space-5)}.home-greeting{padding:var(--space-8) 0 var(--space-6)}.home-greeting .greeting-label{font-size:var(--text-sm);color:var(--color-text-muted);font-weight:var(--weight-medium);letter-spacing:.03em;margin-bottom:var(--space-1)}.home-greeting .greeting-title{font-family:var(--font-display);font-size:var(--text-3xl);color:var(--color-text);line-height:var(--leading-tight)}.home-greeting .greeting-title span{color:var(--color-accent)}.home-date{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-accent-soft);border:1px solid rgba(232,168,73,.15);border-radius:var(--radius-full);padding:var(--space-2) var(--space-4);font-size:var(--text-sm);color:var(--color-accent);font-weight:var(--weight-medium);margin-top:var(--space-3)}.home-date svg{width:14px;height:14px}.tech-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);padding-bottom:var(--space-6)}.tech-card{position:relative;background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-4);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);transition:all var(--duration-normal) var(--ease-out);overflow:hidden}.tech-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--tech-color, var(--color-accent));opacity:.6;transition:opacity var(--duration-normal) var(--ease-out)}.tech-card:hover,.tech-card:focus-visible{border-color:var(--color-border);background:var(--color-surface);box-shadow:var(--shadow-sm)}.tech-card:hover:before{opacity:1}.tech-card:active{transform:scale(.96);transition-duration:var(--duration-fast)}.tech-avatar{width:48px;height:48px;border-radius:var(--radius-full);background:var(--tech-color, var(--color-accent));display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-bg);letter-spacing:-.02em;flex-shrink:0}.tech-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--color-text);text-align:center;line-height:var(--leading-tight)}.tech-role{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:-4px}.home-stats{display:flex;gap:var(--space-3);margin-bottom:var(--space-6)}.stat-card{flex:1;background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);padding:var(--space-4);text-align:center}.stat-value{font-size:var(--text-xl);font-weight:var(--weight-bold);color:var(--color-text);line-height:1;margin-bottom:var(--space-1)}.stat-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:var(--weight-medium)}@media(min-width:400px){.tech-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.tech-grid{grid-template-columns:repeat(3,1fr)}}.form-page{padding:0 var(--space-5)}.form-header{padding:var(--space-6) 0 var(--space-3);display:flex;align-items:center;gap:var(--space-3)}.form-back-btn{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid var(--color-border-subtle);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);transition:all var(--duration-normal) var(--ease-out);flex-shrink:0}.form-back-btn:active{transform:scale(.9)}.form-back-btn svg{width:18px;height:18px}.form-header-text{flex:1}.form-header-text h1{font-family:var(--font-display);font-size:var(--text-xl);color:var(--color-text);line-height:var(--leading-tight)}.form-header-text p{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px}.form-prefilled{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-accent-soft);border:1px solid rgba(232,168,73,.12);border-radius:var(--radius-md);margin-bottom:var(--space-5)}.prefilled-item{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-accent);font-weight:var(--weight-medium)}.prefilled-item svg{width:14px;height:14px;flex-shrink:0}.form-group{margin-bottom:var(--space-5)}.form-label{display:block;font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-2)}.form-label .required{color:var(--color-danger);margin-left:2px}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-base);transition:all var(--duration-normal) var(--ease-out);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-glow)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-dim)}.form-error-msg{font-size:var(--text-xs);color:var(--color-danger);margin-top:var(--space-1)}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%236e7179' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10)}.form-textarea{min-height:80px;resize:vertical}.search-dropdown{position:relative}.search-dropdown-list{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:var(--space-1);z-index:var(--z-dropdown);box-shadow:var(--shadow-lg);display:none}.search-dropdown-list.open{display:block}.search-dropdown-item{padding:var(--space-3) var(--space-4);font-size:var(--text-sm);cursor:pointer;transition:background var(--duration-fast);border-bottom:1px solid var(--color-border-subtle)}.search-dropdown-item:last-child{border-bottom:none}.search-dropdown-item:hover,.search-dropdown-item.highlighted{background:var(--color-surface-hover);color:var(--color-accent)}.search-dropdown-item .match{color:var(--color-accent);font-weight:var(--weight-semibold)}.form-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.toggle-group{display:flex;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden;flex-shrink:0}.toggle-option{padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-muted);transition:all var(--duration-normal) var(--ease-out);border:none;background:none;cursor:pointer;position:relative}.toggle-option.active{background:var(--color-accent);color:var(--color-text-inverse)}.toggle-option:active{transform:scale(.95)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-submit{width:100%;padding:var(--space-4) var(--space-6);background:var(--color-accent);color:var(--color-text-inverse);font-size:var(--text-base);font-weight:var(--weight-semibold);border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);margin-top:var(--space-4);margin-bottom:var(--space-8);position:relative;overflow:hidden}.form-submit:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.1) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.form-submit:hover:after{transform:translate(100%)}.form-submit:active{transform:scale(.98)}.form-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-divider{height:1px;background:var(--color-border-subtle);margin:var(--space-4) 0}.input-with-icon{position:relative}.input-with-icon svg{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--color-text-muted);pointer-events:none}.input-with-icon .form-input{padding-left:calc(var(--space-3) + 20px)}.hardware-list{display:flex;flex-direction:column;gap:var(--space-2)}.hardware-item{display:flex;gap:var(--space-2);align-items:center;animation:staggerIn var(--duration-normal) var(--ease-out) forwards}.hardware-item .form-input{flex:1;min-width:0}.hardware-item .hw-cost{width:90px;flex-shrink:0}.hardware-remove-btn{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:all var(--duration-fast) var(--ease-out);flex-shrink:0}.hardware-remove-btn:hover{color:var(--color-danger);background:var(--color-danger-dim)}.hardware-remove-btn:active{transform:scale(.9)}.hardware-remove-btn svg{width:14px;height:14px}.hardware-add-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px dashed var(--color-border);color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--duration-normal) var(--ease-out);margin-top:var(--space-2);width:100%}.hardware-add-btn:hover{color:var(--color-accent);border-color:var(--color-accent);background:var(--color-accent-soft)}.hardware-add-btn:active{transform:scale(.98)}.hardware-add-btn svg{width:16px;height:16px}.hardware-total{display:flex;justify-content:flex-end;align-items:center;gap:var(--space-2);padding:var(--space-2) 0;font-size:var(--text-sm);color:var(--color-text-secondary);font-weight:var(--weight-medium)}.hardware-total strong{color:var(--color-text);font-weight:var(--weight-bold)}.time-summary{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);margin-top:var(--space-2);box-shadow:var(--shadow-sm)}.time-summary-item{flex:1;text-align:center}.time-summary-label{font-size:10px;font-weight:var(--weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:2px}.time-summary-value{font-size:var(--text-lg);font-weight:var(--weight-bold);color:var(--color-text);line-height:1}.time-summary-value.accent{color:var(--color-accent)}.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-3)}@media(max-width:380px){.form-row-3{grid-template-columns:1fr 1fr}.form-row-3>:last-child{grid-column:1 / -1}}.billing-page{padding:0 var(--space-5)}.billing-header{padding:var(--space-6) 0 var(--space-3)}.billing-header h1{font-family:var(--font-display);font-size:var(--text-2xl);color:var(--color-text);line-height:var(--leading-tight)}.billing-header p{font-size:var(--text-sm);color:var(--color-text-muted);margin-top:var(--space-1)}.billing-filters{display:flex;gap:var(--space-2);margin-bottom:var(--space-5);overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-bottom:var(--space-1)}.billing-filters::-webkit-scrollbar{display:none}.filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--weight-medium);color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border-subtle);white-space:nowrap;transition:all var(--duration-normal) var(--ease-out);cursor:pointer}.filter-tab.active{background:var(--color-accent);color:var(--color-text-inverse);border-color:var(--color-accent)}.filter-tab:active{transform:scale(.95)}.filter-tab .count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:var(--radius-full);background:#ffffff26;font-size:11px;font-weight:var(--weight-bold);margin-left:var(--space-2);padding:0 5px}.filter-tab:not(.active) .count{background:var(--color-border);color:var(--color-text-secondary)}.billing-list{display:flex;flex-direction:column;gap:var(--space-3);padding-bottom:var(--space-6)}.billing-card{background:var(--color-surface);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--duration-normal) var(--ease-out);box-shadow:var(--shadow-sm)}.billing-card.approved{opacity:.65}.billing-card:hover{border-color:var(--color-border)}.billing-card-header{padding:var(--space-4) var(--space-4) var(--space-3);display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);cursor:pointer}.billing-card-info{flex:1;min-width:0}.billing-card-customer{font-size:var(--text-base);font-weight:var(--weight-semibold);color:var(--color-text);line-height:var(--leading-tight);margin-bottom:var(--space-1)}.billing-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-2) var(--space-4);font-size:var(--text-xs);color:var(--color-text-muted)}.billing-card-meta span{display:inline-flex;align-items:center;gap:4px}.billing-card-meta svg{width:12px;height:12px}.billing-card-badges{display:flex;gap:var(--space-2);flex-shrink:0}.badge{font-size:10px;font-weight:var(--weight-bold);text-transform:uppercase;letter-spacing:.05em;padding:3px 8px;border-radius:var(--radius-sm)}.badge-onsite{background:var(--color-info-dim);color:var(--color-info)}.badge-remote{background:#a882d61f;color:#a882d6}.badge-followup{background:var(--color-danger-dim);color:var(--color-danger)}.badge-approved{background:var(--color-success-dim);color:var(--color-success)}.badge-pending{background:#e8a8491f;color:var(--color-accent)}.billing-card-details{max-height:0;overflow:hidden;transition:max-height var(--duration-slow) var(--ease-out)}.billing-card-details.expanded{max-height:500px}.billing-card-details-inner{padding:0 var(--space-4) var(--space-4);border-top:1px solid var(--color-border-subtle)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3) var(--space-4);padding-top:var(--space-3)}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-item.full-width{grid-column:1 / -1}.detail-label{font-size:10px;font-weight:var(--weight-semibold);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.detail-value{font-size:var(--text-sm);color:var(--color-text);font-weight:var(--weight-medium)}.billing-card-actions{display:flex;gap:var(--space-2);padding:var(--space-3) var(--space-4) var(--space-4);border-top:1px solid var(--color-border-subtle)}.action-btn{flex:1;padding:var(--space-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-semibold);display:flex;align-items:center;justify-content:center;gap:var(--space-2);transition:all var(--duration-normal) var(--ease-out);border:1px solid transparent}.action-btn svg{width:16px;height:16px}.action-btn:active{transform:scale(.96)}.action-btn-approve{background:var(--color-success-dim);color:var(--color-success);border-color:#5cb87a33}.action-btn-approve:hover{background:var(--color-success);color:#fff}.action-btn-copy{background:var(--color-surface-hover);color:var(--color-text-secondary);border-color:var(--color-border-subtle)}.action-btn-copy:hover{color:var(--color-text);border-color:var(--color-border)}.action-btn-delete{background:var(--color-danger-dim);color:var(--color-danger);border-color:#e06b5e33;flex:0;padding:var(--space-3)}.action-btn-delete:hover{background:var(--color-danger);color:#fff}.expand-chevron{width:20px;height:20px;color:var(--color-text-muted);transition:transform var(--duration-normal) var(--ease-out);flex-shrink:0;margin-top:2px}.expand-chevron.rotated{transform:rotate(180deg)}
