:root{
  --ink:#2d221d;
  --muted:#735c4d;
  --paper:#fff2d2;
  --paper2:#f8dfac;
  --green:#1f6b6a;
  --red:#bf432e;
  --gold:#d19a3b;
  --purple:#59416f;
  --line:rgba(139,95,43,.26);
  --shadow:0 24px 60px rgba(73,43,27,.22);
}
*{box-sizing:border-box}
[hidden]{display:none!important}
html,body{margin:0;min-height:100%;font-family:"Zen Kaku Gothic New",system-ui,sans-serif;color:var(--ink);background:#e8c890}
body{overflow-x:hidden}
button,a{font:inherit}
button{cursor:pointer}
.back-link{
  position:fixed;top:12px;left:12px;z-index:80;display:inline-flex;align-items:center;min-height:38px;
  padding:0 14px;border-radius:999px;background:rgba(255,248,230,.96);border:1px solid var(--line);
  color:var(--ink);font-weight:900;text-decoration:none;box-shadow:0 8px 18px rgba(73,43,27,.14);
}
.app{
  min-height:100svh;padding:14px;display:grid;place-items:center;
  background:linear-gradient(145deg,#fff1d0 0%,#e6c089 56%,#c17f61 100%);
}
.screen{
  position:relative;width:min(100%,1600px);aspect-ratio:16/9;max-height:calc(100svh - 28px);
  overflow:hidden;border-radius:18px;border:1px solid rgba(139,95,43,.25);box-shadow:0 28px 90px rgba(73,43,27,.2);
  background:#f8e6bf;
}
.screen::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.38;
  background:
    radial-gradient(circle at 12% 16%,rgba(255,255,255,.65),transparent 18rem),
    radial-gradient(circle at 86% 14%,rgba(255,255,255,.42),transparent 18rem),
    repeating-linear-gradient(105deg,transparent 0 52px,rgba(139,95,43,.08) 53px 54px);
}
.eyebrow{margin:0 0 12px;color:#bd633c;font:900 13px/1.3 "Zen Kaku Gothic New",sans-serif;letter-spacing:.18em}
h1,h2,h3{font-family:"Shippori Mincho",serif;letter-spacing:0;margin:0}

.primary,.secondary{
  min-height:58px;border:0;text-decoration:none;font-weight:900;display:inline-flex;align-items:center;justify-content:center;
  gap:10px;padding:0 28px;color:#fff8e9;text-shadow:0 2px 0 rgba(60,32,20,.36);
  background:transparent url("./img/v2/ui/ui-start.png") center/100% 100% no-repeat;
  transition:transform .16s ease,filter .16s ease;
}
.primary:hover,.secondary:hover{transform:translateY(-2px);filter:saturate(1.08)}
.primary span{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.18)}
.secondary{background-image:url("./img/v2/ui/ui-share.png");color:#31231c;text-shadow:0 1px 0 rgba(255,248,230,.75)}

/* title */
.intro{
  background:
    linear-gradient(90deg,rgba(255,241,211,.86),rgba(255,241,211,.12) 52%,rgba(255,241,211,.18)),
    url("./img/rebuild/title-bg-v4.png") center/cover no-repeat;
}
.ambient{position:absolute;z-index:2;pointer-events:none;width:11%;height:22%;background:url("./img/v2/fx/fx-steam.png") center/contain no-repeat;opacity:.62;filter:drop-shadow(0 16px 18px rgba(255,255,255,.65))}
.steam-a{left:6%;bottom:4%}
.steam-b{right:18%;top:7%}
.intro-copy{position:absolute;z-index:4;left:4.2%;top:17%;width:43%;max-width:640px}
.intro h1{
  width:max-content;max-width:100%;padding:8px 4px 6px;
  font-size:clamp(64px,6.8vw,112px);line-height:.92;
  text-shadow:0 2px 0 rgba(255,248,230,.9),0 10px 0 rgba(46,34,29,.08),0 22px 30px rgba(73,43,27,.16);
}
.intro h1 span{display:block;white-space:nowrap}
.subtitle{margin:3% 0 5%;font-size:clamp(18px,1.85vw,28px);line-height:1.9;font-weight:900}
.mission-picker{display:flex;gap:12px;flex-wrap:wrap;margin:0 0 5%}
.mission-chip{
  min-height:42px;padding:0 14px;border:0;border-radius:999px;font-weight:900;color:#fff6e6;
  background:transparent url("./img/v2/ui/ui-chip-default.png") center/100% 100% no-repeat;text-shadow:0 2px 0 rgba(20,16,12,.55);
}
.mission-chip.is-selected{color:#fff8e9;background-image:url("./img/v2/ui/ui-chip-selected.png")}
.start-btn{min-width:330px;font-size:24px}
.intro-map{
  position:absolute;z-index:2;right:3.2%;top:7%;width:49%;transform:rotate(7deg);
  filter:drop-shadow(0 28px 26px rgba(73,43,27,.2));
  display:none;
}
.intro-map img{display:block;width:100%;border-radius:22px}
.intro-cards{position:absolute;z-index:3;right:4.5%;bottom:5%;width:37%;display:flex;align-items:flex-end;gap:2.5%}
.intro-cards img{width:31%;filter:drop-shadow(0 22px 22px rgba(73,43,27,.22))}
.intro-cards img:nth-child(1){transform:rotate(-7deg) translateY(5%)}
.intro-cards img:nth-child(2){transform:rotate(2deg)}
.intro-cards img:nth-child(3){transform:rotate(9deg) translateY(4%)}

/* game */
.play{
  background:
    radial-gradient(circle at 50% 22%,rgba(255,255,255,.46),transparent 28rem),
    radial-gradient(circle at 86% 78%,rgba(116,142,120,.15),transparent 23rem),
    radial-gradient(circle at 8% 88%,rgba(196,91,59,.12),transparent 18rem),
    linear-gradient(180deg,#fff1d0 0%,#f9e2b5 58%,#f2d49d 100%);
}
.play::after{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background:
    url("./img/v2/fx/fx-steam.png") 4% 66%/13% auto no-repeat,
    url("./img/v2/fx/fx-petals.png") 92% 8%/11% auto no-repeat,
    url("./img/v2/fx/fx-gold.png") 50% 6%/9% auto no-repeat;
}
.play-map{display:block;position:absolute;left:26%;right:23%;top:20%;height:31%;z-index:1;filter:drop-shadow(0 20px 24px rgba(73,43,27,.18));transform:rotate(-1deg)}
.play-map::before{
  content:"";position:absolute;inset:-14px;border-radius:24px;
  background:rgba(255,248,230,.78);border:1px solid rgba(139,95,43,.2);box-shadow:0 18px 34px rgba(73,43,27,.12);
}
.play-map img{position:relative;width:100%;height:100%;object-fit:cover;border-radius:16px;border:6px solid rgba(196,147,72,.34);opacity:.92}
.play-top{position:absolute;z-index:4;left:29%;right:29%;top:5.5%;height:12%;display:flex;align-items:start;justify-content:center}
.time-rail{display:grid;grid-template-columns:repeat(6,64px);gap:10px;align-items:center}
.time-dot{position:relative;text-align:center}
.time-dot::after{content:"";position:absolute;left:54px;top:31px;width:34px;border-top:4px dotted rgba(139,95,43,.55)}
.time-dot:last-child::after{display:none}
.time-dot img{position:relative;z-index:2;width:60px;height:60px;object-fit:contain;border-radius:50%;background:rgba(255,248,230,.88);box-shadow:0 8px 16px rgba(73,43,27,.16)}
.time-dot span{display:block;margin-top:3px;color:var(--green);font-weight:900;font-size:11px}
.time-dot.is-current img{transform:translateY(-5px) scale(1.08);outline:4px solid rgba(198,70,49,.24)}
.time-dot.is-current::before{display:none}
.time-dot.is-done{filter:saturate(.75) brightness(1.08)}
.score-box{
  display:none;
  position:absolute;left:6%;bottom:-650%;width:82%;height:88px;place-items:center;text-align:center;align-self:start;
  border-radius:22px;border:3px double rgba(209,154,59,.9);
  background:radial-gradient(circle at 50% 18%,#103d42,#041d21 64%,#d19a3b 65%,#2a1710 72%);
  box-shadow:0 12px 22px rgba(73,43,27,.2),inset 0 0 0 3px rgba(255,248,230,.18);
  color:#fff8e9;
}
.score-box span{font-size:12px;color:#ffd36c;font-weight:900;text-shadow:0 2px 0 rgba(20,55,56,.48)}
.score-box strong{font:800 38px/1 "Shippori Mincho",serif;text-shadow:0 3px 0 rgba(20,55,56,.48)}
.status-panel,.itinerary-panel{
  position:absolute;z-index:3;top:4%;bottom:5%;width:21%;padding:4.7% 1.8% 3%;
  background:rgba(255,244,218,.64);border:1px solid rgba(139,95,43,.18);border-radius:22px;box-shadow:0 18px 42px rgba(73,43,27,.14);
  backdrop-filter:blur(2px);
}
.status-panel{left:2.3%}
.itinerary-panel{right:2.3%}
.panel-label,.panel-title{
  height:46px;margin:0 0 14px;display:grid;place-items:center;color:#fff8e9;font-weight:900;
  background:url("./img/v2/ui/ui-header.png") center/100% 100% no-repeat;text-shadow:0 2px 0 rgba(20,55,56,.45);
}
.mission-card{margin:0 0 16px;padding:12px 14px;border-radius:14px;background:rgba(31,107,106,.12);border:1px solid rgba(31,107,106,.18)}
.mission-card strong{display:block;font:800 20px/1.25 "Shippori Mincho",serif}
.mission-card p{margin:6px 0 0;color:var(--muted);font-weight:900;font-size:12px;line-height:1.5}
.meters{display:grid;gap:14px}
.meter{display:grid;grid-template-columns:42px 1fr;gap:10px;align-items:center}
.meter-icon{width:42px;height:42px;object-fit:contain;border-radius:8px;background:rgba(255,248,230,.88);filter:drop-shadow(0 6px 9px rgba(73,43,27,.16))}
.meter-label{display:flex;justify-content:space-between;margin-bottom:5px;font-weight:900;font-size:12px;color:var(--muted)}
.meter-label strong{color:var(--ink)}
.meter-track{height:18px;border-radius:999px;border:2px solid rgba(139,95,43,.22);background:rgba(255,248,230,.72);overflow:hidden}
.meter-fill{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--green),var(--gold),var(--red));transition:width .28s ease}
.card-table{position:absolute;z-index:4;left:26%;right:22%;bottom:4.5%;height:43%}
.turn-label{min-height:54px;margin:0 auto 10px;width:58%;max-width:100%;padding:10px 24px;display:flex;align-items:center;justify-content:center;border-radius:22px;background:#c85b43;color:#fff8e9;font-weight:900;box-shadow:0 8px 18px rgba(73,43,27,.14);white-space:nowrap;border:4px double rgba(255,237,181,.78)}
.cards{height:calc(100% - 64px);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:2.2%}
.travel-card{
  position:relative;height:100%;min-height:0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;
  border:1px solid rgba(139,95,43,.22);
  background:linear-gradient(180deg,rgba(255,248,230,.96),rgba(248,223,172,.82));
  border-radius:18px;padding:12px 12px 11px;
  color:var(--ink);text-align:center;box-shadow:0 16px 30px rgba(73,43,27,.14);transition:transform .16s ease,filter .16s ease;overflow:hidden;
  isolation:isolate;
}
.travel-card:hover{transform:translateY(-6px) rotate(-1deg);filter:saturate(1.06)}
.card-art{position:relative;z-index:1;display:block;width:100%;height:42%;max-width:100%;object-fit:contain;margin:0 auto 8px;filter:drop-shadow(0 12px 13px rgba(73,43,27,.16))}
.travel-card h3{font:800 clamp(18px,1.45vw,24px)/1.15 "Shippori Mincho",serif;margin:0 0 4px}
.travel-card p{
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  margin:0 auto 8px;font-size:11px;line-height:1.45;font-weight:900;color:var(--muted);max-width:96%;
}
.travel-card h3{
  display:block;z-index:3;
  position:relative;left:auto;right:auto;bottom:auto;
  font-size:clamp(14px,1.08vw,18px);line-height:1.16;overflow-wrap:anywhere;
  padding:0;color:#39271f;text-shadow:0 1px 0 rgba(255,248,230,.9);
  background:transparent;border:0;box-shadow:none;
}
.travel-card::before{
  content:"";display:none;
}
.card-score{
  display:inline-flex;align-items:center;justify-content:center;min-height:25px;margin:0 auto 7px;padding:0 10px;
  border-radius:999px;background:#1f6b6a;color:#fff8e9;font-size:11px;font-weight:900;letter-spacing:.04em;
  box-shadow:0 5px 9px rgba(73,43,27,.13);
}
.card-stats{
  position:relative;z-index:3;left:auto;right:auto;bottom:auto;
  display:flex;justify-content:center;gap:4px;flex-wrap:wrap;margin:0;
}
.card-stats span{font-size:10px;font-weight:900;padding:3px 6px;border-radius:999px;background:rgba(255,248,230,.92);border:1px solid rgba(139,95,43,.2);box-shadow:0 4px 8px rgba(73,43,27,.08)}
.itinerary{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.itinerary li{display:grid;grid-template-columns:42px 1fr;gap:9px;align-items:center;min-height:56px;padding:7px 9px;border-radius:13px;background:rgba(255,248,230,.5);border:1px solid rgba(139,95,43,.14);font-weight:900}
.itinerary img{width:40px;height:40px;object-fit:contain}
.itinerary small{display:block;color:var(--green);font-size:11px;margin-bottom:2px}

/* result */
.result{
  background:
    radial-gradient(circle at 65% 15%,rgba(255,255,255,.42),transparent 25rem),
    linear-gradient(180deg,#fff0cf,#f6dca8);
}
.result-book{position:absolute;left:3.5%;top:16%;width:64%;height:68%;transform:rotate(-5deg);z-index:1;filter:drop-shadow(0 20px 24px rgba(73,43,27,.18))}
.result-book img{width:100%;height:100%;object-fit:contain}
.result-copy{position:absolute;z-index:3;left:7%;top:5%;width:42%}
.result h2{font-size:clamp(38px,4vw,64px);line-height:1.08;text-shadow:0 2px 0 rgba(255,248,230,.9),0 16px 28px rgba(73,43,27,.12)}
.result-copy p:not(.eyebrow){margin:12px 0 0;font-weight:900;color:var(--muted)}
.final-score{margin-top:16px;width:260px;height:74px;display:flex;align-items:center;justify-content:center;gap:16px;border-radius:18px;background:rgba(255,248,230,.72);border:1px solid var(--line)}
.final-score span{font-weight:900;color:var(--green)}
.final-score strong{font:800 48px/1 "Shippori Mincho",serif;color:var(--red)}
.result-itinerary{position:absolute;z-index:4;left:22%;top:35%;width:36%;height:42%;list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.result-itinerary li{position:relative;min-height:86px;padding:8px 8px 7px 68px;border-radius:14px;background:rgba(255,248,230,.84);border:1px solid rgba(139,95,43,.18);filter:drop-shadow(0 10px 12px rgba(73,43,27,.12));font-weight:900}
.result-itinerary img{position:absolute;left:8px;top:8px;width:50px;height:70px;object-fit:contain}
.result-itinerary span{
  display:block!important;
  position:relative;left:auto;right:auto;bottom:auto;
  text-align:left;font:800 clamp(10px,.82vw,13px)/1.25 "Shippori Mincho",serif;
  color:#39271f;text-shadow:0 1px 0 rgba(255,248,230,.9);
}
.result-itinerary small{display:block;margin-bottom:3px;color:var(--green);font:900 10px/1 "Zen Kaku Gothic New",sans-serif}
.result-panel{position:absolute;z-index:3;right:6%;top:24%;width:31%;padding:24px;background:rgba(255,248,230,.68);border:1px solid rgba(139,95,43,.2);border-radius:22px;box-shadow:0 18px 42px rgba(73,43,27,.14);backdrop-filter:blur(2px)}
.result-bars{display:grid;gap:14px}
.notice{margin:16px 0 0;padding:12px;border-radius:13px;background:rgba(255,244,218,.7);border:1px solid rgba(139,95,43,.14);font-size:11px;line-height:1.55;font-weight:900;color:#4f3a30}
.result-actions{position:absolute;z-index:6;left:42%;bottom:5%;display:flex;gap:18px}
.result-actions .primary{background-image:url("./img/v2/ui/ui-retry.png")}

@media (max-width:1180px){
  .screen{aspect-ratio:auto;max-height:none;min-height:calc(100svh - 28px);overflow-y:auto}
  .intro-copy{top:12%;width:52%}
  .intro-map{right:-2%;top:9%;width:58%}
  .intro-cards{right:2%;bottom:7%;width:52%}
  .play{padding:76px 18px 24px}
  .play-map,.play-top,.status-panel,.card-table,.itinerary-panel{position:relative;left:auto;right:auto;top:auto;bottom:auto;width:100%;height:auto}
  .play-map{height:300px;margin:0 0 16px}
  .play-top{height:auto;margin-bottom:14px}
  .status-panel,.itinerary-panel{padding:22px;margin-bottom:16px}
  .card-table{margin-bottom:16px}
  .cards{height:auto}
  .result{padding:76px 18px 24px}
  .result-book,.result-copy,.result-itinerary,.result-panel,.result-actions{position:relative;left:auto;right:auto;top:auto;bottom:auto;width:100%;height:auto}
  .result-copy{z-index:3;margin-bottom:14px}
  .result-book{transform:rotate(-4deg);height:380px;margin:-20px 0 -90px}
  .result-itinerary{z-index:4;width:100%;height:auto;margin:0 0 16px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .result-itinerary li{position:relative;left:auto!important;top:auto;width:auto;transform:none!important}
  .result-actions{justify-content:center;margin-top:18px}
}

@media (max-width:1180px) and (min-width:761px){
  .travel-card{height:auto;min-height:360px}
  .card-art{height:170px;flex:0 0 auto}
}

@media (max-width:760px){
  .app{padding:0;display:block}
  .back-link{top:8px;left:8px;min-height:34px;font-size:12px}
  .screen{width:100%;min-height:100svh;border:0;border-radius:0}
  .intro{min-height:100svh;background-position:64% center}
  .intro::before{
    opacity:.72;
    background:linear-gradient(180deg,rgba(255,241,211,.08),rgba(255,241,211,.88) 33%,rgba(255,241,211,.74) 58%,rgba(255,241,211,.14) 100%);
  }
  .intro-copy{left:18px;right:18px;top:27%;width:auto;text-shadow:0 2px 0 rgba(255,248,230,.92)}
  .intro h1{font-size:clamp(44px,13vw,56px)}
  .subtitle{font-size:16px;line-height:1.7}
  .intro-map{width:96%;right:-28%;top:4%}
  .intro-cards{left:9%;right:9%;width:auto;bottom:3%;opacity:.92;justify-content:center;gap:1.5%;overflow:visible}
  .intro-cards img{width:31%;max-height:210px;object-fit:contain}
  .mission-chip{min-height:40px;font-size:13px;padding:0 11px}
  .start-btn{min-width:min(100%,310px);font-size:20px}
  .play{padding:50px 12px 18px;display:flex;flex-direction:column;gap:10px}
  .play-map{order:1;height:245px;margin:0;transform:rotate(-1deg)}
  .play-top{order:2;display:block;margin:0}
  .time-rail{grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:8px}
  .time-dot img{width:56px;height:56px}
  .time-dot span{font-size:10px}
  .time-dot::after{display:none}
  .score-box{margin-left:auto;width:112px;height:72px}
  .card-table{order:3;margin:0;height:auto}
  .cards{height:auto;grid-template-columns:1fr;gap:8px}
  .travel-card{display:grid;grid-template-columns:86px 1fr;grid-template-rows:auto auto auto auto;align-items:center;min-height:138px;padding:9px 10px;text-align:left;background:rgba(255,248,230,.78);border:1px solid rgba(139,95,43,.18);box-shadow:0 10px 22px rgba(73,43,27,.1);overflow:hidden}
  .card-art{grid-row:1 / span 4;width:82px;height:112px;margin:0;align-self:center}
  .travel-card h3{
    position:relative;left:auto;right:auto;bottom:auto;align-self:end;margin:18px 0 5px;
    font-size:16px;line-height:1.16;text-align:left;white-space:normal;padding:0;background:transparent;border:0;box-shadow:none;
  }
  .travel-card p{display:-webkit-box;margin:0 0 6px;font-size:11px;line-height:1.35;max-width:100%}
  .card-score{margin:0 0 6px;justify-self:start;font-size:10px;min-height:22px;padding:0 8px}
  .card-stats{position:relative;left:auto;right:auto;bottom:auto;justify-content:flex-start}
  .card-stats span{font-size:10px;padding:3px 7px}
  .status-panel{order:4}
  .itinerary-panel{order:5}
  .turn-label{width:100%;white-space:normal;line-height:1.35}
  .time-dot.is-current::before{display:none}
  .result{padding:70px 18px 22px}
  .result-copy{margin-top:10px}
  .result-copy .eyebrow{margin-top:8px}
  .result h2{font-size:clamp(34px,10.5vw,42px)}
  .final-score{width:100%;height:92px;flex-direction:column;gap:2px}
  .final-score strong{font-size:44px}
  .result-book{height:240px;margin:0 0 -18px}
  .result-itinerary{height:auto;margin:0 0 16px;display:grid;grid-template-columns:1fr;gap:8px}
  .result-itinerary li{width:100%;min-height:78px;position:relative;left:auto!important;top:auto;transform:none!important;padding-left:62px}
  .result-itinerary img{width:44px;height:62px}
  .result-panel{padding:18px}
  .result-actions{gap:10px}
  .result-actions .primary,.result-actions .secondary{padding:0 18px;min-height:54px}
}

@media (max-width:420px){
  .intro-copy{top:29%}
  .intro-cards{bottom:2%;left:4%;right:4%}
  .intro-cards img{width:32%;max-height:176px}
  .mission-picker{gap:8px}
  .mission-chip{font-size:12px}
  .play-map{height:230px}
  .status-panel,.itinerary-panel{padding:18px 14px}
  .card-art{width:100%}
  .travel-card{grid-template-columns:74px 1fr;min-height:136px;padding:8px}
  .card-art{width:70px;height:102px}
  .travel-card h3{font-size:15px}
  .result-book{height:220px;margin-bottom:-12px}
}
