*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{color:#1c2733;-webkit-font-smoothing:antialiased;background:#eef2f7;font-family:Noto Sans JP,Hiragino Sans,Yu Gothic,sans-serif;font-size:14px;line-height:1.6}a{color:#2f6098;text-decoration:none}a:hover{color:#4a82c4}button{cursor:pointer;font-family:inherit}table{border-collapse:collapse;width:100%}h1,h2,h3,h4{font-weight:700;line-height:1.3}[x-cloak]{display:none!important}.app{min-height:100vh;display:flex}.app__main{flex-direction:column;flex:1;min-width:0;margin-left:240px;display:flex}.app__content{flex:1;padding:24px 28px}.page-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.page-header__title{color:#14253b;font-size:20px}.page-header__subtitle{color:#5b6b7d;margin-top:2px;font-size:13px}.page-header__actions{gap:10px;display:flex}.sidebar{color:#eaf1f9;z-index:100;background:#0d1b2a;flex-direction:column;width:240px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar__brand{letter-spacing:.02em;border-bottom:1px solid #ffffff14;align-items:center;gap:10px;height:60px;padding:0 20px;font-size:16px;font-weight:700;display:flex}.sidebar__logo{background:#2f6098;border-radius:4px;place-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:grid}.sidebar__nav{flex:1;padding:12px 0;overflow-y:auto}.sidebar__section-label{letter-spacing:.08em;color:#eaf1f973;padding:14px 20px 6px;font-size:11px}.sidebar__link{color:#eaf1f9c7;border-left:3px solid #0000;align-items:center;gap:12px;padding:10px 20px;font-size:14px;transition:background .12s,color .12s;display:flex}.sidebar__link:hover{color:#eaf1f9;background:#ffffff0d}.sidebar__link--active{color:#fff;background:#2f609847;border-left-color:#4a82c4}.sidebar__icon{text-align:center;width:18px;font-size:15px}.sidebar__footer{color:#eaf1f980;border-top:1px solid #ffffff14;padding:14px 20px;font-size:12px}.topbar{z-index:200;background:#fff;border-bottom:1px solid #d6e0ec;justify-content:space-between;align-items:center;height:60px;padding:0 28px;display:flex;position:sticky;top:0}.topbar__crumbs{color:#5b6b7d;font-size:13px}.topbar__user{color:#1c2733;align-items:center;gap:10px;font-size:13px;display:flex}.topbar__avatar{color:#fff;background:#1b3a5b;border-radius:50%;place-items:center;width:32px;height:32px;font-weight:700;display:grid}.btn{color:#1c2733;background:#fff;border:1px solid #0000;border-radius:4px;justify-content:center;align-items:center;gap:7px;padding:8px 16px;font-size:14px;font-weight:500;line-height:1.2;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.btn:hover{background:#f5f8fc}.btn--primary{color:#fff;background:#234b75;border-color:#234b75}.btn--primary:hover{background:#2f6098}.btn--accent{color:#fff;background:#2f6098;border-color:#2f6098}.btn--accent:hover{background:#4a82c4}.btn--ghost{color:#1b3a5b;background:0 0;border-color:#d6e0ec}.btn--ghost:hover{background:#f5f8fc;border-color:#4a82c4}.btn--danger{color:#d04a4a;background:0 0;border-color:#d04a4a}.btn--danger:hover{background:#d04a4a14}.btn--sm{padding:5px 10px;font-size:12.5px}.btn--block{width:100%}.btn:disabled{opacity:.55;cursor:not-allowed}.card{background:#fff;border:1px solid #d6e0ec;border-radius:8px;box-shadow:0 1px 2px #0d1b2a14}.card__header{border-bottom:1px solid #d6e0ec;justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.card__title{color:#14253b;font-size:15px}.card__body{padding:18px}.card--flush .card__body{padding:0}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #d6e0ec;border-left:4px solid #2f6098;border-radius:8px;flex-direction:column;gap:6px;padding:18px;display:flex;box-shadow:0 1px 2px #0d1b2a14}.stat-card__label{color:#5b6b7d;font-size:12.5px}.stat-card__value{color:#14253b;font-size:26px;font-weight:700;line-height:1.1}.stat-card__unit{color:#5b6b7d;margin-left:3px;font-size:13px;font-weight:500}.stat-card--accent{border-left-color:#2e9e6b}.stat-card--warn{border-left-color:#d99a2b}.data-table{width:100%;font-size:13.5px}.data-table__head th{color:#eaf1f9;text-align:left;white-space:nowrap;background:#14253b;padding:10px 12px;font-weight:500;position:sticky;top:0}.data-table__row{border-bottom:1px solid #d6e0ec}.data-table__row:hover{background:#f5f8fc}.data-table__row--total{background:#2f609814;font-weight:700}.data-table__row--subtotal{background:#1b3a5b1f;font-weight:700}.data-table__row--section{color:#eaf1f9;background:#1b3a5b;font-weight:700}.data-table td{vertical-align:middle;padding:9px 12px}.data-table__num{text-align:right;font-variant-numeric:tabular-nums}.data-table__muted{color:#5b6b7d}.data-table--compact td,.data-table--compact th{padding:6px 9px}.data-table--num-left .data-table__num{text-align:left}.table-wrap{border-radius:8px;overflow-x:auto}.empty-state{text-align:center;color:#5b6b7d;padding:48px 24px}.empty-state__icon{opacity:.4;margin-bottom:10px;font-size:40px}.form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;display:grid}.field{flex-direction:column;gap:5px;display:flex}.field__label{color:#5b6b7d;font-size:12.5px;font-weight:500}.field__label--required:after{content:"*";color:#d04a4a;margin-left:3px}.field__error{color:#d04a4a;font-size:12px}.field--full{grid-column:1/-1}.input,.select,.textarea{color:#1c2733;background:#fff;border:1px solid #d6e0ec;border-radius:4px;width:100%;padding:8px 11px;font-family:inherit;font-size:14px;transition:border-color .12s,box-shadow .12s}.input:focus,.select:focus,.textarea:focus{border-color:#2f6098;outline:none;box-shadow:0 0 0 3px #2f60982e}.input--num,.select--num,.textarea--num{text-align:right;font-variant-numeric:tabular-nums}.input--sm,.select--sm,.textarea--sm{padding:5px 8px;font-size:13px}.textarea{resize:vertical;min-height:72px}.input-cell{text-align:right;font-variant-numeric:tabular-nums;background:0 0;border:1px solid #0000;border-radius:4px;width:100%;padding:6px 8px;font-size:13.5px}.input-cell:hover{border-color:#d6e0ec}.input-cell:focus{background:#fff;border-color:#2f6098;outline:none;box-shadow:0 0 0 3px #2f60982e}.badge{color:#5b6b7d;background:#f5f8fc;border:1px solid #d6e0ec;border-radius:999px;align-items:center;padding:3px 9px;font-size:12px;font-weight:500;display:inline-flex}.badge--general{color:#1b3a5b;background:#2f60981f;border-color:#2f609840}.badge--public{color:#2e9e6b;background:#2e9e6b1f;border-color:#2e9e6b40}.badge--support{color:#d99a2b;background:#d99a2b24;border-color:#d99a2b4d}.badge--contract{color:#234b75;background:#7ba7d92e;border-color:#7ba7d966}.badge--draft{background:#f5f8fc}.badge--active{color:#1b3a5b;background:#2f60981f}.badge--done{color:#2e9e6b;background:#2e9e6b1f}.flash{border:1px solid;border-radius:4px;margin-bottom:18px;padding:12px 16px;font-size:13.5px}.flash--success{color:#1d6e49;background:#2e9e6b1a;border-color:#2e9e6b66}.flash--error{color:#9c2f2f;background:#d04a4a1a;border-color:#d04a4a66}.tabs{border-bottom:1px solid #d6e0ec;gap:4px;display:flex;overflow-x:auto}.tabs__item{color:#5b6b7d;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;padding:8px 14px;font-size:13.5px}.tabs__item:hover{color:#234b75}.tabs__item--active{color:#1b3a5b;border-bottom-color:#2f6098;font-weight:700}.modal{z-index:1000;background:#0d1b2a80;justify-content:center;align-items:flex-start;padding:60px 20px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal__dialog{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:880px;max-height:80vh;display:flex;box-shadow:0 8px 24px #0d1b2a29}.modal__header{border-bottom:1px solid #d6e0ec;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal__title{color:#14253b;font-size:16px}.modal__close{color:#5b6b7d;background:0 0;border:none;font-size:22px;line-height:1}.modal__close:hover{color:#1c2733}.modal__body{padding:18px 20px;overflow-y:auto}.modal__footer{border-top:1px solid #d6e0ec;justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.section-title{color:#14253b;border-bottom:2px solid #234b75;margin:22px 0 12px;padding-bottom:6px;font-size:15px}.auth{background:#eef2f7;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.auth__card{width:100%;max-width:400px;padding:32px 28px}.auth__brand{color:#14253b;align-items:center;gap:10px;margin-bottom:22px;font-weight:700;display:flex}.auth__brand .sidebar__logo{color:#fff;background:#1b3a5b;border-radius:4px;place-items:center;width:34px;height:34px;font-size:13px;display:grid}.auth__title{color:#14253b;margin-bottom:18px;font-size:19px}.auth__form{flex-direction:column;gap:16px;display:flex}.auth__remember{color:#5b6b7d;align-items:center;gap:7px;font-size:13px;display:flex}.password-field{position:relative}.password-field .input{padding-right:42px}.password-field__toggle{cursor:pointer;opacity:.7;background:0 0;border:0;place-items:center;width:30px;height:30px;padding:0;font-size:16px;line-height:1;display:grid;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.password-field__toggle:hover{opacity:1}.pw-rules{color:#5b6b7d;flex-wrap:wrap;gap:6px 16px;margin:8px 0 0;padding:0;font-size:12.5px;list-style:none;display:flex}.pw-rules li{align-items:center;gap:5px;display:inline-flex}.pw-rules__mark{color:#5b6b7d;font-weight:700}.pw-rules__item--ok,.pw-rules__item--ok .pw-rules__mark{color:#2e9e6b}.field__hint{color:#5b6b7d;font-size:11.5px;font-weight:400}.topbar__logout{margin:0}.badge--admin{color:#1b3a5b;background:#1b3a5b24;border-color:#1b3a5b59}.pagination{justify-content:flex-end;margin:0;display:flex}.pagination__list{align-items:center;gap:4px;list-style:none;display:flex}.pagination__item{display:inline-flex}.pagination__link{color:#1b3a5b;font-variant-numeric:tabular-nums;background:#fff;border:1px solid #d6e0ec;border-radius:4px;justify-content:center;align-items:center;min-width:36px;height:36px;padding:0 11px;font-size:13.5px;line-height:1;transition:background .12s,border-color .12s,color .12s;display:inline-flex}.pagination__link:hover{color:#1b3a5b;background:#f5f8fc;border-color:#4a82c4}.pagination__item--active .pagination__link{color:#fff;cursor:default;background:#234b75;border-color:#234b75}.pagination__item--disabled .pagination__link{color:#5b6b7d;opacity:.55;cursor:not-allowed}.pagination__item--disabled .pagination__link:hover{color:#5b6b7d;background:#fff;border-color:#d6e0ec}.pagination__ellipsis{color:#5b6b7d;justify-content:center;align-items:center;min-width:28px;height:36px;display:inline-flex}.estimate{flex-direction:column;gap:18px;display:flex}.estimate__cover{background:#fff;border:1px solid #d6e0ec;border-radius:8px;padding:18px;box-shadow:0 1px 2px #0d1b2a14}.estimate-section{background:#fff;border:1px solid #d6e0ec;border-radius:8px;overflow:hidden;box-shadow:0 1px 2px #0d1b2a14}.estimate-section__header{color:#eaf1f9;background:#1b3a5b;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;display:flex}.estimate-section__heading{align-items:center;gap:10px;font-size:14.5px;font-weight:700;display:flex}.estimate-section__code{background:#ffffff29;border-radius:4px;padding:2px 9px;font-size:12.5px}.estimate-section__actions{gap:8px;display:flex}.estimate-section__subtotals{background:#f5f8fc;border-top:1px solid #d6e0ec;flex-wrap:wrap;gap:18px;padding:12px 16px;font-size:13px;display:flex}.subtotal-chip{flex-direction:column;gap:2px;display:flex}.subtotal-chip__label{color:#5b6b7d;font-size:12px}.subtotal-chip__value{font-variant-numeric:tabular-nums;color:#14253b;font-weight:700}.subtotal-chip--emphasis .subtotal-chip__value{color:#234b75;font-size:15px}.estimate-grid{width:100%;font-size:13px}.estimate-grid th{color:#eaf1f9;text-align:left;white-space:nowrap;background:#14253b;padding:8px 10px;font-weight:500}.estimate-grid td{border-bottom:1px solid #d6e0ec;padding:4px 8px}.estimate-grid__num{text-align:right;font-variant-numeric:tabular-nums}.estimate-grid tr:hover td{background:#f5f8fc}.master-picker__results{border:1px solid #d6e0ec;border-radius:4px;max-height:44vh;margin-top:12px;overflow-y:auto}.master-picker__item{cursor:pointer;border-bottom:1px solid #d6e0ec;grid-template-columns:1fr 1fr 70px 110px;gap:8px;padding:8px 12px;font-size:13px;display:grid}.master-picker__item:hover{background:#2f609814}.budget-table{width:100%;font-size:13px}.budget-table th{color:#eaf1f9;text-align:right;background:#14253b;padding:9px 11px;font-weight:500}.budget-table th:first-child,.budget-table th:nth-child(2){text-align:left}.budget-table td{text-align:right;font-variant-numeric:tabular-nums;border-bottom:1px solid #d6e0ec;padding:7px 11px}.budget-table td:first-child,.budget-table td:nth-child(2){text-align:left}.budget-table__group{color:#eaf1f9;background:#1b3a5b;font-weight:700}.budget-table__group td{text-align:left}.budget-table__total td{background:#2f60981a;font-weight:700}.budget-table__grand td{color:#fff;background:#234b75;font-size:14px;font-weight:700}.ov{border-collapse:collapse;table-layout:fixed;background:#fff;width:100%;font-size:13px}.ov th,.ov td{vertical-align:middle;text-align:left;border:1px solid #d6e0ec;padding:6px 8px}.ov__band{color:#eaf1f9;letter-spacing:.05em;background:#1b3a5b;font-weight:700}.ov__sect{color:#eaf1f9;text-align:center;letter-spacing:.3em;background:#14253b;font-size:15px;font-weight:700;position:relative}.ov__date{letter-spacing:normal;font-size:12px;font-weight:400;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.ov__label{color:#14253b;white-space:nowrap;background:#f5f8fc;width:16%;font-weight:500}.ov__inline{white-space:nowrap}.ov__inline .ov__in{vertical-align:middle}.ov__in{background:0 0;border:none;border-bottom:1px solid #d6e0ec;width:100%;max-width:100%;padding:4px;font-family:inherit;font-size:13px}.ov__in:focus{background:#f5f8fc;border-bottom-color:#2f6098;outline:none}.ov__in--num{text-align:right;font-variant-numeric:tabular-nums}.ov__in--xs{width:56px}.ov__in--sm{width:130px}.ov__ta{resize:vertical;border:1px solid #d6e0ec;border-radius:4px;width:100%;min-height:64px;padding:6px 8px;font-family:inherit;font-size:13px}.ov__ta:focus{border-color:#2f6098;outline:none;box-shadow:0 0 0 3px #2f60982e}.ov__ta--sm{min-height:40px}.ov__rep{align-items:center;gap:4px;margin-bottom:4px;display:flex}.ov-radio{flex-wrap:wrap;gap:10px;display:inline-flex}.ov-radio__opt{cursor:pointer;align-items:center;gap:4px;display:inline-flex}.ov-radio input{accent-color:#2f6098}.period-picker{background:#fff;border:1px solid #d6e0ec;border-radius:8px;align-items:center;gap:8px;padding:10px 14px;display:inline-flex}.period-picker__label{color:#1b3a5b;margin-right:4px;font-weight:700}.report-table{border-collapse:collapse;width:100%;font-size:13px}.report-table th,.report-table td{border:1px solid #d6e0ec;padding:6px 9px}.report-table thead th{color:#eaf1f9;white-space:nowrap;text-align:right;background:#14253b;font-weight:500}.report-table thead th:first-child,.report-table thead th:nth-child(2){text-align:left}.report-table td{text-align:right;font-variant-numeric:tabular-nums}.report-table td.report-table__text{text-align:left}.report-table__group td{color:#eaf1f9;text-align:left;background:#1b3a5b;font-weight:700}.report-table__subtotal td{background:#2f60981a;font-weight:700}.report-table__grand td{color:#fff;background:#234b75;font-weight:700}.report-table tbody tr:hover td{background:#f5f8fc}.report-table .input-cell{width:100%}
