:root{--color-primary: #C4AFA2;--color-primary-dark: #A8978A;--color-primary-light:#DDD3CC;--color-accent: #4A3728;--color-accent-mid: #7A5C4A;--color-accent-light: #B08070;--color-bg: #F7F4F1;--color-surface: #FFFFFF;--color-surface-2: #FBF8F6;--color-border: #E2D8D0;--color-border-dark: #C8B9AF;--color-text: #2C2420;--color-text-muted: #8A7B74;--color-success: #4A7A5E;--color-success-bg: #EAF4EE;--color-warning: #B8742A;--color-warning-bg: #FDF3E3;--color-danger: #A03535;--color-danger-bg: #FAEAEA;--color-info: #2E6090;--color-info-bg: #E6F0F9;--font-display: "Cormorant Garamond", Georgia, serif;--font-body: "Inter", system-ui, sans-serif;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(44,36,32,.08);--shadow-md: 0 4px 12px rgba(44,36,32,.1);--shadow-lg: 0 8px 24px rgba(44,36,32,.12)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;line-height:1.2;color:var(--color-accent)}h1{font-size:2.2rem}h2{font-size:1.7rem}h3{font-size:1.35rem}h4{font-size:1.1rem}p{color:var(--color-text)}a{color:var(--color-accent-mid);text-decoration:none}a:hover{color:var(--color-accent);text-decoration:underline}.app-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--color-accent);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow-y:auto}.sidebar-brand{padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.12)}.sidebar-brand-name{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:var(--color-primary-light);line-height:1.2}.sidebar-brand-sub{font-size:.72rem;color:#ffffff8c;letter-spacing:.08em;text-transform:uppercase;margin-top:2px}.sidebar-nav{flex:1;padding:16px 0}.sidebar-section-label{font-size:.65rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#fff6;padding:8px 20px 4px;margin-top:8px}.sidebar-link{display:flex;align-items:center;gap:10px;padding:10px 20px;color:#ffffffc7;font-size:.875rem;font-weight:400;cursor:pointer;border:none;background:none;width:100%;text-align:left;text-decoration:none;transition:background .15s,color .15s;border-radius:0}.sidebar-link:hover,.sidebar-link.active{background:#ffffff1a;color:#fff;text-decoration:none}.sidebar-link.active{background:#c4afa240;color:var(--color-primary-light);font-weight:500}.sidebar-link .icon{font-size:1rem;width:20px;text-align:center}.sidebar-sublink{padding-left:36px;font-size:.82rem;opacity:.85}.sidebar-sublink .icon{font-size:.85rem;width:16px}.sidebar-footer{padding:16px 20px;border-top:1px solid rgba(255,255,255,.12);font-size:.8rem;color:#ffffff80}.sidebar-user{font-weight:500;color:#fffc;margin-bottom:4px;font-size:.85rem}.main-content{flex:1;margin-left:240px;min-height:100vh;display:flex;flex-direction:column}.topbar{background:#e4d3ca;border-bottom:1px solid var(--color-primary-dark);padding:0 32px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50}.topbar-title{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--color-accent)}.topbar-actions{display:flex;align-items:center;gap:12px}.page-body{flex:1;padding:32px;max-width:1200px;width:100%}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:20px 24px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-body{padding:24px}.card-footer{padding:16px 24px;border-top:1px solid var(--color-border);background:var(--color-surface-2);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s;white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-mid);color:#fff}.btn-secondary{background:var(--color-primary);color:var(--color-accent)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-outline{background:transparent;color:var(--color-accent);border:1px solid var(--color-border-dark)}.btn-outline:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-accent-mid)}.btn-ghost{background:transparent;color:var(--color-text-muted)}.btn-ghost:hover:not(:disabled){background:var(--color-bg);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#8a2a2a}.btn-sm{padding:6px 12px;font-size:.8rem}.btn-lg{padding:12px 24px;font-size:1rem}.btn-icon{padding:8px;border-radius:var(--radius-md)}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.82rem;font-weight:500;color:var(--color-accent)}.form-required{color:var(--color-danger);margin-left:2px}.form-control{width:100%;padding:9px 12px;border:1px solid var(--color-border-dark);border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;color:var(--color-text);background:var(--color-surface);transition:border-color .15s,box-shadow .15s;outline:none}.form-control:focus{border-color:var(--color-accent-mid);box-shadow:0 0 0 3px #7a5c4a1f}.form-control::placeholder{color:var(--color-text-muted)}textarea.form-control{resize:vertical;min-height:80px}select.form-control{cursor:pointer}.form-grid{display:grid;gap:16px}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.form-hint{font-size:.78rem;color:var(--color-text-muted)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-danger{background:var(--color-danger-bg);color:var(--color-danger)}.badge-info{background:var(--color-info-bg);color:var(--color-info)}.badge-neutral{background:var(--color-border);color:var(--color-text-muted)}.badge-primary{background:var(--color-primary-light);color:var(--color-accent)}.tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:24px}.tab-btn{padding:10px 20px;background:none;border:none;font-family:var(--font-body);font-size:.875rem;font-weight:500;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;display:flex;align-items:center;gap:6px}.tab-btn:hover{color:var(--color-accent)}.tab-btn.active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.875rem}thead tr{background:var(--color-surface-2);border-bottom:2px solid var(--color-border)}th{padding:11px 16px;text-align:left;font-size:.75rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-muted)}td{padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle}tbody tr:hover{background:var(--color-surface-2)}tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c242073;z-index:200;display:flex;align-items:center;justify-content:center;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-xl{max-width:900px}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--color-surface);z-index:1}.modal-title{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--color-accent)}.modal-body{padding:24px;flex:1}.modal-footer{padding:16px 24px;border-top:1px solid var(--color-border);display:flex;justify-content:flex-end;gap:10px;position:sticky;bottom:0;background:var(--color-surface)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-accent);background-image:linear-gradient(135deg,#4a3728,#2c1e16);padding:24px}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:420px;overflow:hidden}.auth-header{background:var(--color-primary);padding:32px 32px 24px;text-align:center}.auth-logo{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--color-accent);line-height:1.1}.auth-logo-sub{font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-accent-mid);margin-top:4px}.auth-body{padding:32px}.auth-form{display:flex;flex-direction:column;gap:18px}.auth-footer{text-align:center;margin-top:16px;font-size:.82rem;color:var(--color-text-muted)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.project-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;transition:box-shadow .18s,transform .18s;display:flex;flex-direction:column}.project-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-card-header{background:var(--color-primary);padding:18px 20px 14px;position:relative}.project-card-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;color:var(--color-accent)}.project-card-client{font-size:.8rem;color:var(--color-accent-mid);margin-top:2px}.project-card-body{padding:16px 20px;flex:1}.project-card-stats{display:flex;gap:16px;margin-top:12px}.stat{text-align:center}.stat-value{font-size:1.1rem;font-weight:700;color:var(--color-accent);font-family:var(--font-display)}.stat-label{font-size:.68rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.project-card-footer{padding:12px 20px;border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background:var(--color-surface-2)}.task-list{display:flex;flex-direction:column;gap:12px}.task-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px 18px;display:flex;align-items:flex-start;gap:14px;transition:box-shadow .15s}.task-card:hover{box-shadow:var(--shadow-sm)}.task-card-content{flex:1;min-width:0}.task-card-title{font-weight:600;font-size:.9rem;color:var(--color-text)}.task-card-meta{font-size:.78rem;color:var(--color-text-muted);margin-top:3px;display:flex;gap:12px;flex-wrap:wrap}.task-card-actions{display:flex;gap:6px;flex-shrink:0}.shopping-list{display:flex;flex-direction:column;gap:6px}.shopping-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:background .12s}.shopping-item.checked{background:var(--color-success-bg);border-color:#c5e0cf}.shopping-item.checked .item-name{text-decoration:line-through;color:var(--color-text-muted)}.shopping-checkbox{width:20px;height:20px;accent-color:var(--color-success);cursor:pointer;flex-shrink:0}.item-name{flex:1;font-size:.875rem;font-weight:500}.item-qty{font-size:.78rem;color:var(--color-text-muted);white-space:nowrap}.item-cost{font-size:.85rem;font-weight:600;color:var(--color-accent);white-space:nowrap}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}.photo-card{border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface-2);position:relative}.photo-card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}.photo-label{position:absolute;top:8px;left:8px;padding:3px 8px;border-radius:999px;font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.photo-label-before{background:var(--color-warning-bg);color:var(--color-warning)}.photo-label-after{background:var(--color-success-bg);color:var(--color-success)}.photo-upload-zone{border:2px dashed var(--color-border-dark);border-radius:var(--radius-lg);padding:32px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s}.photo-upload-zone:hover{border-color:var(--color-accent-mid);background:var(--color-surface-2)}.photo-upload-icon{font-size:2.5rem;margin-bottom:8px}.photo-upload-text{color:var(--color-text-muted);font-size:.875rem}.notif-dot{display:inline-block;width:8px;height:8px;background:var(--color-danger);border-radius:50%;position:absolute;top:6px;right:6px}.notif-list{display:flex;flex-direction:column;gap:0}.notif-item{padding:14px 20px;border-bottom:1px solid var(--color-border);display:flex;gap:12px;align-items:flex-start;background:var(--color-surface)}.notif-item.unread{background:var(--color-info-bg)}.notif-icon{font-size:1.1rem;flex-shrink:0;margin-top:1px}.notif-content{flex:1}.notif-msg{font-size:.875rem;font-weight:500}.notif-time{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.portal-header{background:var(--color-primary);padding:20px 32px;display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid var(--color-primary-dark)}.portal-brand{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-accent)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.flex-1{flex:1}.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.font-bold{font-weight:700}.font-display{font-family:var(--font-display)}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.p-4{padding:16px}.p-6{padding:24px}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.border{border:1px solid var(--color-border)}.bg-surface{background:var(--color-surface)}.bg-primary{background:var(--color-primary)}.divider{height:1px;background:var(--color-border);margin:20px 0}.empty-state{text-align:center;padding:48px 24px;color:var(--color-text-muted)}.empty-state-icon{font-size:2.5rem;margin-bottom:12px}.empty-state-title{font-family:var(--font-display);font-size:1.2rem;color:var(--color-accent);margin-bottom:6px}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:.875rem;display:flex;align-items:flex-start;gap:10px}.alert-danger{background:var(--color-danger-bg);color:var(--color-danger);border:1px solid #e8bfbf}.alert-success{background:var(--color-success-bg);color:var(--color-success);border:1px solid #b8d9c5}.alert-info{background:var(--color-info-bg);color:var(--color-info);border:1px solid #b8d3ec}.alert-warning{background:var(--color-warning-bg);color:var(--color-warning);border:1px solid #e8d0b0}.spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-accent-mid);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-page{display:flex;align-items:center;justify-content:center;min-height:200px;flex-direction:column;gap:16px;color:var(--color-text-muted)}.mobile-topbar{display:none;align-items:center;justify-content:space-between;padding:0 16px;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:50}.hamburger-btn{display:flex;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;width:40px}.hamburger-btn span{display:block;height:2px;background:var(--color-accent);border-radius:2px;transition:all .2s}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#2c242073;z-index:99}@media (max-width: 768px){.mobile-topbar{display:flex}.sidebar-overlay{display:block}.sidebar{transform:translate(-100%);transition:transform .25s ease;z-index:100}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.topbar{display:none}.page-body{padding:16px 14px}.form-grid-2,.form-grid-3,.projects-grid{grid-template-columns:1fr}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal-overlay{align-items:flex-end;padding:0}.modal{max-height:92vh}.tabs{overflow-x:auto;gap:0}.tab-btn{white-space:nowrap;padding:10px 14px;font-size:.8rem}.btn{font-size:.875rem}.form-control{font-size:16px}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}table{font-size:.8rem}th,td{padding:8px 10px}}
