*{box-sizing:border-box}body{margin:0;background:#f7faff;color:#0f2240;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Noto Sans JP",sans-serif;display:flex}a{text-decoration:none;color:inherit}aside{width:238px;min-height:100vh;background:linear-gradient(#08234a,#06203e);color:#fff;padding:26px 18px;position:fixed}.brand{display:flex;gap:12px;align-items:center;margin-bottom:38px}.logo{width:42px;height:42px;border-radius:12px;background:#1f5eff;display:grid;place-items:center;font-weight:900;font-size:20px}.brand h1{font-size:18px;margin:0}.brand p{margin:4px 0 0;color:#c9d6ee;font-size:13px}nav a{display:block;padding:16px;border-radius:10px;margin-bottom:10px;font-weight:800;color:white}.nav-on{background:#1e56e8}nav span{float:right;background:#ff4057;border-radius:999px;padding:2px 7px}.copy{position:absolute;bottom:28px;font-size:12px;color:#a9bad5}main{margin-left:238px;width:calc(100% - 238px);padding:0 30px 30px}header{height:70px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e4ebf5}.breadcrumb{color:#6c7890}.user{text-align:right;font-weight:900}.user span{font-size:12px;color:#6d7c93}.hero,.project-head{display:flex;justify-content:space-between;gap:24px;padding:25px 0}.hero em{color:#1e56e8;font-style:normal;font-weight:900;font-size:13px}h2{font-size:30px;margin:6px 0 8px}.project-head h2{font-size:28px;margin:18px 0 8px}.status-pill{font-style:normal;color:#24964d;background:#e8f7ec;border:1px solid #6abe7a;border-radius:999px;font-size:14px;padding:5px 14px;margin-left:12px}button,.btn{background:#1e56e8;color:white;border:0;border-radius:10px;padding:13px 18px;font-weight:900;cursor:pointer}.btn-white{background:white;color:#0b49cf;border:1px solid #dce4ee}.kpis,.summary,.tabs,.panel,.case-tabs,.bottom,.info-strip{background:white;border:1px solid #dfe7f2;border-radius:13px;box-shadow:0 8px 22px rgba(16,42,67,.05)}.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-bottom:18px;overflow:hidden}.kpis div{padding:18px;border-right:1px solid #e8eef7}.kpis div:last-child{border-right:0}.kpis span,.summary small,.info-strip small{display:block;color:#70809a;font-weight:800}.kpis strong{display:block;font-size:32px;margin-top:8px}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.panel{padding:20px;margin-bottom:16px}.panel-head,.panel-title{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.panel h3{margin:0 0 10px;font-size:20px}.panel p{color:#5d6c84}.todo{line-height:2}.focus-card,.risk-card,.action-card{padding:14px;border:1px solid #e3ebf5;border-radius:12px;background:#fbfdff;margin-bottom:10px}.case-tabs,.tabs{display:grid;grid-template-columns:1fr 1fr;overflow:hidden;margin-bottom:16px}.tabs{grid-template-columns:repeat(4,1fr)}.case-tab,.tab{border:0;background:white;color:#22324d;padding:20px;font-size:17px;font-weight:900;cursor:pointer;border-bottom:4px solid transparent;border-radius:0}.case-tab.active,.tab.active{color:#0b49cf;border-bottom-color:#1e56e8;background:#fbfdff}.filters button,.small{background:#f4f7fb;border:1px solid #dfe7f2;border-radius:8px;padding:9px 12px;font-weight:800;color:#334766}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;color:#6d7c93;border-bottom:1px solid #e4ebf4;padding:12px}td{border-bottom:1px solid #e4ebf4;padding:13px 12px;vertical-align:middle}tbody tr:hover{background:#fbfdff}.clickable tbody tr:hover{cursor:pointer}.badge,.pill{border-radius:999px;padding:5px 10px;font-weight:900;font-size:12px;white-space:nowrap}.green,.done{background:#e8f7ec;color:#208146}.yellow,.yes{background:#fff4d8;color:#9a680c}.blue,.doing{background:#e6efff;color:#1e56e8}.red{background:#ffe5e8;color:#c91f37}.gray,.wait,.unknown{background:#eef2f7;color:#667085}.no{background:#e8f7ec;color:#208146}.progress{height:9px;width:130px;border-radius:999px;background:#edf2f8;overflow:hidden}.progress i{display:block;height:100%;border-radius:999px;background:#1e56e8}.back{color:#0b49cf;font-weight:800;font-size:13px}.summary{display:grid;grid-template-columns:repeat(7,1fr);padding:16px;margin-bottom:18px}.summary div{border-right:1px solid #e8eef7;padding:0 16px}.summary div:last-child{border-right:0}.summary strong{display:block;margin-top:8px}.bar{height:9px;background:#edf2f8;border-radius:999px;margin-top:9px}.bar i{display:block;height:100%;background:#194bc7;border-radius:999px}.actions{display:flex;gap:12px;align-items:flex-start}.tabpage{display:none}.tabpage.active{display:block}.content-grid{display:grid;grid-template-columns:1.45fr .85fr;gap:16px}.score{font-size:56px;font-weight:900;color:#1e56e8}.memo{border:1px solid #e2e9f3;border-radius:10px;padding:15px;margin-top:14px;line-height:1.8}.timeline{border-left:3px solid #1e56e8;padding-left:22px}.timeline div{position:relative;padding:12px 0 18px}.timeline div:before{content:"";position:absolute;left:-30px;top:17px;width:13px;height:13px;border-radius:50%;background:#1e56e8}.timeline time{display:block;color:#6e7f98;font-weight:800;margin-bottom:7px}.survey-layout{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}.fake-map{height:310px;border:1px solid #dfe7f2;border-radius:10px;background:linear-gradient(25deg,#fff,#f1f4f8);position:relative;overflow:hidden}.fake-map:before{content:"";position:absolute;inset:0;background-image:linear-gradient(70deg,transparent 48%,#d4dbe6 49%,transparent 50%),linear-gradient(15deg,transparent 48%,#d4dbe6 49%,transparent 50%);background-size:90px 70px}.parcel{position:absolute;left:32%;top:18%;width:150px;height:210px;border:3px solid #ff4949;transform:rotate(-14deg);background:rgba(255,80,80,.04)}.fake-map button{position:absolute;bottom:16px;left:16px;border:0;background:white;color:#0b49cf;border-radius:8px;padding:10px 18px;font-weight:900}.file-list div{padding:12px;border:1px solid #e3eaf3;background:#f8fbff;border-radius:8px;margin-bottom:9px;font-weight:800}.file-list small{color:#71819b}.steps{list-style:none;padding:0;margin:0}.steps li{display:grid;grid-template-columns:1fr 76px 118px;gap:10px;padding:14px;border-bottom:1px solid #e6edf5}.done-text{color:#16a34a;font-weight:900}.doing-text{color:#1e56e8;font-weight:900}.wait-text{color:#8a95a8;font-weight:900}.bottom{display:grid;grid-template-columns:1.15fr 1.55fr 120px;gap:12px;align-items:center;padding:15px;background:#eef6ff}.map-demo{height:360px;border-radius:15px;border:1px solid #dfe7f2;background:linear-gradient(135deg,#e5eef6,#fff);position:relative;overflow:hidden}.map-demo:before{content:"";position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(31,78,120,.08) 1px,transparent 1px),linear-gradient(rgba(31,78,120,.08) 1px,transparent 1px);background-size:44px 44px}.pin{position:absolute;background:#1e56e8;color:white;padding:8px 12px;border-radius:999px;font-weight:900}.p1{top:80px;left:58%}.p2{top:140px;left:48%}.p3{top:250px;left:42%}.p4{top:165px;left:36%}@media(max-width:1200px){.summary,.kpis{grid-template-columns:repeat(2,1fr)}.summary div,.kpis div{border-right:0;border-bottom:1px solid #e8eef7;padding:12px}.content-grid,.grid2,.survey-layout{grid-template-columns:1fr}.hero,.project-head{display:block}.actions{margin-top:16px}}@media(max-width:800px){aside{position:static;width:100%;min-height:auto}.copy{position:static;margin-top:28px}body{display:block}main{margin-left:0;width:100%}.tabs,.case-tabs,.bottom{grid-template-columns:1fr}}

/* login.html */
body.login-page{
  min-height:100vh;
  display:grid;
  place-items:center;
  padding:28px;
  background:
    radial-gradient(circle at 18% 18%, rgba(30,86,232,.18), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(8,35,74,.16), transparent 32%),
    linear-gradient(135deg,#f7faff,#eef6ff 46%,#f8fbff);
  position:relative;
  overflow:hidden;
}

.login-bg-shape{
  position:fixed;
  border-radius:999px;
  pointer-events:none;
  filter:blur(.2px);
}

.shape-1{
  width:360px;
  height:360px;
  left:-130px;
  bottom:-130px;
  background:rgba(30,86,232,.10);
}

.shape-2{
  width:280px;
  height:280px;
  right:-90px;
  top:90px;
  background:rgba(8,35,74,.10);
}

.login-shell{
  width:min(640px,100%);
  margin:auto;
  position:relative;
  z-index:1;
}

.login-visual{
  background:
    radial-gradient(circle at 88% 14%, rgba(255,255,255,.18), transparent 26%),
    linear-gradient(160deg,#08234a,#1e56e8);
  color:#fff;
  padding:60px;
  border-radius:28px;
  box-shadow:0 26px 70px rgba(16,42,67,.20);
  position:relative;
  overflow:hidden;
}

.login-visual:before{
  content:"";
  position:absolute;
  right:-100px;
  bottom:-130px;
  width:340px;
  height:340px;
  border-radius:50%;
  background:rgba(255,255,255,.12);
}

.login-visual:after{
  content:"";
  position:absolute;
  left:42px;
  bottom:42px;
  width:110px;
  height:110px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:30px;
  transform:rotate(18deg);
}

.login-brand{
  margin-bottom:54px;
  position:relative;
  z-index:1;
}

.company-logo{
  width:52px;
  height:52px;
  display:grid;
  place-items:center;
}

.company-logo svg{
  width:52px;
  height:52px;
  display:block;
}

.company-logo rect{
  fill:#fff;
}

.company-logo path{
  fill:#1e56e8;
}

.login-visual .brand h1,
.login-visual h2,
.login-visual .lead{
  color:white;
  position:relative;
  z-index:1;
}

.login-visual h2{
  font-size:34px;
  line-height:1.35;
  margin:0 0 12px;
  letter-spacing:.02em;
}

.login-visual .lead{
  color:#dce8ff;
  line-height:1.9;
  margin-bottom:26px;
}

.login-form{
  position:relative;
  z-index:1;
}

.error-message{
  display:none;
  margin-bottom:16px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.32);
  color:#fff;
  font-weight:800;
  line-height:1.6;
}

.error-message.show{
  display:block;
}

.login-form label{
  display:block;
  margin:16px 0 8px;
  color:white;
  font-weight:900;
  font-size:14px;
}

.input-wrap{
  position:relative;
}

.input-icon{
  position:absolute;
  left:15px;
  top:50%;
  transform:translateY(-50%);
  font-size:17px;
  opacity:.78;
  z-index:1;
}

.login-form input[type="text"],
.login-form input[type="password"]{
  width:100%;
  height:52px;
  border:1px solid rgba(255,255,255,.32);
  border-radius:14px;
  padding:0 48px;
  font-size:16px;
  outline:none;
  background:rgba(255,255,255,.96);
  color:#0f2240;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease, transform .18s ease;
}

.login-form input[type="text"]:focus,
.login-form input[type="password"]:focus{
  border-color:white;
  box-shadow:0 0 0 4px rgba(255,255,255,.20);
  background:white;
}

.password-toggle{
  position:absolute;
  right:8px;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  border:0;
  border-radius:10px;
  background:transparent;
  color:#0f2240;
  font-size:17px;
  padding:0;
  cursor:pointer;
}

.password-toggle:hover{
  background:#eef4ff;
}

.login-options{
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
  margin:18px 0 22px;
  color:#dce8ff;
  font-size:14px;
}

.login-options label{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0;
  font-weight:800;
  color:#dce8ff;
}

.login-options input{
  accent-color:#fff;
}

.login-options a{
  color:white;
  font-weight:900;
  white-space:nowrap;
  text-decoration:underline;
  text-underline-offset:3px;
}

.login-button{
  width:100%;
  height:54px;
  font-size:16px;
  background:white;
  color:#0b49cf;
  border:0;
  border-radius:14px;
  box-shadow:0 10px 26px rgba(6,32,62,.20);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.login-button:hover{
  transform:translateY(-2px);
  background:#f4f8ff;
  box-shadow:0 16px 34px rgba(6,32,62,.26);
}

.login-button:active{
  transform:translateY(0);
  box-shadow:0 8px 20px rgba(6,32,62,.18);
}

@media(prefers-color-scheme:dark){
  body.login-page{
    background:
      radial-gradient(circle at 18% 18%, rgba(30,86,232,.20), transparent 28%),
      radial-gradient(circle at 82% 12%, rgba(98,142,255,.12), transparent 32%),
      linear-gradient(135deg,#071225,#0c1b33 48%,#08101f);
  }

  .login-visual{
    box-shadow:0 26px 70px rgba(0,0,0,.40);
  }

  .login-form input[type="text"],
  .login-form input[type="password"]{
    background:rgba(255,255,255,.92);
  }
}

@media(max-width:900px){
  body.login-page{
    padding:20px;
    display:grid;
    place-items:center;
  }

  .login-shell{
    width:100%;
  }

  .login-visual{
    padding:36px 24px;
    border-radius:24px;
  }

  .login-brand{
    margin-bottom:34px;
  }

  .login-visual h2{
    font-size:28px;
  }

  .login-options{
    display:block;
  }

  .login-options a{
    display:inline-block;
    margin-top:12px;
  }
}
