:root{--navy:#16324f;--blue:#1769aa;--pale:#f4f7fa;--line:#dce4eb;--text:#243342;--muted:#6b7b89;--green:#16845b;--orange:#c87517}
[hidden]{display:none!important}
*{box-sizing:border-box}body{margin:0;font-family:"Yu Gothic UI","Noto Sans JP",sans-serif;color:var(--text);background:#f5f7f9}.topbar{height:72px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 5vw}.brand{display:flex;align-items:center;gap:12px}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:9px;background:var(--navy);color:white;font-weight:700}.brand div{display:flex;flex-direction:column}.brand small{font-size:11px;color:var(--muted);margin-top:2px}.user{font-size:13px;color:var(--muted)}button,input,select{font:inherit}.text-button,.more,.back{border:0;background:none;color:var(--blue);cursor:pointer}.screen{display:none;max-width:1180px;margin:0 auto;padding:44px 28px 70px}.screen.active{display:block}.page-heading{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:28px}.page-heading.compact{align-items:center}.eyebrow{font-size:11px;letter-spacing:.17em;color:var(--blue);font-weight:800;margin:0 0 8px}.page-heading h1,.complete-card h1{font-size:29px;margin:0 0 8px;color:var(--navy)}.page-heading p{margin:0;color:var(--muted)}button{border-radius:8px;padding:12px 20px;font-weight:700;border:1px solid transparent;cursor:pointer}.primary{background:var(--blue);color:white;box-shadow:0 6px 15px #1769aa26}.primary:hover{background:#115b96}.primary:disabled{background:#aebdca;box-shadow:none;cursor:not-allowed}.secondary{background:white;border-color:#bccbd6;color:var(--navy)}.wide{width:100%;margin-top:12px}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:18px}.summary-card{background:white;border:1px solid var(--line);border-top:3px solid var(--blue);padding:20px;border-radius:10px}.summary-card span{display:block;color:var(--muted);font-size:13px}.summary-card strong{font-size:29px;color:var(--navy);margin-right:5px}.summary-card small{color:var(--muted)}.summary-card.orange{border-top-color:var(--orange)}.summary-card.green{border-top-color:var(--green)}.panel{background:white;border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 25px #2947610b}.toolbar{display:flex;gap:12px;padding:18px;border-bottom:1px solid var(--line)}.search{flex:1;border:1px solid #cdd8e0;border-radius:7px;padding:9px 13px;color:var(--muted)}.search input{border:0;outline:0;width:90%;margin-left:7px}.toolbar select,.field select,.field input{border:1px solid #c7d3dc;border-radius:7px;padding:11px;background:#fff;color:var(--text)}.contract-row{display:grid;grid-template-columns:50px 1fr 110px 110px 24px;align-items:center;gap:15px;padding:18px;border-bottom:1px solid #e6ebef}.contract-row:last-child{border-bottom:0}.doc-icon{font-size:10px;font-weight:800;color:#d35448;border:1px solid #efc8c4;border-radius:5px;padding:10px 6px;text-align:center}.contract-main{display:flex;flex-direction:column;gap:5px}.contract-main span,time{font-size:12px;color:var(--muted)}.status{font-size:12px;font-weight:700;border-radius:20px;padding:6px 10px}.status.signed{color:var(--green);background:#e9f7f1}.status.waiting{color:var(--orange);background:#fff3e5}.back{padding:0;margin-bottom:20px}.steps{display:flex;align-items:center}.steps span{width:32px;height:32px;border:2px solid #cbd5dc;border-radius:50%;display:grid;place-items:center;color:#84929e;font-weight:700}.steps span.current{background:var(--blue);border-color:var(--blue);color:white}.steps i{width:35px;border-top:2px solid #cbd5dc}.form-panel{padding:30px;max-width:850px;margin:auto}.form-panel h2{margin:0 0 25px;color:var(--navy);font-size:19px}.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.field{display:flex;flex-direction:column;gap:8px}.field.full{grid-column:1/-1;margin-bottom:20px}.field label,.signature-label{font-size:13px;font-weight:700}.field b,.signature-label b{font-size:10px;color:#d94f42;background:#fff0ee;padding:3px 5px;border-radius:4px}.note{font-size:12px;background:#f1f7fb;color:#527084;padding:12px;margin-top:22px;border-radius:7px}.actions{display:flex;justify-content:flex-end;gap:10px;margin-top:28px}.review-layout{display:grid;grid-template-columns:minmax(0,760px) 300px;gap:24px;align-items:start}.pdf-panel{background:#29333c;border-radius:10px;overflow:hidden}.pdf-toolbar{color:#eaf0f4;font-size:12px;padding:13px 18px;display:flex;justify-content:space-between;background:#202830}.pdf-page{width:75%;margin:22px auto;position:relative;box-shadow:0 5px 25px #0008}.pdf-page img{display:block;width:100%}.signature-on-pdf{position:absolute;left:48%;top:16.3%;width:25%;height:4%;background-size:contain;background-repeat:no-repeat;background-position:center}.review-side{display:flex;flex-direction:column;gap:12px}.info-card,.guide{background:white;border:1px solid var(--line);border-radius:9px;padding:17px}.info-card span{font-size:11px;color:var(--muted);display:block;margin-bottom:7px}.info-card strong{font-size:14px}.guide{border-left:4px solid var(--blue)}.guide strong{font-size:14px;color:var(--navy)}.guide p{font-size:12px;line-height:1.7;color:var(--muted);margin:8px 0 0}.customer-mode{max-width:850px}.sign-wrap{background:white;border:1px solid var(--line);border-radius:14px;padding:34px;box-shadow:0 10px 35px #29476112}.sign-header{display:flex;align-items:center;gap:16px;margin-bottom:25px}.sign-header h1{margin:0 0 5px;color:var(--navy);font-size:25px}.sign-header p{margin:0;color:var(--muted)}.lock{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:#eaf6f1;color:var(--green);font-size:22px;font-weight:800}.agreement{background:#f4f8fb;border:1px solid #d7e4ed;border-radius:9px;padding:18px;margin-bottom:25px}.agreement label{display:flex;align-items:flex-start;gap:10px;line-height:1.6}.agreement input{width:20px;height:20px;accent-color:var(--blue)}.signature-label{display:block;margin-bottom:9px}.canvas-box{position:relative;border:2px dashed #9fb1bf;border-radius:10px;height:260px;background:#fff;overflow:hidden}.canvas-box canvas{width:100%;height:100%;touch-action:none;position:relative;z-index:2}.canvas-box span{position:absolute;inset:0;display:grid;place-items:center;color:#a5b1ba;z-index:1}.sign-actions{display:flex;justify-content:space-between;margin-top:18px}.centered{display:block;margin:25px auto 0}.complete-card{max-width:530px;margin:35px auto;background:white;border:1px solid var(--line);border-radius:14px;padding:42px;text-align:center;box-shadow:0 12px 40px #29476114}.complete-icon{width:70px;height:70px;border-radius:50%;display:grid;place-items:center;margin:0 auto 22px;background:#e7f7f0;color:var(--green);font-size:36px}.complete-card>p:not(.eyebrow){color:var(--muted)}dl{margin:28px 0;text-align:left;background:#f6f8fa;border-radius:9px;padding:8px 18px}dl div{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line)}dl div:last-child{border-bottom:0}dt{color:var(--muted);font-size:12px}dd{margin:0;font-size:13px;font-weight:700}
@media(max-width:760px){.screen{padding:28px 16px}.topbar{padding:0 16px}.user{display:none}.page-heading{align-items:flex-start;gap:20px}.page-heading:not(.compact){flex-direction:column}.summary-grid{grid-template-columns:1fr 1fr}.summary-card:first-child{grid-column:1/-1}.contract-row{grid-template-columns:42px 1fr 24px}.contract-row>div:nth-child(3),.contract-row time{display:none}.field-grid,.review-layout{grid-template-columns:1fr}.steps{display:none}.pdf-page{width:94%}.sign-wrap{padding:22px 16px}.canvas-box{height:220px}.actions{flex-direction:column-reverse}.actions button{width:100%}}

.upload-area{display:flex;min-height:190px;border:2px dashed #a9bac7;border-radius:11px;background:#f9fbfc;align-items:center;justify-content:center;flex-direction:column;gap:8px;text-align:center;cursor:pointer;transition:.2s}
.upload-area:hover,.upload-area.dragging{border-color:var(--blue);background:#f1f7fb}
.upload-area input{display:none}
.upload-area strong{color:var(--blue)}
.upload-area>span:not(.upload-icon){font-size:13px;color:var(--muted)}
.upload-area small{font-size:11px;color:#8c99a4}
.upload-icon,.file-badge{display:grid;place-items:center;color:#d54b40;border:1px solid #edbbb6;background:white;border-radius:7px;font-size:11px;font-weight:800}
.upload-icon{width:50px;height:50px}
.file-info{align-items:center;gap:13px;border:1px solid #cad8e1;border-radius:9px;padding:13px;margin-top:12px}
.file-info:not([hidden]){display:flex}
.file-badge{width:42px;height:42px}
.file-info div{display:flex;flex:1;flex-direction:column;gap:3px}
.file-info small{font-size:11px;color:var(--muted)}
.section-title{margin-top:32px!important;margin-bottom:20px!important}
.pdf-page embed{display:block;width:100%;height:880px;background:white}
.customer-name-field{display:flex;flex-direction:column;gap:9px;margin-top:26px}.customer-name-field label{font-size:14px;font-weight:700}.customer-name-field b{font-size:10px;color:#d94f42;background:#fff0ee;padding:3px 5px;border-radius:4px}.customer-name-field input{width:100%;border:1px solid #b9cbd8;border-radius:8px;padding:14px 15px;font-size:16px}.customer-name-field input:focus{outline:3px solid #d9ebf7;border-color:var(--blue)}.customer-name-field small{font-size:11px;color:var(--muted)}
.reading-mode{width:min(1500px,calc(100vw - 32px));margin-left:50%;transform:translateX(-50%);background:#202a33;border-radius:12px;overflow:hidden;box-shadow:0 12px 35px #172b3e25}
.reading-toolbar{min-height:64px;background:#17212a;color:white;display:flex;align-items:center;justify-content:space-between;padding:12px 24px;gap:20px}
.reading-toolbar>div:first-child{display:flex;flex-direction:column;gap:3px}.reading-toolbar strong{font-size:14px}.reading-toolbar span{font-size:11px;color:#bac7d0}
.read-progress{display:flex;align-items:center;gap:12px}.read-progress progress{width:180px;height:8px;accent-color:#39a875}
.pdf-reader{height:calc(100vh - 230px);min-height:560px;overflow-y:auto;background:#303b44;padding:28px 20px;scroll-behavior:smooth}
.pdf-pages{display:flex;align-items:center;flex-direction:column;gap:24px}.pdf-canvas{display:block;max-width:100%;background:white;box-shadow:0 5px 22px #0008}
.page-shell{position:relative}.page-number{position:absolute;right:12px;bottom:9px;background:#17212acc;color:white;padding:5px 9px;border-radius:14px;font-size:11px}
.signed-mark{position:absolute;left:52%;top:18%;width:25%;height:4.3%;object-fit:contain;object-position:left center;pointer-events:none;z-index:3}
.signed-label{position:absolute;left:73%;top:21.5%;font-size:10px;color:#55636e;background:#ffffffdc;padding:2px 5px;border-radius:4px;z-index:3}
.signed-date-part{position:absolute;top:4.72%;font-size:18px;font-weight:700;color:#30383e;line-height:1;text-align:center;pointer-events:none;z-index:3}
.signed-year{left:71.7%;width:4%}
.signed-month{left:77.4%;width:4%}
.signed-day{left:83.4%;width:4%}
.contract-date-field{display:flex;flex-direction:column;gap:8px;margin:0 0 25px}.contract-date-field label{font-size:13px;font-weight:700}.contract-date-field b{font-size:10px;color:#d94f42;background:#fff0ee;padding:3px 5px;border-radius:4px}.contract-date-field input{width:min(320px,100%);padding:12px;border:1px solid #b9cbd8;border-radius:8px;background:white}.contract-date-field small{font-size:11px;color:var(--muted)}
.reader-end{width:min(820px,100%);margin:25px auto 0;padding:22px;background:#eaf6f1;color:var(--green);text-align:center;border-radius:8px;font-weight:800}
.review-gate{background:white;padding:18px 24px;display:grid;grid-template-columns:minmax(200px,1fr) minmax(360px,1.6fr) auto;gap:20px;align-items:center}
.customer-summary{display:flex;flex-direction:column;gap:4px}.customer-summary span{font-size:11px;color:var(--muted)}.customer-summary strong{font-size:13px}
.review-agreement{display:flex;align-items:center;gap:12px;padding:12px 15px;border:1px solid #b8d8c9;background:#f2fbf7;border-radius:8px;cursor:pointer}.review-agreement.disabled{border-color:#d7dee4;background:#f5f6f7;color:#8b979f;cursor:not-allowed}
.review-agreement input{width:21px;height:21px;accent-color:var(--green)}.review-agreement span{display:flex;flex-direction:column;gap:3px}.review-agreement strong{font-size:13px}.review-agreement small{font-size:11px;color:var(--muted)}
@media(max-width:900px){.reading-toolbar{align-items:flex-start;flex-direction:column}.read-progress{width:100%;justify-content:space-between}.read-progress progress{flex:1}.pdf-reader{height:68vh;min-height:480px;padding:15px 8px}.review-gate{grid-template-columns:1fr}.review-gate button{width:100%}}

.contract-row.clickable{cursor:pointer}
.contract-row.clickable:hover{background:#f3f8fc}
.contract-row.clickable:focus{outline:3px solid #77add5;outline-offset:-3px}
.reader-screen{max-width:none;padding:12px 0 0}
.reader-screen>.back,.reader-screen>.page-heading{margin-left:18px;margin-right:18px}
.reader-screen .page-heading{margin-bottom:12px}
.reader-screen .reading-mode{width:100%;margin:0;transform:none;border-radius:0}
.reader-screen .pdf-reader{height:calc(100vh - 245px);padding:8px 4px}
.reader-screen .pdf-canvas{width:min(100%,1200px);height:auto}

@media(max-width:900px){
  .reader-screen{padding-top:6px}
  .reader-screen>.back{margin:0 10px 5px}
  .reader-screen>.page-heading{margin:0 10px 8px}
  .reader-screen>.page-heading p,.reader-screen .eyebrow{display:none}
  .reader-screen>.page-heading h1{font-size:20px}
  .reader-screen .reading-toolbar{min-height:50px;padding:8px 12px;flex-direction:row;align-items:center}
  .reader-screen .reading-toolbar>div:first-child span{display:none}
  .reader-screen .read-progress{flex:1;justify-content:flex-end}
  .reader-screen .read-progress progress{width:100px;flex:none}
  .reader-screen .pdf-reader{height:calc(100vh - 230px);min-height:430px;padding:0}
  .reader-screen .pdf-pages{gap:8px}
  .reader-screen .pdf-canvas{width:100%;max-width:none;box-shadow:none}
  .reader-screen .review-gate{position:sticky;bottom:0;z-index:5;grid-template-columns:1fr;padding:9px 10px;gap:7px}
  .reader-screen .customer-summary{display:none}
  .reader-screen .review-agreement{padding:8px 10px}
  .reader-screen .review-agreement small{display:none}
  .reader-screen .review-gate button{width:100%;padding:14px}
  .reader-screen .reading-mode{box-shadow:none}
}

.header-actions{display:flex;align-items:center;gap:20px}
.user{display:flex;align-items:center;gap:8px}.user small{color:#fff;background:var(--green);border-radius:12px;padding:3px 8px;font-size:10px}
.home-button{border:1px solid #cbd8e1;background:#f7fafc;color:var(--navy);padding:9px 14px}
.home-button:hover{background:#eaf3f9;border-color:#9db9cc}
.login-screen{position:fixed;inset:0;z-index:100;background:#eef3f7;display:grid;place-items:center;padding:20px}.login-screen.hidden{display:none}.login-card{width:min(430px,100%);background:white;border:1px solid var(--line);border-radius:15px;padding:38px;box-shadow:0 18px 55px #17324c22}.login-mark{margin-bottom:20px}.login-card h1{margin:0 0 8px;color:var(--navy);font-size:25px}.login-card p{margin:0 0 26px;color:var(--muted)}.login-card label{display:block;font-size:13px;font-weight:700;margin-bottom:8px}.login-card select{width:100%;padding:13px;border:1px solid #bdccd7;border-radius:8px;background:white;margin-bottom:12px}.staff{font-size:11px!important;color:#496b83!important;font-weight:700}
@media(max-width:760px){
  .home-button{padding:9px 11px;font-size:13px}
}

.contract-row{grid-template-columns:50px minmax(280px,1fr) 160px 110px 110px 24px}
.staff-column{display:flex;flex-direction:column;gap:4px;padding-left:20px;border-left:1px solid #e0e7ec}
.staff-column span{font-size:11px;color:var(--muted)}
.staff-column strong{font-size:16px;color:var(--navy);white-space:nowrap}
.password-field{display:flex;align-items:center;border:1px solid #bdccd7;border-radius:8px;background:white;margin-bottom:4px}
.password-field:focus-within{outline:3px solid #d9ebf7;border-color:var(--blue)}
.password-field input{flex:1;min-width:0;padding:13px;border:0;outline:0;background:transparent}
.password-field button{padding:8px 12px}
.login-error{margin:7px 0 0!important;color:#c74438!important;font-size:12px}
.login-password-hint{display:block;margin:7px 0 2px;color:#577187;font-size:12px}
.empty-state,.loading-state{padding:40px;text-align:center;color:var(--muted)}
.account-panel{max-width:620px;margin:auto;padding:30px}.account-panel>label,.member-add-panel>label{display:flex;flex-direction:column;gap:8px;margin-bottom:18px;font-size:13px;font-weight:700}.account-panel input,.member-add-panel input{width:100%;padding:12px 14px;border:1px solid #bdccd7;border-radius:8px}.account-panel>small,.member-add-panel>small{display:block;color:var(--muted);font-size:11px}.form-message{padding:11px 13px;border-radius:7px;font-size:12px}.form-message.success{color:#126b49;background:#e7f7f0}.form-message.error{color:#a23b32;background:#fff0ee}
.member-layout{display:grid;grid-template-columns:360px 1fr;gap:20px;align-items:start}.member-add-panel,.member-list-panel{padding:26px}.member-add-panel h2,.member-list-panel h2{margin:0 0 22px;color:var(--navy);font-size:18px}.temporary-password-row{display:flex;gap:8px}.temporary-password-row input{flex:1;min-width:0}.temporary-password-row button{white-space:nowrap}.member-list-heading{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:14px}.member-list-heading h2{margin:0}.member-list-heading span{font-size:11px;color:var(--green);font-weight:700}.member-row{display:flex;justify-content:space-between;align-items:center;gap:15px;padding:16px 0;border-bottom:1px solid var(--line)}.member-row:last-child{border-bottom:0}.member-row>div:first-child{display:flex;flex-direction:column;gap:5px}.member-row strong{color:var(--navy)}.member-row span{font-size:11px;color:var(--muted)}.member-row.inactive{opacity:.55}.member-actions{display:flex;gap:8px}.member-actions button{font-size:11px;padding:8px 11px}.danger-button{color:#a23b32;background:#fff;border-color:#e6b5b0}

@media(max-width:760px){
  .contract-row{grid-template-columns:42px 1fr 24px}
  .contract-row .staff-column{grid-column:2;padding:3px 0 0;border:0}
  .contract-row .staff-column span{display:none}
  .contract-row .staff-column strong{font-size:13px}
  .contract-row .staff-column strong::before{content:"担当者：";font-size:11px;color:var(--muted)}
  .header-actions{gap:6px}.header-actions .home-button{font-size:11px;padding:8px}.member-layout{grid-template-columns:1fr}.member-row{align-items:flex-start;flex-direction:column}.member-actions{width:100%}.member-actions button{flex:1}
}
