@import "https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap";:root{--bg-color:#f5f5f5;--surface-color:#fff;--primary-red:#e60012;--primary-red-hover:#cc0010;--orange-header:#de5d2b;--text-main:#333;--text-secondary:#666;--border-color:#ccc;--border-light:#e0e0e0;--link-color:#06c}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-color);color:var(--text-main);-webkit-font-smoothing:antialiased;font-family:Noto Sans JP,sans-serif}.global-header{background-color:var(--orange-header);color:#fff;letter-spacing:2px;padding:8px 16px;font-size:1.2rem;font-weight:700}.page-title-bar{text-align:center;background-color:#eaeaea;border-bottom:1px solid #dcdcdc;padding:16px;font-size:1.5rem;font-weight:700}.main-content{flex-direction:column;align-items:center;min-height:calc(100vh - 120px);padding:40px 20px;display:flex}.portal-title{text-align:center;margin-bottom:24px}.portal-title h2{margin-bottom:4px;font-size:1.1rem}.portal-title .subtitle{color:var(--text-secondary);font-size:.85rem}.login-card{background-color:var(--surface-color);border:1px solid var(--border-light);border-radius:4px;width:100%;max-width:460px;padding:32px 40px;box-shadow:0 4px 6px #0000000d}.login-header{text-align:center;margin-bottom:24px}.login-header h3{margin-bottom:4px;font-size:1.1rem;font-weight:700}.login-header p{color:var(--text-secondary);font-size:.85rem}.input-block{margin-bottom:20px}.input-block label{margin-bottom:8px;font-size:.85rem;font-weight:600;display:block}.input-block input[type=email],.input-block input[type=password]{border:1px solid var(--border-color);border-radius:4px;width:100%;padding:10px 12px;font-family:inherit;font-size:.95rem}.input-block input::placeholder{color:#aaa}.checkbox-row{align-items:center;margin-bottom:24px;display:flex}.checkbox-row input{width:16px;height:16px;margin-right:8px}.checkbox-row label{color:var(--text-main);cursor:pointer;font-size:.85rem}.btn-primary{background-color:var(--primary-red);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;padding:12px;font-size:1rem;font-weight:700;transition:background-color .2s}.btn-primary:hover{background-color:var(--primary-red-hover)}.btn-primary:disabled{cursor:not-allowed;background-color:#f7a8a8}.divider{background-color:var(--border-light);height:1px;margin:24px 0}.forgot-link{text-align:center;color:var(--link-color);margin-bottom:24px;font-size:.85rem;text-decoration:none;display:block}.forgot-link:hover{text-decoration:underline}.signup-section{text-align:center}.signup-section p{margin-bottom:12px;font-size:.85rem}.btn-outline{width:100%;color:var(--text-main);border:1px solid var(--border-color);cursor:pointer;background-color:#fff;border-radius:4px;padding:10px;font-size:.9rem;font-weight:700}.btn-outline:hover{background-color:#f9f9f9}.footer-links{text-align:center;color:var(--text-secondary);margin-top:40px;font-size:.75rem}.footer-links a{color:var(--text-secondary);margin:0 8px;text-decoration:none}.footer-links a:hover{text-decoration:underline}.copyright{text-align:center;color:var(--text-secondary);margin-top:16px;font-size:.75rem}.terms-card{background-color:var(--surface-color);border:1px solid var(--border-light);border-radius:4px;width:100%;max-width:500px;padding:40px;box-shadow:0 4px 6px #0000000d}.terms-header{text-align:center;margin-bottom:32px}.doc-icon{color:#e60012;margin-bottom:12px;font-size:2rem}.terms-header h3{margin-bottom:8px;font-size:1.25rem;font-weight:700}.terms-header p{color:var(--text-secondary);font-size:.85rem}.terms-notice-box{border:1px solid var(--border-light);color:var(--text-main);background-color:#f7f7f7;border-radius:4px;margin-bottom:24px;padding:16px;font-size:.9rem;line-height:1.5}.terms-link-container{margin-bottom:32px}.pdf-link{color:var(--link-color);align-items:center;font-size:.95rem;font-weight:500;text-decoration:none;display:flex}.pdf-link:hover{text-decoration:underline}.pdf-icon{color:#e60012;margin-right:8px;font-size:1.2rem}.terms-checkbox-row{justify-content:center;margin-bottom:32px}.disabled-label{color:var(--text-secondary)!important;cursor:not-allowed!important}.btn-terms{padding:16px;font-size:1.05rem}.home-layout{background-color:var(--bg-color);width:100%;height:calc(100vh - 40px);display:flex}.sidebar{background-color:var(--surface-color);border-right:1px solid var(--border-light);flex-direction:column;width:250px;padding-top:24px;display:flex}.sidebar-logo{color:var(--orange-header);align-items:center;margin-bottom:24px;padding:0 24px;font-weight:700;display:flex}.sidebar-menu{flex:1;list-style:none}.sidebar-menu li{color:var(--text-main);cursor:pointer;border-left:4px solid #0000;align-items:flex-start;padding:12px 24px;font-size:.9rem;transition:background-color .2s;display:flex}.sidebar-menu li:hover:not(.active){background-color:#f9f9f9}.sidebar-menu li.active{color:var(--orange-header);border-left-color:var(--orange-header);background-color:#fff5ee;font-weight:700}.icon-placeholder{margin-right:12px;font-size:1.1rem}.sidebar-bottom{border-top:1px solid var(--border-light);padding:24px}.logout-btn{color:var(--primary-red);cursor:pointer;background:0 0;border:none;align-items:center;font-size:.9rem;font-weight:700;display:flex}.logout-btn:hover{text-decoration:underline}.dashboard-content{background-color:#fdfdfd;flex:1;padding:30px 48px;overflow-y:auto}.dashboard-header{justify-content:flex-end;margin-bottom:10px;display:flex}.contractor-info{text-align:right;color:var(--text-secondary);font-size:.8rem;line-height:1.4}.dashboard-title-row{border-bottom:2px solid var(--surface-color);justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;display:flex}.dashboard-title-row h2{color:var(--text-main);align-items:center;font-size:1.3rem;font-weight:700;display:flex}.area-filter{color:var(--text-main);font-size:.9rem}.area-filter select{border:1px solid var(--border-color);border-radius:4px;margin-left:8px;padding:6px 12px}.blue-notice-box{color:var(--text-main);background-color:#e8f4fc;border:1px solid #b3d8f9;border-radius:4px;align-items:center;margin-bottom:24px;padding:16px;font-size:.85rem;display:flex}.info-icon{color:#2196f3;margin-right:12px;font-size:1.2rem}.dispenser-table{border-collapse:collapse;width:100%;margin-bottom:32px;font-size:.9rem}.dispenser-table th,.dispenser-table td{text-align:left;border-bottom:1px solid var(--border-light);padding:14px 12px}.dispenser-table th{color:var(--text-secondary);font-weight:500}.dispenser-table tbody tr:hover{background-color:#f9f9f9}.orange-notice-box{border:1px solid var(--orange-header);background-color:#fffaf5;border-radius:4px;padding:24px;font-size:.85rem;line-height:1.6}.notice-title{color:var(--orange-header);align-items:center;margin-bottom:12px;font-size:.95rem;font-weight:700;display:flex}.warn-icon{margin-right:8px}.orange-notice-box a{color:var(--orange-header);font-weight:500;text-decoration:none}.orange-notice-box a:hover{text-decoration:underline}.empty-state{text-align:center;border:1px dashed var(--border-color);color:var(--text-main);background-color:#f9f9f9;border-radius:4px;margin-bottom:32px;padding:60px 20px;font-weight:500}.empty-state p{margin-bottom:16px;font-size:1.05rem}.apply-link{color:var(--link-color);font-size:.95rem;text-decoration:none}.apply-link:hover{text-decoration:underline}.corporate-footer{text-align:center;color:var(--text-secondary);margin-top:40px;font-size:.75rem}.app-subtitle-text{color:var(--text-secondary);margin-bottom:24px;font-size:.85rem}.notice-yellow-box{color:var(--text-main);background-color:#fffdf5;border:1px solid #ffeb3b;border-radius:4px;margin-bottom:24px;padding:16px;font-size:.85rem;font-weight:500}.block-container{border:1px solid var(--border-light);background-color:#fff;border-radius:8px;margin-bottom:24px;padding:24px;position:relative}.block-header{color:#e60012;justify-content:space-between;align-items:center;margin-bottom:16px;font-weight:700;display:flex}.btn-remove{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:1.1rem}.btn-remove:hover{color:var(--primary-red)}.grid-row{gap:24px;margin-bottom:16px;display:flex}.grid-col{flex:1}.form-label{color:var(--text-main);margin-bottom:8px;font-size:.85rem;font-weight:700;display:block}.form-input{border:1px solid var(--border-color);border-radius:4px;width:100%;padding:10px 12px;font-size:.95rem}.form-input.error{border-color:var(--primary-red);background-color:snow}.sub-help-text{color:var(--text-secondary);margin-top:4px;font-size:.7rem}.btn-add-dispenser{color:#e60012;cursor:pointer;background:0 0;border:none;align-items:center;margin-top:8px;font-size:.85rem;font-weight:700;display:flex}.btn-add-dispenser:hover{text-decoration:underline}.dispenser-row{align-items:center;gap:12px;margin-bottom:12px;display:flex}.add-notification-row{text-align:center;border-top:1px dashed var(--border-color);margin:32px 0;padding-top:24px}.btn-add-block{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;font-size:.95rem}.btn-add-block:hover{color:var(--text-main);text-decoration:underline}.action-row{justify-content:center;gap:16px;margin-top:40px;display:flex}.error-summary-box{color:var(--primary-red);background-color:snow;border:1px solid #fcc;border-radius:4px;margin-bottom:24px;padding:16px;font-size:.85rem}.error-summary-box ul{margin-top:8px;padding-left:20px}.confirm-table{border-collapse:collapse;width:100%;font-size:.9rem}.confirm-table th,.confirm-table td{border-bottom:1px solid var(--border-light);vertical-align:top;padding:12px 0}.confirm-table th{width:250px;color:var(--text-secondary);text-align:left;font-weight:400}.confirm-table td{font-weight:500}.complete-card{background:#fff;border-radius:8px;max-width:600px;margin:40px auto;padding:32px;box-shadow:0 4px 12px #0000001a}.green-notice{background-color:#f0fdf4;border:1px solid #bbf7d0;border-radius:4px;margin-bottom:24px;padding:16px}.green-notice p{color:#166534;font-size:.9rem;font-weight:700}.area-block{border:1px solid var(--border-light);border-radius:4px;margin-bottom:16px;padding:16px}.area-block-header{align-items:center;gap:16px;margin-bottom:12px;font-weight:700;display:flex}.dispenser-tags{flex-wrap:wrap;gap:8px;display:flex}.dispenser-tag{border:1px solid var(--border-color);background:#f1f5f9;border-radius:4px;padding:4px 12px;font-size:.8rem}.ext-action-bar{align-items:center;gap:16px;margin-bottom:24px;display:flex}.ext-bulk-btn{border-radius:20px;padding:6px 16px;font-size:.85rem;font-weight:500}.ext-btn-orange{color:#e65100;border-color:#ffb74d}.ext-btn-orange:hover{background-color:#fff3e0}.ext-table tr.disabled-row{color:#999;background-color:#f5f5f5}.ext-table tr.disabled-row:hover{background-color:#f5f5f5}.ext-table input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.ext-save-btn{color:#e65100;border-color:#ffb74d;border-radius:24px;padding:12px 64px;font-weight:700}.ext-save-btn:disabled{color:#999;cursor:not-allowed;border-color:#ccc}.ext-save-btn:not(:disabled):hover{background-color:#fff3e0}.ext-success-block{border-top:1px dashed var(--border-color);margin-top:32px;padding-top:32px;animation:.4s ease-out fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-card{border:1px solid var(--border-color);background-color:#fff;border-radius:8px;margin-bottom:24px}.n-card-header{background-color:#fafafa;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.n-btn-edit{color:#f57f17;background-color:#fff8e1;border-color:#ffc107;padding:6px 16px;font-size:.8rem;font-weight:700}.n-btn-edit:hover{background-color:#ffecb3}.n-card-body{padding:24px;display:flex}.n-email-col{border-right:1px solid #eee;flex:1;padding-right:24px}.n-disp-col{flex:1;padding-left:24px}.n-email-row{align-items:center;display:flex}.n-email-text{color:var(--text-main);word-break:break-all;font-size:.9rem}.n-tag{white-space:nowrap;border-radius:4px;margin-right:12px;padding:2px 8px;font-size:.7rem;font-weight:700}.main-tag{color:#c62828;background-color:#ffebee;border:1px solid #ffcdd2}.sub-tag{color:#616161;background-color:#f5f5f5;border:1px solid #e0e0e0}.n-disp-row{background-color:#fff;border:1px solid #f0f0f0;border-radius:4px;justify-content:space-between;align-items:center;margin-bottom:8px;padding:12px;display:flex}.history-block{margin-bottom:40px}.h-block-header{color:var(--text-main);border-bottom:2px solid #ffe0b2;align-items:center;padding-bottom:12px;font-size:1.05rem;font-weight:700;display:flex}.h-cal-icon{color:#e60012;margin-right:8px}.h-card-top-row{justify-content:space-between;align-items:flex-end;display:flex}.area-id-badge{background-color:#fff8e1;border-radius:4px;align-items:center;height:fit-content;padding:4px 12px;font-weight:700;display:inline-flex}.h-separator-line{background-color:#f0f0f0;height:1px;margin:20px 0}.h-dispensers-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.hd-tag{border:1px solid var(--border-color);background-color:#fafafa;border-radius:4px;padding:12px}.hd-tag-name{color:var(--text-main);margin-bottom:4px;font-size:.9rem;font-weight:500}.hd-tag-model{color:#999;font-size:.7rem}.contractor-table{border-collapse:collapse;width:100%;margin-bottom:40px}.contractor-table th,.contractor-table td{text-align:left;padding:16px 0;font-size:.9rem}.contractor-table th{width:250px;color:var(--text-secondary);font-weight:400}.contractor-table td{color:var(--text-main);font-weight:500}.contractor-warning-box{background-color:#fffdf5;border:1px solid #ffcc80;border-radius:4px;padding:24px}.cw-title{color:var(--text-main);align-items:center;margin-bottom:8px;font-size:.85rem;font-weight:700;display:flex}.cw-desc{color:var(--text-secondary);margin-bottom:16px;font-size:.8rem;line-height:1.5}.inq-support-block{background-color:#fafafa;border-bottom:1px solid #eee;align-items:center;gap:32px;padding:24px 32px;display:flex}.inq-email-link{color:#e60012;font-size:.95rem;font-weight:700}.inq-email-link:hover{text-decoration:underline}.faq-item{margin-bottom:24px}.faq-q{color:var(--text-main);margin-bottom:8px;font-size:.85rem;font-weight:700;line-height:1.4}.faq-a{color:var(--text-secondary);padding-left:20px;font-size:.8rem;line-height:1.6}.inq-links-list{flex-direction:column;gap:12px;display:flex}.inq-doc-link{color:#e60012;align-items:center;font-size:.85rem;font-weight:500;display:flex}.inq-doc-link:hover{text-decoration:underline}.spinner{border:4px solid var(--border-light);border-top-color:var(--primary-red);border-radius:50%;width:40px;height:40px;margin:0 auto;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.lp-page{background-color:#f0f0f0;flex-direction:column;min-height:100vh;display:flex}.lp-title-bar{text-align:center;background-color:#f0f0f0;padding:20px 24px 8px}.lp-title-bar-inner{justify-content:center;align-items:center;gap:12px;display:flex}.lp-title-text{color:#222;white-space:nowrap;font-size:1rem;font-weight:700}.lp-subtitle{color:#555;margin-top:4px;font-size:.8rem}.lp-accent-dot{background-color:#1a5276;border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.lp-accent-line{background-color:#1a5276;flex-shrink:0;width:80px;height:2px;display:inline-block}.lp-card-accent{align-items:center;gap:4px;margin-left:16px;display:flex}.lp-title-accent{align-items:center;gap:4px;display:flex}.lp-content{flex-direction:column;flex:1;align-items:center;padding:24px 20px 40px;display:flex}.lp-card{background-color:#fff;border-radius:6px;width:100%;max-width:460px;padding:36px 40px;box-shadow:0 2px 10px #00000014}.lp-card-header{margin-bottom:28px}.lp-card-header-inner{justify-content:center;align-items:center;margin-bottom:6px;display:flex}.lp-card-title{color:#111;text-align:center;font-size:1.1rem;font-weight:700}.lp-card-subtitle{text-align:center;color:#666;font-size:.85rem}.lp-input-block{margin-bottom:20px}.lp-label{color:#005b7f;margin-bottom:6px;font-size:.8rem;font-weight:700;display:block}.lp-input{color:#333;border:1px solid #ccc;border-radius:4px;outline:none;width:100%;padding:10px 12px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.lp-input:focus{border-color:#005b7f}.lp-input::placeholder{color:#aaa}.lp-checkbox-row{color:#333;align-items:center;gap:8px;margin-bottom:24px;font-size:.85rem;display:flex}.lp-checkbox-row input[type=checkbox]{cursor:pointer;width:16px;height:16px}.lp-checkbox-row label{cursor:pointer}.lp-btn-primary{color:#fff;cursor:pointer;background-color:#e60012;border:none;border-radius:4px;width:100%;padding:14px;font-family:inherit;font-size:1.1rem;font-weight:700;transition:background-color .2s}.lp-btn-primary:hover{background-color:#cc0010}.lp-btn-primary:disabled{cursor:not-allowed;background-color:#f7a8a8}.lp-btn-outline,.lp-btn-outline-link{color:#333;cursor:pointer;text-align:center;background-color:#fff;border:1px solid #ccc;border-radius:4px;width:100%;padding:11px;font-family:inherit;font-size:.9rem;font-weight:700;text-decoration:none;transition:background-color .2s;display:block}.lp-btn-outline:hover,.lp-btn-outline-link:hover{background-color:#f5f5f5}.lp-divider{background-color:#e0e0e0;height:1px;margin:24px 0}.lp-forgot-link{text-align:center;color:#06c;margin-bottom:20px;font-size:.85rem;text-decoration:none;display:block}.lp-forgot-link:hover{text-decoration:underline}.lp-signup-section{text-align:center}.lp-no-account{color:#555;margin-bottom:12px;font-size:.8rem}.lp-error-box{color:#e60012;background-color:snow;border:1px solid #fcc;border-radius:4px;margin-bottom:16px;padding:12px 16px;font-size:.85rem}.lp-footer-links{text-align:center;color:#666;margin-top:32px;font-size:.75rem}.lp-footer-links a{color:#666;text-decoration:none}.lp-footer-links a:hover{text-decoration:underline}.lp-footer-sep{color:#999;margin:0 4px}.lp-copyright{text-align:center;color:#1a5276;margin-top:8px;font-size:.75rem;font-weight:500}
