.admin-page{max-width:1200px;margin:0 auto;padding:2rem}.admin-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.admin-header h1{color:#333;margin:0;font-size:2rem}.admin-header p{color:#666;margin:.5rem 0 0}.alert{border-radius:.5rem;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1rem;display:flex}.alert-error{color:#c33;background-color:#fee;border:1px solid #fcc}.alert-success{color:#3c3;background-color:#efe;border:1px solid #cfc}.loading,.no-users{text-align:center;color:#666;padding:2rem;font-size:1.1rem}.users-table-container{border:1px solid #e0e0e0;border-radius:.5rem;margin-bottom:2rem;overflow-x:auto}.users-table{border-collapse:collapse;background:#fff;width:100%}.users-table thead{background-color:#f5f5f5;border-bottom:2px solid #ddd}.users-table th{text-align:left;color:#333;padding:1rem;font-size:.9rem;font-weight:600}.users-table td{color:#666;border-bottom:1px solid #eee;padding:1rem}.users-table tbody tr:hover{background-color:#fafafa}.users-table tbody tr.inactive{opacity:.6}.role-badge,.status-badge{border-radius:.25rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;display:inline-block}.role-badge{color:#1976d2;background-color:#e3f2fd}.role-badge.role-viewer{color:#4f6476;background-color:#eef3f7}.role-badge.role-editor{color:#0f6cbd;background-color:#e6f4ff}.role-badge.role-hr{color:#247346;background-color:#edf8ef}.role-badge.admin,.role-badge.role-admin{color:#c2185b;background-color:#fce4ec}.status-badge.active{color:#2e7d32;background-color:#e8f5e9}.status-badge.inactive{color:#c62828;background-color:#ffebee}.actions{text-align:center}.btn{cursor:pointer;text-align:center;border:none;border-radius:.25rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-success{color:#fff;background-color:#4caf50}.btn-success:hover:not(:disabled){background-color:#45a049}.btn-warning{color:#fff;background-color:#ff9800}.btn-warning:hover:not(:disabled){background-color:#e68900}.text-muted{color:#999;font-size:.9rem}.role-select{background:#fff;border:1px solid #cfd9e2;border-radius:.5rem;min-width:140px;padding:.55rem .75rem}.admin-info{background-color:#f9f9f9;border:1px solid #ddd;border-radius:.5rem;margin-top:2rem;padding:1.5rem}.admin-info h3{color:#333;margin-top:0}.admin-info ul{color:#666;margin:0;padding-left:1.5rem}.admin-info li{margin-bottom:.5rem}.error-container{text-align:center;color:#666;padding:3rem}.error-container h2{color:#c33;margin-top:0}:root{color:#153047;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;background:radial-gradient(circle at 0 0,#287ab938,#0000 24%),radial-gradient(circle at 100% 0,#0d94881f,#0000 22%),linear-gradient(#eef5fb 0%,#f7fbfd 52%,#f4f8fb 100%);font-family:Yu Gothic UI,Meiryo,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button{cursor:pointer;border:none;border-radius:14px;padding:11px 18px;transition:transform .18s,box-shadow .18s,background-color .18s,border-color .18s}button:hover,a.primary-button:hover,a.secondary-button:hover,a.ghost-button:hover{transform:translateY(-1px)}#root{min-height:100vh}.screen-message{color:#4b647b;background:#ffffff8c;border:1px dashed #d8e4ee;border-radius:22px;place-items:center;min-height:36vh;display:grid}.auth-shell,.app-shell{max-width:1180px;margin:0 auto;padding:0 20px 32px}.page-stack{gap:20px;display:grid}.auth-card,.panel{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffe0;border:1px solid #dae5efe6;border-radius:28px;box-shadow:0 18px 50px #15304717}.auth-card{max-width:520px;margin:40px auto;padding:34px}.hero-panel{background:linear-gradient(135deg,#ffffffe0,#f1f8ffeb),linear-gradient(120deg,#0f6cbd,#1d8c87);border:1px solid #d6e3eee6;border-radius:28px;justify-content:space-between;gap:24px;padding:12px 16px;display:flex;box-shadow:0 20px 46px #10345514}.hero-panel-archive{background:linear-gradient(135deg,#fffaf4e6,#fff4e9f5),linear-gradient(120deg,#c9721d,#b64a2b)}.hero-panel-history{background:linear-gradient(135deg,#f4f8ffeb,#eff8f8f2),linear-gradient(120deg,#294c73,#1f6b6b)}.hero-panel h1,.page-header h1,.detail-header h1,.auth-card h1{margin:0 0 4px;font-size:clamp(1.45rem,3vw,2rem);line-height:1.08}.hero-actions{flex-wrap:wrap;align-items:flex-start;gap:14px;display:flex}.hero-cta{min-height:auto;padding:12px 18px}.toolbar-panel,.table-panel{padding:18px 20px}.toolbar-panel{z-index:8;position:relative;overflow:visible}.search-block{gap:8px;display:grid}.search-controls{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.toolbar-summary{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.toolbar-summary .search-block{flex:480px}.search-label{color:#35506c;font-weight:700}.search-input{background:#fffffff2;border:1px solid #cad8e5;border-radius:14px;width:min(480px,100%);padding:13px 14px}.toolbar-summary .search-input{width:100%}.search-input:focus{border-color:#6aaadf;outline:none;box-shadow:0 0 0 4px #0f6cbd14}.filter-toggle-button{justify-self:flex-start}.filter-panel{padding:18px 20px}.filter-grid{grid-template-columns:repeat(6,minmax(0,1fr));gap:14px 16px;display:grid}.filter-field-half{grid-column:span 3;justify-self:start;width:min(100%,220px)}.filter-field-wide{grid-column:span 6;justify-self:start;width:min(100%,520px)}.filter-inline-row{grid-column:1/-1;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:16px;width:100%;display:grid}.filter-name-group{width:min(100%,360px)}.filter-sort-group{justify-self:end;min-width:280px}.filter-sort-controls{grid-template-columns:minmax(0,1.5fr) minmax(120px,.8fr);gap:10px;display:grid}.filter-field-narrow{grid-column:span 2}.filter-field-prefecture{grid-column:span 2;width:100%}.filter-actions{justify-content:flex-end;margin-top:18px;display:flex}.salary-calc-panel{gap:18px;display:grid}.salary-calc-panel-sticky{z-index:12;position:sticky;top:82px}.salary-calculator-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.salary-employee-table th:nth-child(n+3),.salary-employee-table td:nth-child(n+3){text-align:right}.salary-employee-table th:nth-child(2),.salary-employee-table td:nth-child(2){text-align:center}.salary-sort-header{align-items:center;gap:8px;display:inline-flex}.salary-sort-button{background:#fffffff2;border:1px solid #cad8e5;border-radius:999px;justify-content:center;align-items:center;width:24px;min-width:24px;height:24px;padding:0;display:inline-flex}.salary-sort-button-active{background:#4c7ece1f;border-color:#4c7ece}.salary-sort-icon{justify-items:center;gap:2px;display:grid}.salary-sort-arrow{opacity:.45;border-left:5px solid #0000;border-right:5px solid #0000;width:0;height:0}.salary-sort-arrow-up{border-bottom:6px solid #4c7ece}.salary-sort-arrow-down{border-top:6px solid #4c7ece}.salary-sort-arrow-current{opacity:1}.inline-stat{gap:4px;min-width:112px;padding:8px 0;display:grid}.inline-stat-label{color:#658097;font-size:.82rem;font-weight:700}.inline-stat-value{color:#133d60;font-size:1.55rem;font-weight:800}.stat-card{background:#ffffffc2;border:1px solid #d5e2eee6;border-radius:20px;min-width:132px;padding:16px 18px}.stat-card-warm{background:#fffaf4e6}.stat-label{color:#658097;letter-spacing:.06em;margin-bottom:8px;font-size:.82rem;font-weight:700;display:block}.stat-value{color:#133d60;font-size:1.8rem;font-weight:800}.stat-value-sm{font-size:1.2rem}.eyebrow{color:#0f6cbd;letter-spacing:.08em;background:#e4f0fb;border-radius:999px;padding:6px 10px;font-size:.82rem;font-weight:700;display:inline-block}.eyebrow-compact{padding-inline:8px}.eyebrow-warm{color:#b55710;background:#fff0e2}.eyebrow-dark{color:#35506c;background:#e9f0f7}.muted{color:#61788d}.stack{gap:14px;display:grid}.field{gap:6px;display:grid}.field label{color:#35506c;font-weight:700}.field input,.field textarea,.field select{background:#fffffff2;border:1px solid #cad8e5;border-radius:14px;width:100%;padding:13px 14px;box-shadow:inset 0 1px #ffffffa6}.field input:focus,.field textarea:focus,.field select:focus{border-color:#6aaadf;outline:none;box-shadow:0 0 0 4px #0f6cbd14}.choice-group{flex-wrap:wrap;gap:10px;display:flex}.choice-chip{cursor:pointer;background:#fffffff2;border:1px solid #cad8e5;border-radius:14px;align-items:center;gap:8px;padding:11px 14px;display:inline-flex}.choice-chip input{margin:0}.choice-chip-checkbox{justify-content:flex-start;min-height:48px}.field-checkbox{align-content:start;max-width:180px}.field-checkbox .choice-chip-checkbox,.field-checkbox .readonly-value{width:fit-content;min-width:96px}.field-span-2{grid-column:span 2}.company-filter-skill-field,.company-filter-row{grid-column:span 6}.company-filter-row-primary{grid-template-columns:minmax(0,1.15fr) minmax(0,1fr);gap:16px}.company-filter-row-secondary,.company-filter-row-tertiary{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.company-filter-skill-group{flex-wrap:nowrap}.company-filter-skill-group .choice-chip-checkbox{white-space:nowrap;justify-content:center;min-width:120px}.company-filter-memo-field{grid-column:span 3}.date-field{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.date-picker-button{flex:none}.date-picker-input{opacity:0;pointer-events:none;border:0;width:0;min-width:0;padding:0;position:absolute}.primary-button,.secondary-button,.danger-button,.ghost-button{white-space:nowrap;border-radius:16px;justify-content:center;align-items:center;min-height:46px;padding:12px 20px;font-weight:700;line-height:1;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg,#0f6cbd,#2d88db);box-shadow:0 10px 18px #0f6cbd3d}.secondary-button{color:#204d74;background:linear-gradient(135deg,#eef6ff,#dbeaf8);border:1px solid #d2e0ee}.danger-button{color:#fff;background:linear-gradient(135deg,#d04a4a,#b93434);box-shadow:0 10px 18px #b934342e}.ghost-button{color:#35506c;background:#ffffffb8;border:1px solid #ccd8e3}.button-row{flex-wrap:wrap;gap:12px;display:flex}.page-header,.detail-header{justify-content:space-between;align-items:flex-start;gap:20px;display:flex}.detail-header-rich{margin-bottom:0}.list-grid,.history-list{gap:16px;display:grid}.list-grid-rich{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.employee-card{justify-content:space-between;align-items:center;gap:20px;padding:20px;display:flex}.employee-card-rich{min-height:156px;padding:24px;position:relative;overflow:hidden}.employee-card-rich:after{content:"";pointer-events:none;background:radial-gradient(circle,#2188db1f,#0000 66%);border-radius:999px;width:140px;height:140px;position:absolute;inset:auto -24px -30px auto}.employee-card-archive:after{background:radial-gradient(circle,#c9721d24,#0000 66%)}.employee-card-main{gap:12px;display:grid}.employee-table-wrap{overflow-x:auto}.table-pagination{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:12px;display:flex}.table-pagination-top{margin-bottom:14px}.table-pagination-bottom{margin-top:14px}.pagination-button{min-width:92px}.pagination-pages{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.pagination-page-button{min-width:42px;min-height:40px;padding:8px 10px}.pagination-page-button-active{color:#fff;background:linear-gradient(135deg,#0f6cbd,#2d88db);border-color:#0000;box-shadow:0 8px 18px #0f6cbd2e}.pagination-ellipsis{color:#6c8498;justify-content:center;align-items:center;min-width:24px;display:inline-flex}.employee-table{table-layout:fixed;border-collapse:separate;border-spacing:0;width:100%}.employee-table thead th{text-align:left;color:#557189;border-bottom:1px solid #dbe5ef;padding:14px 16px;font-size:.88rem}.employee-table tbody td{vertical-align:middle;overflow-wrap:anywhere;word-break:break-word;border-bottom:1px solid #edf3f7;padding:16px}.employee-table tbody tr:last-child td{border-bottom:none}.employee-table tbody tr:hover{background:#f5faffbf}.clickable-row{cursor:pointer}.employee-name-cell{gap:4px;display:grid}.table-button{padding:9px 14px}.empty-cell{text-align:center;color:#61788d}.employee-card-heading{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.employee-card h2{margin:0;font-size:1.2rem}.employee-meta{color:#62758a;gap:6px;display:grid}.employee-meta-inline{flex-wrap:wrap;gap:8px;display:flex}.employee-meta-inline span{background:#f3f8fc;border:1px solid #dce8f1;border-radius:999px;padding:8px 12px;font-size:.92rem}.status-pill{border-radius:999px;align-items:center;padding:8px 12px;font-size:.85rem;font-weight:700;display:inline-flex}.status-pill-active{color:#247346;background:#e7f6eb}.status-pill-archive{color:#b55710;background:#fff0e3}.history-list-timeline{position:relative}.history-card{padding:22px;position:relative}.history-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;display:flex}.history-head h2{margin:0 0 6px}.history-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.history-item{background:#f8fbfd;border:1px solid #d7e2ec;border-radius:14px;padding:12px 14px}.history-item-plain{gap:6px;display:grid}.history-item-label{color:#61788d;font-size:.84rem;font-weight:700}.history-item-value{overflow-wrap:anywhere;word-break:break-word;background:#fff;border:1px solid #d7e2ec;border-radius:12px;min-width:0;min-height:44px;padding:12px 14px}.history-badge{border-radius:999px;align-items:center;padding:7px 11px;font-size:.85rem;font-weight:700;display:inline-flex}.action-created{color:#1f6b38;background:#e5f4ea}.action-updated{color:#0f6cbd;background:#e5f0fb}.action-deleted{color:#b55710;background:#fff0e3}.action-restored{color:#1f6f90;background:#edf7ff}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.company-detail-row{grid-column:1/-1;gap:16px;display:grid}.company-detail-row-primary{grid-template-columns:repeat(2,minmax(0,1fr))}.company-detail-row-secondary{grid-template-columns:repeat(3,minmax(0,1fr))}.company-detail-row-skill{grid-template-columns:minmax(0,1fr)}.detail-grid-compact{grid-template-columns:repeat(auto-fit,minmax(140px,180px))}.detail-panel{padding:24px}.detail-panel-rich{padding:28px}.section-stack{gap:18px;display:grid}.section-head-with-action{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.name-banner,.form-section{background:#fbfdff;border:1px solid #dbe5ef;border-radius:20px;padding:18px}.empty-state-inline{color:#6e8397;padding:10px 4px}.name-banner-rich{background:linear-gradient(#fffffff5,#f5fafff5);gap:14px;display:grid}.employee-detail-page .name-banner-rich,.company-detail-page .name-banner-rich,.company-create-page .name-banner-rich{z-index:20;position:sticky;top:88px;box-shadow:0 14px 30px #15304714}.form-section-rich{background:linear-gradient(#fbfdfffa,#f5f9fcfa)}.name-banner h2,.section-head h3{margin:6px 0 0}.employee-detail-page .name-banner h2{font-size:clamp(1.15rem,2vw,1.4rem)}.employee-detail-page .employee-meta-inline span:not(.status-pill){display:none}.name-banner-title-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.employee-detail-page .section-head h3{color:#8a4d12;background:linear-gradient(135deg,#ffebd6f2,#fff5e9eb);border-radius:999px;align-items:center;padding:6px 12px;display:inline-flex;box-shadow:inset 0 0 0 1px #e4ab6f3d}.section-head{margin-bottom:14px}.readonly-value{background:#f8fbfd;border:1px solid #d7e2ec;border-radius:14px;min-height:48px;padding:12px 14px}.status-banner{color:#70550f;background:#fff5d6;border-radius:14px;margin-bottom:16px;padding:12px 14px}.error-banner{color:#8b2020;background:#fee7e7;border-radius:14px;margin-top:12px;padding:12px 14px}.app-main{padding-top:84px}.mobile-topbar{z-index:90;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffeb;border-bottom:1px solid #d8e3edf2;grid-template-columns:56px 1fr auto;align-items:center;width:min(1180px,100% - 40px);min-height:72px;padding:10px 8px;display:grid;position:fixed;top:0;left:50%;transform:translate(-50%);box-shadow:0 8px 24px #12304914}.mobile-topbar-title{text-align:center;letter-spacing:.02em;margin:0;font-size:1.45rem;font-weight:800}.icon-button{color:#183751;background:0 0;border-radius:16px;place-items:center;width:48px;height:48px;padding:0;display:inline-grid}.menu-trigger{justify-self:start}.hamburger-lines{gap:5px;display:grid}.hamburger-lines span{background:#183751;border-radius:999px;width:26px;height:3px;display:block}.topbar-profile{justify-self:end}.topbar-actions-right{justify-self:end;align-items:center;gap:6px;display:inline-flex}.topbar-back-button{width:48px;height:48px}.topbar-back-icon{color:#4e4e4e;text-shadow:.6px 0 #4e4e4e,-.6px 0 #4e4e4e,0 .6px #4e4e4e,0 -.6px #4e4e4e;justify-content:center;align-items:center;font-size:2.35rem;font-weight:900;line-height:1;display:inline-flex;transform:translateY(-1px)}.topbar-profile-ring{border:2px solid #183751;border-radius:999px;width:32px;height:32px;position:relative}.topbar-profile-head{background:#183751;border-radius:999px;width:8px;height:8px;position:absolute;top:5px;left:50%;transform:translate(-50%)}.profile-anchor{justify-self:end;position:relative}.profile-anchor-open .profile-popover{opacity:1;visibility:visible;transform:translateY(0)}.topbar-profile-button{width:48px;height:48px}.profile-popover{z-index:110;opacity:0;visibility:hidden;background:#fffffffa;border:1px solid #d8e3ed;border-radius:12px;gap:2px;min-width:146px;padding:8px 9px;transition:opacity .18s,visibility .18s,transform .18s;display:grid;position:absolute;top:calc(100% + 8px);right:0;transform:translateY(8px);box-shadow:0 18px 44px #12304929}.profile-logout-button{min-height:26px;margin-top:1px;padding:2px 4px}.topbar-profile-body{background:#183751;border-radius:999px 999px 4px 4px;width:14px;height:7px;position:absolute;bottom:5px;left:50%;transform:translate(-50%)}.drawer-backdrop{z-index:95;background:#14212d47;border-radius:0;position:fixed;inset:0}.side-drawer{z-index:100;background:#fffffffa;border-right:1px solid #d8e3ed;border-radius:0 20px 20px 0;grid-template-rows:auto auto auto auto;align-content:start;width:min(360px,84vw);min-height:48vh;max-height:calc(100vh - 20px);padding:12px 0 16px;display:grid;position:fixed;top:10px;left:max(20px,50% - 590px);overflow-y:auto;box-shadow:18px 0 44px #12304929}.drawer-header{border-bottom:1px solid #edf3f7;justify-content:flex-start;padding:0 16px 12px;display:flex}.drawer-close{font-size:2rem;line-height:1}.drawer-profile{align-items:center;gap:10px;padding:14px 16px;display:flex}.drawer-profile-badge{color:#fff;background:linear-gradient(135deg,#0f6cbd,#2d88db);border-radius:10px;place-items:center;width:36px;height:36px;font-size:.92rem;font-weight:800;display:grid}.drawer-nav,.drawer-footer{align-content:start;gap:8px;padding:0 12px;display:grid}.drawer-link{color:#183751;background:0 0;border-radius:12px;justify-content:flex-start;align-items:center;gap:12px;width:100%;min-height:54px;padding:12px 14px;font-size:1.04rem;font-weight:600;line-height:1.2;display:flex}.drawer-link:hover,.drawer-link-active{background:#eef5fb}.drawer-link-icon{place-items:center;min-width:22px;font-size:1.04rem;display:inline-grid}.drawer-link-logout{color:#c72f2f}.toolbar-actions{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.sort-menu{z-index:12;position:relative}.sort-menu-trigger{min-width:34px;min-height:34px;box-shadow:none;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:inline-flex}.sort-menu-trigger:hover,.sort-menu-trigger:focus-visible{box-shadow:none;background:0 0}.sort-icon{justify-items:center;gap:3px;display:grid}.sort-icon-up,.sort-icon-down{border-left:8px solid #0000;border-right:8px solid #0000;width:0;height:0}.sort-icon-up{border-bottom:10px solid #4c7ece}.sort-icon-down{border-top:10px solid #4c7ece}.sort-menu-list{z-index:40;background:#fffffffa;border:1px solid #cad8e5;border-radius:16px;gap:4px;min-width:220px;padding:8px;display:grid;position:absolute;top:calc(100% + 8px);left:0;box-shadow:0 16px 30px #1c36531f}.sort-menu-item{color:#193b60;text-align:left;cursor:pointer;background:0 0;border:none;border-radius:12px;width:100%;padding:8px 10px;font-size:.92rem}.sort-menu-item:hover,.sort-menu-item-active{background:#4c7ece1f}.toolbar-summary-wide .search-block{flex:320px}.dashboard-welcome{gap:8px;padding:10px 4px 0;display:grid}.dashboard-welcome h2{margin:0;font-size:clamp(2rem,5vw,2.6rem);line-height:1.05}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.dashboard-grid-compact{grid-template-columns:repeat(3,minmax(0,1fr))}.company-card-action .dashboard-card-value{font-size:1.2rem}.dashboard-card{color:#183751;background:#ffffffe6;border:1px solid #dae5efe6;border-radius:24px;justify-items:center;gap:10px;min-height:200px;padding:24px 20px;display:grid;box-shadow:0 18px 42px #15304714}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 24px 50px #1530471f}.dashboard-card-icon{font-size:2.2rem;line-height:1}.dashboard-card-label{font-size:1.25rem;font-weight:700}.dashboard-card-value{font-size:2rem;font-weight:800}.dashboard-card-sublabel{color:#657f95;font-size:1rem}.company-contact-list{gap:14px;display:grid}.company-contact-card{color:#183751;background:#fffffff0;border:1px solid #dbe5ef;border-radius:18px;gap:12px;padding:18px;display:grid}.company-contact-card-button{text-align:left;cursor:pointer;width:100%}.company-contact-card-button:hover{transform:translateY(-1px);box-shadow:0 12px 24px #15304714}.company-contact-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.company-contact-card-head h4,.modal-header h2{margin:0}.company-contact-card-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.company-contact-card-field-memo{grid-column:1/-1}.status-chip{border-radius:999px;justify-content:center;align-items:center;min-width:58px;padding:6px 10px;font-size:.85rem;font-weight:700;display:inline-flex}.status-chip-active{color:#1f6f90;background:#1f6f901f}.status-chip-inactive{color:#c72f2f}.modal-backdrop{z-index:1300;background:#0c1e2f57;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal-panel{background:#fbfdfffa;border:1px solid #dae5eff2;border-radius:24px;width:min(100%,760px);max-height:min(90vh,960px);padding:22px;overflow:auto;box-shadow:0 24px 60px #1530472e}.modal-panel-large{width:min(100%,920px)}.modal-header,.modal-footer{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.modal-footer{flex-wrap:wrap;margin-top:4px;margin-bottom:0}.modal-close{font-size:1.4rem}.workspace-panel,.company-top-panel{padding:28px}.workspace-panel-head,.company-top-head{gap:8px;display:grid}.workspace-panel-head h2,.company-top-head h2{margin:0;font-size:clamp(1.6rem,3vw,2.1rem)}.workspace-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:20px;margin-top:22px;display:grid}.workspace-card{color:#183751;text-align:left;background:linear-gradient(#fffffff5,#f5fafff0),linear-gradient(135deg,#0f6cbd1a,#2d88db0d);border:1px solid #dae5efe6;border-radius:24px;justify-items:start;gap:10px;min-height:170px;padding:28px 24px;display:grid;box-shadow:0 18px 42px #15304714}.workspace-card:hover{transform:translateY(-2px);box-shadow:0 24px 50px #1530471f}.workspace-card-icon{font-size:2.4rem;line-height:1}.workspace-card-title{font-size:1.35rem;font-weight:800}.dashboard-notifications-block{gap:10px;display:grid}.dashboard-notifications{background:#fffffff0;gap:16px;display:grid;overflow:hidden}.dashboard-notifications .notification-list{overflow:auto hidden}.dashboard-notifications .notification-card{min-width:max-content}.dashboard-notifications-head{justify-content:space-between;align-items:center;gap:16px;display:flex}.dashboard-notifications-head-outside{padding-inline:4px}.dashboard-notifications-head h3{margin:0;font-size:1.2rem}.toolbar-summary .search-label{font-size:1.45rem}.toolbar-summary .search-block{align-self:center}.toolbar-panel .toolbar-summary{min-height:92px}.notifications-summary-panel .toolbar-summary{min-height:72px}.notifications-summary-panel{padding-top:8px;padding-bottom:8px}.notification-list{gap:0;display:grid}.notification-card{min-height:0;box-shadow:none;background:0 0;border:none;border-radius:0;padding:4px 8px}.notification-card-message{color:#24384d;white-space:nowrap;text-overflow:ellipsis;flex-wrap:nowrap;align-items:center;gap:6px;margin:0;line-height:1.2;display:flex;overflow:hidden}.notification-employee-link{color:#0f6cbd;flex:0 auto;min-width:0;font-weight:700;text-decoration:none}.notification-employee-link:hover{text-decoration:underline}.screen-message-inline{min-height:auto;padding:18px 0}.history-grid-compare{gap:14px;display:grid}.history-item-compare{gap:8px;display:grid}.history-compare-values{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:stretch;gap:10px;display:grid}.history-compare-block{gap:6px;min-width:0;display:grid}.history-compare-caption{color:#607286;font-size:.78rem;font-weight:700}.history-compare-arrow{color:#6e8398;place-items:center;font-weight:700;display:grid}.history-item-value-strong{background:#f4f9ff;border-color:#b8d3ea}@media (width<=860px){.hero-panel,.page-header,.detail-header,.employee-card{display:grid}.hero-actions,.toolbar-actions{justify-content:flex-start}.filter-grid,.company-contact-card-grid,.salary-calculator-grid,.company-detail-row-primary,.company-detail-row-secondary{grid-template-columns:1fr}.salary-calc-panel-sticky{top:78px}.filter-field-half,.filter-field-wide,.filter-field-prefecture,.filter-field-narrow{grid-column:span 1}.filter-inline-row{grid-template-columns:1fr;align-items:stretch}.filter-name-group{width:100%}.filter-sort-group{justify-self:stretch;width:100%;min-width:0}.filter-sort-controls{grid-template-columns:1fr}.mobile-topbar{width:calc(100% - 20px)}.app-shell{padding-inline:10px}.app-main{padding-top:78px}.employee-detail-page .name-banner-rich,.company-detail-page .name-banner-rich{top:82px}.toolbar-summary{align-items:stretch}.toolbar-actions{justify-content:flex-start}.dashboard-grid,.dashboard-grid-compact,.workspace-grid{grid-template-columns:1fr}.modal-backdrop{padding:12px}.profile-popover{min-width:140px;right:-4px}}@media (width>=861px){.profile-anchor:hover .profile-popover{opacity:1;visibility:visible;transform:translateY(0)}.side-drawer{width:min(280px,28vw)}.drawer-link{min-height:52px;padding:11px 12px}.dashboard-grid-compact{grid-template-columns:repeat(3,minmax(0,1fr))}}
