@charset "utf-8";
/* Estimate flow internals (.sim). Pairs with /en/assets/en.css.
   Adapted from the Japanese simulator_new.php / form_new.php. */
.sim{color:var(--ink)}
.sim *{box-sizing:border-box}
.sim .wrap{max-width:1120px}
.sim .formwrap{max-width:920px;margin:0 auto;padding:0 24px}

.sim .pagehead{background:linear-gradient(100deg,var(--red),#e8512f);color:#fff;padding:34px 30px 30px;position:relative;overflow:hidden;border-radius:12px;margin-bottom:6px}
.sim .pagehead .en,.sim .pagehead h1,.sim .pagehead p{position:relative;z-index:1}
.sim .pagehead::after{content:"";position:absolute;right:-40px;top:-40px;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.10)}
.sim .pagehead::before{content:"";position:absolute;right:90px;bottom:-70px;width:160px;height:160px;border-radius:50%;background:rgba(91,189,180,.35)}
.sim .pagehead .en{font-size:.72rem;letter-spacing:.3em;opacity:.85;font-weight:700;text-transform:uppercase}
.sim .pagehead h1{font-size:clamp(1.4rem,3.6vw,2.1rem);font-weight:900;letter-spacing:.01em;margin-top:6px;color:#fff}
.sim .pagehead p{margin-top:9px;font-size:.95rem;opacity:.95}

.sim .steps{display:flex;margin:26px 0 30px;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.sim .steps div{flex:1;text-align:center;padding:13px 6px;font-size:.78rem;font-weight:800;color:var(--gray);background:var(--bg)}
.sim .steps div.on{background:var(--teal);color:#fff}
.sim .steps div b{display:block;font-size:.7rem;color:var(--red);letter-spacing:.1em}
.sim .steps div.on b{color:#fff}

.sim .grid{display:grid;grid-template-columns:1fr 380px;gap:26px;margin-bottom:40px;align-items:start}
.sim .card{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden;margin-bottom:22px}
.sim .card > h3{font-size:1rem;font-weight:900;color:#fff;background:var(--red);padding:13px 20px;letter-spacing:.02em;display:flex;align-items:center;gap:9px;margin:0}
.sim .card > h3 .n{background:#fff;color:var(--red);width:22px;height:22px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:.78rem;flex-shrink:0}
.sim .card .inner{padding:22px 22px 6px}
.sim .card .lead{font-size:.82rem;color:var(--gray);margin:-6px 0 16px;line-height:1.6}

.sim .field{margin-bottom:20px}
.sim .field > label,.sim .field > label.flbl{display:block;font-size:.84rem;font-weight:800;color:var(--ink);margin-bottom:8px}
.sim .req{background:var(--red);color:#fff;font-size:.58rem;padding:2px 7px;border-radius:3px;margin-left:7px;vertical-align:2px;font-weight:800;letter-spacing:.04em}
.sim .opt{background:var(--teal);color:#fff;font-size:.58rem;padding:2px 7px;border-radius:3px;margin-left:7px;vertical-align:2px;font-weight:800;letter-spacing:.04em}

.sim .seg,.sim .input-choice{display:flex;flex-wrap:wrap;gap:8px}
.sim .seg label,.sim .input-choice label{font-size:.85rem;font-weight:600;color:var(--ink);background:#fff;border:1.5px solid var(--line);padding:10px 16px;border-radius:8px;cursor:pointer;transition:.15s;display:inline-flex;align-items:center;gap:7px;margin:0}
.sim .seg label:hover,.sim .input-choice label:hover{border-color:var(--teal)}
.sim .seg label.on,.sim .input-choice label.on{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 4px 10px -5px var(--teal-d)}
.sim .seg input,.sim .input-choice input[type=radio]{position:absolute;opacity:0;width:0;height:0}
.sim .input-choice input[type=checkbox],.sim .optchecks input{width:17px;height:17px;accent-color:var(--teal);cursor:pointer}
.sim .optchecks{display:flex;flex-wrap:wrap;gap:8px}
.sim .optchecks label{display:inline-flex;align-items:center;gap:7px;font-size:.83rem;font-weight:600;color:var(--ink);background:#fff;border:1.5px solid var(--line);padding:8px 13px;border-radius:8px;cursor:pointer;margin:0}

.sim input[type=text].sim-inp,.sim input[type=number].sim-inp,.sim input[type=text].input-text,.sim input[type=tel].input-text,.sim input[type=email].input-text,.sim input[type=number].input-text{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;transition:.15s}
.sim input.sim-inp:focus,.sim input.input-text:focus,.sim select.input-select:focus,.sim textarea.input-textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(91,189,180,.18)}
.sim select.input-select{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px}
.sim textarea.input-textarea{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;line-height:1.6}
.sim .hint{font-size:.74rem;color:var(--gray);margin-top:6px;line-height:1.6}

.sim .frow{display:grid;grid-template-columns:210px 1fr;gap:16px;align-items:start;padding:16px 0;border-bottom:1px dashed var(--line)}
.sim .frow:last-child{border-bottom:none}
.sim .frow > .fk{font-size:.85rem;font-weight:800;color:var(--ink);padding-top:10px;line-height:1.5}
.sim .frow > .fv{min-width:0}
.sim .frow > .fv .val{padding-top:10px;font-weight:700}

.sim .route{position:relative}
.sim .stop{position:relative;margin-bottom:13px}
.sim .stop label{font-size:.72rem;font-weight:800;color:var(--teal-d);display:block;margin-bottom:4px}
.sim .stop.start label,.sim .stop.goal label{color:var(--red)}
.sim .routenote{font-size:.74rem;color:var(--gray);background:#f0faf9;border-left:3px solid var(--teal);padding:9px 12px;border-radius:0 6px 6px 0;margin:4px 0 16px;line-height:1.6}
.sim .leg{border:1px solid var(--line);border-radius:10px;padding:16px 16px 8px;margin-bottom:14px;background:#fff}
.sim .legtitle{font-size:.82rem;font-weight:900;color:var(--teal-d);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.sim .legtitle .b{background:var(--teal);color:#fff;font-size:.66rem;padding:3px 11px;border-radius:999px;letter-spacing:.04em}
.sim .timerow{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:6px 0 4px}
.sim .timerow.three{grid-template-columns:1fr 1fr 1fr}
.sim .timerow .tlbl{font-size:.72rem;font-weight:800;color:var(--ink);margin-bottom:6px;display:block}
.sim .flatpickr-group{position:relative}
.sim .flatpickr-group input{width:100%;font-family:var(--sans);font-size:.95rem;color:var(--ink);background:#fff;border:1.5px solid var(--line);border-radius:8px;padding:11px 13px;cursor:pointer}
.sim .flatpickr-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--gray);cursor:pointer;font-size:1.1rem}

.sim .mapwrap{margin:16px 0 6px}
.sim .mapmeta{display:flex;gap:18px;flex-wrap:wrap;font-size:.82rem;color:var(--ink);margin-top:10px;padding:10px 14px;background:var(--bg);border:1px solid var(--line);border-radius:8px}
.sim .mapmeta b{color:var(--teal-d)}
.sim .mapmeta input{width:64px;border:1px solid var(--line);border-radius:5px;padding:4px 6px;font-family:var(--sans);font-size:.85rem;text-align:right;background:#fff}

.sim .result{position:sticky;top:90px;border-radius:12px;overflow:hidden;border:1px solid var(--line)}
.sim .result .rhead{background:var(--teal);color:#fff;padding:14px 20px;font-weight:900;font-size:.95rem;letter-spacing:.02em}
.sim .result .rbody{padding:22px 20px;background:#fff}
.sim .est-lbl{font-size:.74rem;color:var(--gray);font-weight:800}
.sim .est{font-weight:900;color:var(--red);line-height:1.05;margin:8px 0 2px;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap}
.sim .est .y{font-size:1.3rem}
.sim .est .num{font-size:2.8rem}
.sim .est-tax{font-size:.76rem;color:var(--gray)}
.sim .bd{margin:18px 0 0;border-top:1px dashed var(--line);padding-top:14px}
.sim .brow{display:flex;justify-content:space-between;align-items:baseline;padding:6px 0;font-size:.84rem;color:var(--ink)}
.sim .brow span:last-child{font-weight:700}
.sim .brow.sub span:first-child{padding-left:12px;color:var(--gray);font-size:.78rem}
.sim .brow.sub span:last-child{color:var(--teal-d)}
.sim .tollbox{margin-top:10px;background:#fff8f3;border:1px solid #f3d9c9;border-radius:8px;padding:10px 14px}
.sim .tollbox .brow{padding:2px 0}
.sim .tollnote{font-size:.7rem;color:var(--red-d);margin-top:4px;line-height:1.55}
.sim .rnote{font-size:.7rem;color:var(--gray);margin-top:12px;line-height:1.6}
.sim .cta{display:block;width:100%;margin-top:18px;text-align:center;cursor:pointer;font-family:var(--sans);font-weight:900;font-size:1rem;letter-spacing:.02em;color:#fff;background:var(--red);border:none;padding:15px;border-radius:10px;transition:.18s;box-shadow:0 8px 18px -8px var(--red)}
.sim .cta:hover{background:var(--red-d);transform:translateY(-1px)}
.sim .cta small{display:block;font-weight:500;font-size:.66rem;opacity:.9;margin-top:3px}
.sim .timewarn{font-size:.78rem;font-weight:700;color:#D72A15;background:#fff5f3;border:1px solid #f3c9c0;border-radius:8px;padding:9px 12px;margin:10px 0}

.sim .agreement{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:20px 22px;margin:8px 0 26px}
.sim .agreement-text{font-size:.84rem;color:var(--ink);line-height:1.7;margin-bottom:12px}
.sim .agreement-text a{color:var(--teal-d);font-weight:800;text-decoration:underline}
.sim .agreement-check{display:flex;align-items:center;gap:9px;font-size:.9rem;font-weight:800}
.sim .agreement-check input{width:18px;height:18px;accent-color:var(--teal);cursor:pointer}
.sim .submitrow{text-align:center;margin:0 0 60px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.sim .submitrow .cta{display:inline-block;width:auto;min-width:300px}
.sim .back{display:inline-block;padding:15px 28px;border-radius:10px;border:1.5px solid var(--line);font-weight:800;color:var(--gray);background:#fff}
.sim .back:hover{border-color:var(--teal);color:var(--teal-d)}

.sim .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.sim .coordnote{display:flex;gap:14px;align-items:center;background:#fff1ec;border:2px solid var(--red);border-radius:10px;padding:14px 18px;margin:0 0 22px}
.sim .coordnote .ic{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:900;font-size:1.2rem}
.sim .coordnote .tx b{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--red-d);margin-bottom:2px}
.sim .coordnote .tx p{font-size:.9rem;font-weight:700;color:#7a1f12;line-height:1.55;margin:0}

@media(max-width:880px){.sim .grid{grid-template-columns:1fr}.sim .result{position:static}.sim .timerow,.sim .timerow.three{grid-template-columns:1fr}.sim .frow{grid-template-columns:1fr;gap:8px}.sim .frow > .fk{padding-top:0}}
