:root{--color-primary:#0c141f;--color-accent:#0766f4;--color-danger:#e60f3d;--color-danger-hover:#c40d34;--color-bg:#f7f8fc;--color-surface:#fff;--color-border:#e8eaf0;--color-primary-active:#546573;--color-text:#1f2937;--color-text-muted:#6b7280;--color-text-light:#9ca3af;--shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 16px rgba(0,0,0,.1),0 2px 8px rgba(0,0,0,.06);--shadow-lg:0 12px 40px rgba(0,0,0,.15),0 4px 16px rgba(0,0,0,.08);--shadow-accent:0 0 20px rgba(7,102,244,.25);--text-sm:12px;--text-base:14px;--text-md:16px;--text-lg:20px;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--ease-spring:cubic-bezier(0.34,1.56,0.64,1);--ease-smooth:cubic-bezier(0.4,0,0.2,1);--dur-fast:150ms;--dur-normal:250ms;--dur-slow:380ms;--sidebar-width:220px;--status-success:#10b981;--status-success-bg:#ecfdf5;--status-warning:#f59e0b;--status-warning-bg:#fef3c7;--status-error:#ef4444;--status-error-bg:#fef2f2;--status-neutral:#6b7280;--status-neutral-bg:#f3f4f6}*,:after,:before{box-sizing:border-box;margin:0;padding:0}button,input,select,textarea{box-sizing:border-box;max-width:100%}html{font-size:16px;overflow-x:hidden;overscroll-behavior-x:none}.material-symbols-rounded,html{-webkit-font-smoothing:antialiased}.material-symbols-rounded{font-family:Material Symbols Rounded,sans-serif;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;vertical-align:middle;-webkit-user-select:none;-moz-user-select:none;user-select:none}.material-symbols-rounded.filled{font-variation-settings:"FILL" 1,"wght" 400,"GRAD" 0,"opsz" 24}.welcome-banner{flex-direction:row!important;align-items:center!important;justify-content:space-between!important}.welcome-banner .welcome-inner-wrap{flex:1 1;min-width:0}.welcome-banner .welcome-btn-row{flex-shrink:0}body{font-family:LINE Seed JP,Hiragino Kaku Gothic ProN,Meiryo,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;overflow-x:hidden;overscroll-behavior-x:none}.btn-gradient{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 22px;background:var(--color-danger);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:700;font-family:inherit;cursor:pointer;position:relative;overflow:hidden;transition:transform var(--dur-fast) var(--ease-spring),box-shadow var(--dur-normal) var(--ease-smooth);box-shadow:0 4px 15px rgba(7,102,244,.25)}.btn-gradient:after{content:"";position:absolute;inset:0;background:var(--color-danger-hover);opacity:0;transition:opacity var(--dur-normal) var(--ease-smooth)}.btn-gradient:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 8px 25px rgba(7,102,244,.25)}.btn-gradient:hover:after{opacity:1}.btn-gradient:active{transform:translateY(0) scale(.98)}.btn-gradient>*{position:relative;z-index:1}.form-input{width:100%;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:8px;font-size:14px;font-family:inherit;color:var(--color-text);background:var(--color-surface);transition:border-color var(--dur-fast) var(--ease-smooth),box-shadow var(--dur-fast) var(--ease-smooth);outline:none}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(7,102,244,.12)}.form-input::placeholder{color:var(--color-text-light)}textarea.form-input{resize:vertical;min-height:72px}select.form-input{cursor:pointer}@media (max-width:768px){input[type=date],input[type=datetime-local],input[type=month],input[type=time]{width:100%!important;max-width:100%!important;min-width:0!important;box-sizing:border-box!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;display:block!important}select,select.form-input{min-height:42px!important;height:auto!important;padding-top:9px!important;padding-bottom:9px!important;line-height:1.5!important;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")!important;background-repeat:no-repeat!important;background-position:right 10px center!important;background-size:16px!important;padding-right:32px!important}}.alert{padding:12px 16px;border-radius:10px;font-size:14px;font-weight:600;display:flex;align-items:center;gap:8px;animation:slideDown var(--dur-normal) var(--ease-spring)}.alert-success{background:var(--status-success-bg);color:var(--status-success);border:1px solid #a7f3d0}.alert-error{background:var(--status-error-bg);color:var(--status-error);border:1px solid #fecaca}@keyframes pageIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}@keyframes navItemIn{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}.page-enter{animation:pageIn var(--dur-slow) var(--ease-smooth) both}.modal-overlay{animation:overlayIn var(--dur-normal) var(--ease-smooth)}.modal-box{animation:scaleIn var(--dur-normal) var(--ease-spring)}.stagger-children>*{animation:pageIn var(--dur-slow) var(--ease-smooth) both}.stagger-children>:first-child{animation-delay:0ms}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:3px}a:visited,a:visited *,button:visited,button:visited *{color:inherit;border-color:inherit;background:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@media print{*,:after,:before{animation:none!important;transition:none!important}}@media (max-width:768px){body,html{overflow-x:hidden!important;width:100%!important;max-width:100vw!important;overscroll-behavior-x:none!important}*{max-width:100%}input:not([type=checkbox]):not([type=radio]),select,textarea{font-size:16px!important}a,button{touch-action:manipulation}.page-enter,[class*=page-]{padding:12px!important;box-sizing:border-box!important}:root{--sidebar-width:0px}.sp-col-1{grid-template-columns:1fr!important}.sp-stack{display:flex!important;flex-direction:column!important}.page-enter{padding:12px!important}.dashboard-kpi-grid{grid-template-columns:1fr 1fr!important}.welcome-banner{flex-direction:column!important;align-items:flex-start!important;padding:18px 16px!important}.welcome-greet{font-size:16px!important;word-break:break-word!important}.welcome-btn-row{gap:6px!important}.welcome-btn-v{min-width:96px!important;padding:10px 8px!important;flex:1 1!important}.estimates-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100vw}.estimates-table-wrap table,.invoices-table-wrap table{min-width:600px}.new-estimate-grid{grid-template-columns:1fr!important}.new-estimate-sticky{position:static!important}.new-estimate-form-grid{grid-template-columns:1fr!important}.print-bar-docs{flex-wrap:wrap!important;gap:6px!important}.customer-detail-grid,.customers-layout,.invoices-layout{grid-template-columns:1fr!important}.invoices-kpi-grid{grid-template-columns:1fr 1fr!important}.schedule-control-bar{flex-wrap:wrap!important;gap:6px!important}.schedule-period-label{font-size:13px!important;min-width:100px!important}.sales-kpi-grid{grid-template-columns:1fr 1fr!important}.sales-staff-charts{grid-template-columns:1fr!important}.modal-box{max-height:96vh!important;margin:0!important;border-radius:12px!important}.form-grid-2col,.modal-grid-2col{grid-template-columns:1fr!important}.app-main>div{max-width:100vw!important;overflow-x:hidden!important;box-sizing:border-box!important}.card-grid-2col{grid-template-columns:1fr!important}.btn-group{flex-wrap:wrap!important;gap:6px!important}.filter-bar-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}.photos-grid{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}.kpi-value{font-size:22px!important}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.kpi-grid-4{grid-template-columns:1fr 1fr!important}.inquiry-kpi-grid{grid-template-columns:repeat(3,1fr)!important}.page-header-wrap{flex-wrap:wrap!important;gap:10px!important}.page-header-wrap h1{font-size:17px!important}.filter-bar-wrap{flex-wrap:wrap!important;gap:6px!important}.settings-tab-wrap{display:grid!important;grid-template-columns:1fr 1fr!important;grid-gap:8px!important;gap:8px!important}a,button,input[type=checkbox],input[type=radio],select{min-height:40px}.form-input{min-height:44px!important;font-size:16px!important;max-width:100%!important;width:100%!important;box-sizing:border-box!important}.form-group,[class*=formGroup]{overflow:hidden;max-width:100%}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}}@media (min-width:769px) and (max-width:1024px){.welcome-banner{flex-direction:column!important;align-items:flex-start!important}.kpi-grid-4{grid-template-columns:1fr 1fr!important}.inquiry-kpi-grid{grid-template-columns:repeat(3,1fr)!important}.new-estimate-grid,.sales-staff-charts{grid-template-columns:1fr!important}.new-estimate-sticky{position:static!important}.welcome-btn-v{min-width:96px!important;padding:12px 14px!important}}@media (max-width:375px){.welcome-btn-v{min-width:80px!important;padding:10px 6px!important}.welcome-greet{font-size:14px!important}.dashboard-kpi-grid{grid-template-columns:1fr 1fr!important}}@media (max-width:768px){.estimates-filter-bar{flex-direction:column!important;align-items:stretch!important;gap:8px!important}.estimates-filter-bar .filter-select,.estimates-filter-bar select{width:100%!important;flex:1 1 auto!important}.estimates-filter-bar span:last-child{margin-left:0!important;text-align:right}}.announcement-row:hover{background:rgba(12,20,31,.08)}@media (max-width:768px){.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;flex-wrap:nowrap}.page-header h1{font-size:1.2rem;flex:1 1;min-width:0}.page-header a,.page-header button{white-space:nowrap;flex-shrink:0}.filter-grid{display:grid!important;grid-template-columns:1fr 1fr!important;grid-gap:8px!important;gap:8px!important}.filter-grid input,.filter-grid select{width:100%!important;min-width:0!important}.toggle-switch{min-width:48px;min-height:28px;flex-shrink:0}}.update-banner{background:var(--color-primary);padding:10px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid hsla(0,0%,100%,.2);box-shadow:0 2px 8px rgba(0,0,0,.2)}.update-banner,.update-banner-btn{color:#fff;font-size:var(--text-base)}.update-banner-btn{background:var(--color-danger);border:none;border-radius:var(--radius-sm);padding:6px 14px;cursor:pointer;white-space:nowrap;transition:background var(--dur-fast) var(--ease-smooth)}.update-banner-btn:hover{background:var(--color-danger-hover)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 12px;border-bottom:1px solid hsla(0,0%,100%,.15)}.sidebar-brand-icon{width:44px;height:44px;border-radius:var(--radius-md);background:hsla(0,0%,100%,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-brand-text{display:flex;flex-direction:column}.sidebar-brand-name{font-size:var(--text-md);font-weight:700;color:#fff;line-height:1.2}.sidebar-brand-sub{font-size:var(--text-sm);color:hsla(0,0%,100%,.65);margin-top:2px}.sidebar-nav{flex:1 1;padding:12px 8px;overflow-y:auto}.nav-item-btn{width:100%;display:flex;align-items:center;gap:10px;padding:9px 12px;border:none;border-radius:var(--radius-md);background:transparent;color:hsla(0,0%,100%,.9);font-size:var(--text-base);cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth);text-align:left}.nav-item-btn:hover{background:hsla(0,0%,100%,.1)}.nav-item-btn.active{background:var(--color-primary-active)}.nav-item-active-dot{width:6px;height:6px;border-radius:50%;background:#fff;margin-left:auto;box-shadow:0 0 6px hsla(0,0%,100%,.7);flex-shrink:0}.sidebar-footer{padding:12px 8px;border-top:1px solid hsla(0,0%,100%,.15);display:flex;flex-direction:column;gap:6px}.sidebar-user-area{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--radius-md);background:hsla(0,0%,100%,.12)}.sidebar-user-icon{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.18);display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-user-name{font-size:var(--text-base);color:#fff;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:var(--text-sm);color:hsla(0,0%,100%,.65)}.sidebar-logout-btn{width:100%;display:flex;align-items:center;gap:8px;padding:8px 12px;border:none;border-radius:var(--radius-md);background:hsla(0,0%,100%,.08);color:hsla(0,0%,100%,.8);font-size:var(--text-base);cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth)}.sidebar-logout-btn:hover{background:hsla(0,0%,100%,.15)}.topbar{height:52px;background:#0c141f;border-bottom:1px solid hsla(0,0%,100%,.1);display:flex;align-items:center;padding:0 16px;gap:8px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.topbar-title{font-size:var(--text-md);font-weight:600;color:#fff;flex:1 1}.topbar-btn{width:36px;height:36px;border:none;border-radius:var(--radius-md);background:transparent;color:hsla(0,0%,100%,.9);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--dur-fast) var(--ease-smooth)}.topbar-btn:hover{background:hsla(0,0%,100%,.1)}.notif-badge{position:absolute;top:6px;right:6px;min-width:16px;height:16px;border-radius:8px;background:#dc2626;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none}.notif-popover{position:absolute;top:calc(100% + 8px);right:0;width:320px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(34,27,107,.16),0 2px 8px rgba(0,0,0,.08);border:1px solid var(--color-border);z-index:200;overflow:hidden}.notif-header{padding:12px 16px;border-bottom:1px solid var(--color-border);background:rgba(7,102,244,.03)}.notif-header-title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.notif-item{padding:10px 16px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth)}.notif-item.unread,.notif-item:hover{background:rgba(7,102,244,.04)}.notif-item-cat{display:inline-block;font-size:10px;padding:2px 6px;border-radius:var(--radius-sm);background:rgba(7,102,244,.08);color:var(--color-accent);margin-bottom:4px}.notif-view-all{display:block;width:100%;padding:10px;text-align:center;font-size:var(--text-base);color:var(--color-accent);background:#f9fafb;border:none;cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth)}.notif-view-all:hover{background:var(--color-bg)}.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:199}.welcome-banner{background:var(--color-primary);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:20px;box-shadow:0 4px 16px rgba(0,0,0,.25);position:relative;overflow:hidden}.welcome-greet{font-size:var(--text-lg);font-weight:700;color:hsla(0,0%,100%,.95)}.welcome-date{font-size:var(--text-base);color:hsla(0,0%,100%,.65);margin-top:4px}.welcome-action-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius-md);background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.25);font-size:var(--text-base);cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth),box-shadow var(--dur-fast) var(--ease-smooth);text-decoration:none}.welcome-action-btn:hover{background:#f0f5ff;color:var(--color-accent);box-shadow:0 4px 12px rgba(7,102,244,.15)}.welcome-btn-v{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 14px;border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);font-size:var(--text-base);cursor:pointer;box-shadow:0 1px 4px rgba(0,0,0,.08);transition:box-shadow var(--dur-fast) var(--ease-smooth)}.welcome-btn-v:hover{box-shadow:var(--shadow-md)}.kpi-card{background:var(--color-surface);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border);cursor:pointer;transition:box-shadow var(--dur-fast) var(--ease-smooth),transform var(--dur-fast) var(--ease-smooth)}.kpi-card:hover{box-shadow:var(--shadow-sm),0 4px 16px rgba(7,102,244,.14);transform:translateY(-1px)}.kpi-icon-wrap{width:40px;height:40px;border-radius:var(--radius-md);background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-accent);flex-shrink:0}.kpi-label{font-size:var(--text-sm);color:var(--color-text-muted);margin-bottom:4px}.kpi-value{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.kpi-unit{font-size:var(--text-base);color:var(--color-text-muted);margin-left:2px}.action-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);background:var(--color-surface);border:1px solid #f3f4f6;cursor:pointer;transition:box-shadow var(--dur-fast) var(--ease-smooth)}.action-item:hover{box-shadow:var(--shadow-sm)}.action-item-icon{color:var(--status-warning);display:flex;align-items:center}.action-item-icon.error{color:var(--status-error)}.action-count-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:10px;font-size:var(--text-sm);font-weight:600;background:#fef3c7;color:var(--status-warning);margin-left:auto}.action-count-badge.error{background:#fee2e2;color:var(--status-error)}.recent-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-bottom:1px solid var(--color-border);transition:background var(--dur-fast) var(--ease-smooth)}.recent-item:hover{background:rgba(7,102,244,.03)}.recent-company-name{font-size:var(--text-base);font-weight:500;color:var(--color-text)}.recent-print-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-sm);background:rgba(7,102,244,.08);color:var(--color-accent);border:none;font-size:var(--text-sm);cursor:pointer;transition:background var(--dur-fast) var(--ease-smooth)}.recent-print-btn:hover{background:rgba(7,102,244,.15)}.schedule-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:24px;color:var(--color-text-light)}.schedule-empty-icon{font-size:36px;color:#d1d5db}.schedule-empty-text{font-size:var(--text-base);color:#9ca3af}.announcement-row{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;border-bottom:1px solid var(--color-border);cursor:pointer;transition:background .12s}.announcement-row:last-child{border-bottom:none}.announcement-chevron{color:#9ca3af;flex-shrink:0;margin-top:2px}