.layout-top{display:flex;flex-direction:column;min-height:100vh}.brandbar{display:flex;align-items:center;background:var(--nav-brand-bg);color:var(--nav-brand-text);padding:0 24px;height:56px;gap:24px;border-bottom:3px solid var(--nav-brand-accent);position:relative;z-index:200}.brandbar-logo{display:flex;align-items:center;gap:8px;font-size:1.1rem;font-weight:700;color:#fff;white-space:nowrap}.brandbar-icon{font-size:1.4rem;color:var(--nav-brand-accent)}.brandbar-search{flex:1;display:flex;max-width:640px;background:var(--nav-search-bg);border-radius:4px;overflow:hidden}.brandbar-search input{flex:1;background:transparent;border:none;padding:8px 12px;color:#fff;font-size:.9rem}.brandbar-search input::placeholder{color:var(--text-muted)}.brandbar-search input:focus{outline:none}.brandbar-search button{padding:0 14px;background:transparent;border:none;color:#cbd5e0;cursor:pointer;font-size:.95rem}.brandbar-search button:hover{background:#2a4365;color:#fff}.mainnav{display:flex;align-items:center;background:var(--bg-surface);border-bottom:1px solid var(--border);box-shadow:0 1px 3px #0000000a;padding:0 24px;gap:16px;min-height:48px;position:relative;z-index:200}.mainnav-links{flex:1;display:flex;align-items:stretch;gap:4px;flex-wrap:nowrap}.mainnav-link,.nav-dropdown-toggle{display:inline-flex;align-items:center;padding:12px 16px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;border:none;background:transparent;cursor:pointer;white-space:nowrap;transition:color .15s;border-bottom:2px solid transparent}.mainnav-link:hover,.nav-dropdown-toggle:hover{color:var(--link);background:var(--bg-hover)}.mainnav-link.active,.nav-dropdown-toggle.active{color:var(--link);font-weight:600;border-bottom-color:var(--link)}.nav-dropdown{position:relative;z-index:210}.nav-dropdown-caret{margin-left:4px;font-size:.7rem;color:inherit}.nav-dropdown-menu{position:absolute;top:100%;left:0;min-width:200px;background:var(--bg-surface);border:1px solid var(--border);border-radius:4px;box-shadow:0 4px 12px #00000014;padding:4px 0;z-index:210}.nav-dropdown-menu a{display:block;padding:10px 16px;color:var(--text-secondary);text-decoration:none;font-size:.9rem}.nav-dropdown-menu a:hover{background:var(--bg-hover);color:var(--link)}.nav-dropdown-menu a.active{background:var(--link-active-bg);color:var(--link);font-weight:600}.mainnav-user{display:flex;align-items:center;gap:10px;flex-shrink:0}.mainnav-email{font-size:.8rem;color:var(--text-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mainnav-user .btn-logout{background:var(--bg-surface);border:1px solid var(--border-strong);color:var(--text-secondary);padding:6px 12px;font-size:.85rem;border-radius:4px;cursor:pointer}.mainnav-user .btn-logout:hover{background:var(--bg-subtle);border-color:var(--border-strong)}.color-picker{display:flex;gap:8px;flex-wrap:wrap}.color-swatch{position:relative;width:32px;height:32px;border-radius:4px;cursor:pointer;border:2px solid transparent;box-sizing:border-box;transition:transform .1s,box-shadow .15s}.color-swatch:hover{transform:scale(1.08)}.color-swatch.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px #fff inset,0 2px 4px #0003}.color-swatch-legacy{position:relative}.color-swatch-legacy:after{content:"現在";position:absolute;bottom:-14px;left:50%;transform:translate(-50%);font-size:10px;color:var(--text-muted);white-space:nowrap}.color-swatch input[type=radio]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.coming-soon{max-width:600px;margin:80px auto;text-align:center;background:var(--bg-surface);padding:48px 32px;border-radius:8px;box-shadow:0 1px 3px #00000014}.coming-soon-icon{font-size:4rem;margin-bottom:16px}.coming-soon h2{margin:0 0 8px;font-size:1.6rem;color:var(--text-primary)}.coming-soon-label{display:inline-block;background:var(--warning-bg);color:var(--warning-text);padding:4px 12px;border-radius:4px;font-size:.85rem;font-weight:600;margin:8px 0 16px}.coming-soon-desc{color:var(--text-secondary);margin:12px 0;font-size:.95rem}.coming-soon-note{color:var(--text-muted);font-size:.85rem;margin-top:16px}.topnav{display:flex;align-items:center;background:#1a202c;color:#e2e8f0;padding:0 24px;height:56px;border-bottom:3px solid #667eea;box-shadow:0 1px 4px #00000014;gap:32px}.topnav-brand h1{font-size:1.1rem;font-weight:700;color:#fff;margin:0;white-space:nowrap}.topnav-links{flex:1;display:flex;align-items:center;gap:4px;overflow-x:auto}.topnav-links a{padding:8px 14px;color:#cbd5e0;text-decoration:none;font-size:.9rem;border-radius:4px;white-space:nowrap;transition:background .15s,color .15s}.topnav-links a:hover{background:#2d3748;color:#fff}.topnav-links a.active{background:#4a5568;color:#fff;font-weight:600}.topnav-loading{color:var(--text-muted);font-size:.85rem;padding:8px 14px}.topnav-user{display:flex;align-items:center;gap:12px;flex-shrink:0}.topnav-email{font-size:.8rem;color:var(--text-muted);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-content-top{flex:1;background:var(--bg-subtle);overflow-y:auto;padding:0}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#1a202c;color:#e2e8f0;display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:20px;border-bottom:1px solid #2d3748}.sidebar-header h1{font-size:1.25rem;font-weight:700;color:#fff;margin:0}.sidebar-nav{flex:1;padding:12px 0}.sidebar-nav a{display:block;padding:10px 20px;color:var(--text-muted);text-decoration:none;font-size:.9rem;transition:background .15s,color .15s}.sidebar-nav a:hover{background:#2d3748;color:#fff}.sidebar-nav a.active{background:#4a5568;color:#fff;border-left:3px solid #667eea}.sidebar-footer{padding:16px 20px;border-top:1px solid #2d3748}.user-info{font-size:.8rem;color:var(--text-muted);margin-bottom:8px;word-break:break-all}.btn-logout{width:100%;padding:6px 12px;background:transparent;border:1px solid #4a5568;color:var(--text-muted);border-radius:4px;cursor:pointer;font-size:.85rem}.btn-logout:hover{background:#2d3748;color:#fff}.main-content{flex:1;background:var(--bg-subtle);overflow-y:auto}.page{padding:24px 32px;max-width:1200px}.page h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.page-header h2{margin:0}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-card{background:var(--bg-surface);border-radius:8px;padding:40px;width:100%;max-width:400px;box-shadow:0 4px 24px #00000026}.login-card h1{text-align:center;color:var(--text-primary);margin:0 0 4px}.login-subtitle{text-align:center;color:var(--text-muted);margin:0 0 24px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:.85rem;font-weight:500;color:var(--text-secondary);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:.9rem;color:var(--text-primary);background:var(--bg-surface);box-sizing:border-box}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #667eea26}.form-group textarea{min-height:80px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.btn-primary{padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:background .15s}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{background:var(--text-muted);cursor:not-allowed;opacity:.7}.btn-secondary{padding:8px 20px;background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border);border-radius:4px;font-size:.9rem;cursor:pointer}.btn-secondary:hover{background:var(--bg-subtle)}.btn-sm{padding:4px 10px;font-size:.8rem;background:#edf2f7;border:none;border-radius:3px;cursor:pointer;color:var(--text-secondary)}.btn-sm:hover{background:var(--bg-hover)}.btn-danger{color:var(--danger)}.btn-danger:hover{background:var(--danger-bg)}.search-bar,.filter-bar{margin-bottom:16px}.search-bar input,.filter-bar select{padding:8px 12px;border:1px solid var(--border);border-radius:4px;font-size:.9rem;min-width:280px;background:var(--bg-surface);color:var(--text-primary)}.data-table{width:100%;border-collapse:collapse;background:var(--bg-surface);border-radius:8px;overflow:hidden;box-shadow:0 1px 3px #00000014}.data-table th{text-align:left;padding:12px 16px;background:var(--bg-subtle);font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border)}.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);font-size:.9rem;color:var(--text-primary)}.data-table tr:hover td{background:var(--row-hover)}.data-table .actions{display:flex;gap:4px}.data-table .empty{text-align:center;color:var(--text-muted);padding:32px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:24px}.kpi-card{background:var(--bg-surface);border-radius:8px;padding:20px;box-shadow:0 1px 3px #00000014}.kpi-card.accent{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.kpi-value{font-size:1.5rem;font-weight:700;margin-bottom:4px}.kpi-label{font-size:.8rem;opacity:.8}.kpi-card.accent .kpi-label{opacity:.9}.card{background:var(--bg-surface);border-radius:8px;padding:20px;box-shadow:0 1px 3px #00000014;margin-bottom:16px}.card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 12px}.card table{width:100%;border-collapse:collapse}.card th{text-align:left;padding:8px 0;font-size:.8rem;color:var(--text-muted);border-bottom:1px solid var(--border)}.card td{padding:8px 0;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid #edf2f7}.dashboard-tables{display:grid;grid-template-columns:1fr 1fr;gap:16px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:500}.badge-open,.badge-pending{background:#fefcbf;color:#975a16}.badge-negotiating{background:#bee3f8;color:#2b6cb0}.badge-won,.badge-confirmed,.badge-delivered{background:#c6f6d5;color:#276749}.badge-lost,.badge-cancelled{background:#fed7d7;color:#9b2c2c}.badge-on_hold,.badge-shipped{background:#e9d8fd;color:#553c9a}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--bg-surface);border-radius:8px;padding:32px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal h3{font-size:1.2rem;margin:0 0 20px;color:var(--text-primary)}.loading{text-align:center;color:var(--text-muted);padding:32px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.1rem;color:var(--text-muted)}.error-message{background:var(--danger-bg);color:var(--danger-text);padding:12px 16px;border-radius:4px;margin-bottom:16px;font-size:.9rem}.sidebar-loading{padding:16px;color:var(--text-muted);font-size:.85rem}.tab-nav{display:flex;border-bottom:1px solid var(--border);margin-bottom:16px}.tab-nav button{padding:8px 16px;border:none;background:transparent;cursor:pointer;color:var(--text-secondary);border-bottom:2px solid transparent;margin-bottom:-1px}.tab-nav button:hover{color:#667eea}.tab-nav button.tab-active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.85rem;color:var(--text-secondary)}.lead-badge-新規{background:#bee3f8;color:#2a4365;padding:2px 8px;border-radius:4px}.lead-badge-コンタクト中{background:#fbd38d;color:#744210;padding:2px 8px;border-radius:4px}.lead-badge-提案中{background:#d6bcfa;color:#44337a;padding:2px 8px;border-radius:4px}.lead-badge-案件化{background:#c6f6d5;color:#22543d;padding:2px 8px;border-radius:4px}.lead-badge-失注{background:#fed7d7;color:#742a2a;padding:2px 8px;border-radius:4px}.lead-badge-保留{background:#e2e8f0;color:var(--text-primary);padding:2px 8px;border-radius:4px}.badge-confirmed{background:#bee3f8;color:#2a4365}.roles-page{padding:20px}.roles-layout{display:grid;grid-template-columns:260px 1fr;gap:20px;align-items:flex-start}.roles-sidebar{background:var(--bg-surface);border-radius:8px;padding:16px;box-shadow:0 1px 3px #00000014;position:sticky;top:20px}.roles-sidebar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.roles-sidebar-header h3{margin:0;font-size:1rem;color:var(--text-primary)}.roles-list{list-style:none;padding:0;margin:0 0 12px}.role-item{display:block;width:100%;text-align:left;padding:10px 12px;background:var(--bg-subtle);border:none;border-radius:6px;margin-bottom:6px;cursor:pointer;transition:background .15s}.role-item:hover{background:var(--bg-hover);transform:translate(2px)}.role-item.active{background:var(--accent);color:#fff;transform:translate(2px)}.role-item.active:hover{background:var(--accent-hover)}.role-item-name{display:block;font-weight:600;font-size:.95rem}.role-item-meta{display:block;font-size:.75rem;opacity:.8;margin-top:2px}.btn-block{width:100%;padding:8px}.roles-main{background:var(--bg-surface);border-radius:8px;padding:20px;box-shadow:0 1px 3px #00000014}.roles-main-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:20px;position:sticky;top:0;background:var(--bg-surface);z-index:10;padding-top:4px}.roles-main-header h2{margin:0 0 6px;font-size:1.3rem}.role-description{color:var(--text-secondary);margin:4px 0 0;font-size:.9rem}.role-note{color:var(--text-muted);margin:4px 0 0;font-size:.8rem}.roles-main-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.permission-groups{display:flex;flex-direction:column;gap:16px}.permission-group{border:1px solid var(--border);border-radius:8px;overflow:hidden}.permission-group-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-subtle);border-bottom:1px solid var(--border)}.permission-group-title{display:flex;align-items:center;gap:8px;font-weight:600;color:var(--text-primary)}.permission-group-icon{font-size:1.2rem}.permission-group-toggles{display:flex;gap:12px}.chk-label{display:inline-flex;align-items:center;gap:4px;font-size:.85rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.chk-label input[type=checkbox]{margin:0}.permission-group-body{padding:12px 16px;display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:8px}.permission-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:6px;cursor:pointer;transition:background .15s,border-color .15s}.permission-item:hover{background:var(--bg-hover);border-color:var(--accent);box-shadow:0 2px 6px #667eea26}.permission-item input[type=checkbox]{margin-top:4px;flex-shrink:0}.permission-item-text{flex:1;min-width:0}.permission-item-desc{font-size:.9rem;color:var(--text-primary);line-height:1.3}.permission-item-key{font-size:.72rem;color:var(--text-muted);background:#edf2f7;padding:1px 6px;border-radius:3px;display:inline-block;margin-top:2px}.unsaved-banner{position:sticky;bottom:0;margin-top:20px;padding:12px 16px;background:var(--warning-bg);border:1px solid var(--warning-text);border-radius:6px;color:var(--warning-text);font-size:.9rem}@media(max-width:768px){.layout{flex-direction:column}.sidebar{width:100%;flex-direction:row;flex-wrap:wrap}.sidebar-nav{display:flex;padding:0}.sidebar-nav a{padding:8px 16px}.sidebar-footer{display:flex;align-items:center;gap:8px;padding:8px 16px}.dashboard-tables{grid-template-columns:1fr}.page{padding:16px}.roles-layout{grid-template-columns:1fr}.roles-sidebar{position:static}.roles-main-header{flex-direction:column;align-items:stretch}.topnav{flex-wrap:wrap;height:auto;padding:8px 16px;gap:8px}.topnav-links{order:3;width:100%;padding-top:4px}.topnav-user{margin-left:auto}.topnav-email{max-width:140px}.brandbar{flex-direction:column;height:auto;padding:8px 16px;gap:8px;align-items:stretch}.brandbar-search{max-width:100%}.mainnav{flex-direction:column;align-items:stretch}.mainnav-user{order:2;padding:8px 0;justify-content:flex-end}}:root{--bg-primary: #f5f7fa;--bg-surface: #ffffff;--bg-subtle: #f7fafc;--bg-hover: #e2e8f0;--bg-active: #cbd5e0;--text-primary: #1a202c;--text-secondary: #4a5568;--text-muted: #718096;--border: #e2e8f0;--border-strong: #cbd5e0;--accent: #667eea;--accent-hover: #5a67d8;--link: #2b6cb0;--link-active-bg: #ebf4ff;--nav-brand-bg: #1a365d;--nav-brand-text: #ffffff;--nav-brand-accent: #f0b429;--nav-search-bg: #2c5282;--danger: #e53e3e;--danger-bg: #fed7d7;--danger-text: #9b2c2c;--warning-bg: #fefcbf;--warning-text: #744210;--success-bg: #c6f6d5;--success-text: #22543d;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--row-hover: #edf2f7}@media(prefers-color-scheme:dark){:root{--bg-primary: #0f172a;--bg-surface: #1e293b;--bg-subtle: #243046;--bg-hover: #334155;--bg-active: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border: #334155;--border-strong: #475569;--accent: #818cf8;--accent-hover: #6366f1;--link: #93c5fd;--link-active-bg: #1e3a8a;--nav-brand-bg: #0b1c33;--nav-brand-text: #f1f5f9;--nav-brand-accent: #f59e0b;--nav-search-bg: #1e3a5f;--danger: #f87171;--danger-bg: #4c1d1d;--danger-text: #fecaca;--warning-bg: #3d2f0c;--warning-text: #fde68a;--success-bg: #14432b;--success-text: #bbf7d0;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--row-hover: #2d3b52}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;color-scheme:light dark}#root{min-height:100vh}
