﻿/* ==== デザイントークン ==== */
:root{
  --main:#1FA9A0;
  --main-deep:#0E7C76;
  --main-tint:#E4F6F4;
  --accent:#F5A623;
  --accent-deep:#D98A0B;
  --coin-hi:#FFD34D;
  --ink:#173B47;
  --paper:#FDF9F0;
  --card:#FFFFFF;
  --gray:#93A7B0;
  --line:#E7EDEF;
  --danger:#E4572E;
  --radius-lg:24px;
  --radius-md:16px;
  --shadow:0 4px 0 rgba(23,59,71,.08);
}

*{margin:0;padding:0;box-sizing:border-box}

body{
  font-family:"Zen Maru Gothic","Hiragino Maru Gothic ProN","BIZ UDGothic",sans-serif;
  background:#DDE9EC;
  color:var(--ink);
  font-weight:700;
  -webkit-font-smoothing:antialiased;
  padding:24px 8px;
}

button,input,select{font:inherit;font-weight:700}

button{
  min-height:48px;
  border:none;
  border-radius:14px;
  background:var(--paper);
  color:var(--ink);
  cursor:pointer;
  font-weight:700;
}

button:active{transform:translateY(2px)}
button:disabled{opacity:.55;cursor:not-allowed}

input,select{
  width:100%;
  min-height:44px;
  border:2px solid var(--line);
  border-radius:10px;
  padding:.5rem .7rem;
  background:#fff;
}

label{display:grid;gap:.3rem;color:#4A6572;font-weight:700;font-size:13px}

h2,h3{margin:0}
h2{font-size:16px;font-weight:900}
h3{font-size:14px;font-weight:900;margin:10px 0 4px}

/* ==== レイアウト ==== */
.app-shell{max-width:430px;margin:0 auto}

.topbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:14px;
}

.app-name{
  font-weight:900;
  font-size:18px;
  color:var(--main-deep);
  letter-spacing:.06em;
  display:flex;
  align-items:center;
  gap:6px;
}

.tabs{display:flex;gap:6px}

.tab{
  min-width:64px;
  padding:6px 14px;
  border-radius:999px;
  border:2px solid var(--line);
  background:#fff;
  color:#4A6572;
  font-size:13px;
  font-weight:700;
  min-height:auto;
}

.tab.is-active{
  background:var(--main);
  color:#fff;
  border-color:var(--main);
}

/* ==== モードチップ ==== */
.mode-chips{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.chip{
  font-size:12px;
  font-weight:700;
  border-radius:999px;
  padding:5px 11px;
  background:var(--main-tint);
  color:var(--main-deep);
}
.chip.time{background:#FBEFD8;color:var(--accent-deep)}

/* ==== 財布(ヒーロー) ==== */
.wallet{
  background:var(--card);
  border-radius:var(--radius-lg);
  padding:18px 16px 14px;
  text-align:center;
  box-shadow:var(--shadow);
  border:2px solid var(--line);
  position:relative;
}

.wallet h1{
  font-size:14px;
  color:#4A6572;
  font-weight:700;
  letter-spacing:.1em;
}

.wallet .amount{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:4px;
  margin:2px 0 4px;
}

.wallet .num{
  font-size:64px;
  font-weight:900;
  line-height:1;
  color:var(--ink);
  font-variant-numeric:tabular-nums;
}

.wallet .unit{font-size:20px;font-weight:900;color:#4A6572}

.wallet .formula{font-size:12.5px;color:var(--gray);font-weight:700}
.wallet .formula b{color:var(--accent-deep)}

.wallet .coin{
  position:absolute;
  top:-14px;
  left:50%;
  transform:translateX(-50%);
}

.jar{display:flex;align-items:center;gap:8px;margin:10px 18px 0}
.jar-track{
  flex:1;
  height:14px;
  border-radius:999px;
  background:#F2EBDD;
  border:1.5px solid #E8DFC9;
  overflow:hidden;
}
.jar-fill{
  display:block;
  height:100%;
  border-radius:999px;
  background:linear-gradient(90deg,var(--coin-hi),var(--accent));
  transition:width .4s ease;
}

.streak{
  display:flex;
  justify-content:center;
  gap:6px;
  align-items:center;
  margin-top:10px;
  font-size:13px;
  color:var(--main-deep);
}

/* ==== セクションタイトル ==== */
.section-title{
  display:flex;
  align-items:center;
  gap:8px;
  margin:22px 4px 10px;
  font-size:15px;
  font-weight:900;
}
.section-title .bar{flex:1;height:2px;background:var(--line);border-radius:2px}

/* ==== クエスト ==== */
.quest-list{display:flex;flex-direction:column;gap:12px}

.quest{
  background:var(--card);
  border-radius:var(--radius-lg);
  border:2px solid var(--line);
  box-shadow:var(--shadow);
  padding:14px;
  display:flex;
  align-items:center;
  gap:12px;
}

.quest .qicon{
  flex:0 0 52px;
  height:52px;
  border-radius:16px;
  background:var(--main-tint);
  display:grid;
  place-items:center;
}

.quest .body{flex:1;min-width:0}
.quest .name{font-size:17px;font-weight:900}
.quest .stamps{display:flex;gap:5px;margin:6px 0 4px;flex-wrap:wrap}

.stamp{
  width:22px;
  height:22px;
  border-radius:50%;
  border:2.5px dashed #C9D6DB;
  background:#fff;
}
.stamp.done{border:none;background:var(--main);position:relative}
.stamp.done::after{
  content:"";
  position:absolute;
  inset:0;
  background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="white" stroke-width="3.4" stroke-linecap="round" stroke-linejoin="round"><path d="M5 13l4 4 10-10"/></svg>') center/13px no-repeat;
}
.stamp.extra{border:none;background:none;position:relative}
.stamp.extra::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23F5A623"><path d="M12 2l2.7 6.2 6.8.6-5.1 4.5 1.5 6.7L12 16.4 6.1 20l1.5-6.7L2.5 8.8l6.8-.6z"/></svg>') center/contain no-repeat;
}

.quest .reward{font-size:11.5px;color:var(--gray);font-weight:700}

.pending-chip{
  display:inline-block;
  background:#FBEFD8;
  color:var(--accent-deep);
  font-size:11px;
  border-radius:999px;
  padding:3px 9px;
  margin-top:4px;
}

.plus{
  flex:0 0 auto;
  height:76px;
  min-width:84px;
  border:none;
  border-radius:20px;
  background:var(--main);
  color:#fff;
  font-family:inherit;
  font-size:19px;
  font-weight:900;
  box-shadow:0 4px 0 var(--main-deep);
  display:grid;
  place-items:center;
  padding:0 12px;
}
.plus:active{transform:translateY(3px);box-shadow:0 1px 0 var(--main-deep)}

.quest.waiting .plus{
  background:#fff;
  color:var(--main-deep);
  border:2.5px solid var(--main);
  box-shadow:none;
  font-size:12px;
}

/* ==== 夏休みプロジェクト ==== */
.project-section{margin-top:0}
.project-grid{display:flex;flex-direction:column;gap:14px}

.project{
  background:linear-gradient(160deg,#FFF6E3,#FFEFCB);
  border:2px solid #F3DCA8;
  border-radius:var(--radius-lg);
  padding:16px;
  box-shadow:var(--shadow);
}

.project .head{display:flex;justify-content:space-between;align-items:center}
.project .name{font-size:16px;font-weight:900}
.project .days{font-size:11.5px;color:var(--accent-deep)}

.track{
  position:relative;
  height:18px;
  background:#fff;
  border-radius:999px;
  margin:12px 0 6px;
  border:2px solid #F3DCA8;
  overflow:visible;
}
.track .fill{
  position:absolute;
  inset:2px auto 2px 2px;
  background:linear-gradient(90deg,var(--coin-hi),var(--accent));
  border-radius:999px;
  transition:width .4s ease;
}
.track .flag{position:absolute;right:-2px;top:-14px}

.project .meta{
  display:flex;
  justify-content:space-between;
  font-size:12.5px;
  color:#7A6A45;
}
.project .meta b{color:var(--accent-deep)}

.goal-chip{
  background:#fff;
  border-radius:12px;
  padding:8px 12px;
  margin-top:10px;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13.5px;
}
.goal-chip b{font-size:17px;color:var(--main-deep)}

/* ==== 親画面 ==== */
.parent-view .view,.parent-view{background:transparent}

.pin-panel{
  background:var(--card);
  border-radius:var(--radius-lg);
  border:2px solid var(--line);
  padding:18px;
  box-shadow:var(--shadow);
  display:grid;
  gap:12px;
}

.p-title{font-size:16px;font-weight:900;margin:4px 4px 12px;color:#33505C}

.panel{
  background:#fff;
  border-radius:var(--radius-md);
  border:1.5px solid var(--line);
  padding:14px;
  margin-bottom:14px;
  display:grid;
  gap:10px;
}

.approve-row{
  background:#fff;
  border-radius:var(--radius-md);
  border:1.5px solid var(--line);
  padding:12px 14px;
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:10px;
}

.approve-row .thumb{
  flex:0 0 46px;
  height:46px;
  border-radius:10px;
  overflow:hidden;
  display:grid;
  place-items:center;
  cursor:pointer;
  object-fit:cover;
}

.approve-row .thumb.nophoto{
  background:#EEF2F4;
  color:var(--gray);
  font-size:10px;
  cursor:default;
}

.approve-row .info{flex:1;font-size:14px;font-weight:700}
.approve-row .info small{
  display:block;
  color:var(--gray);
  font-size:11.5px;
  font-weight:700;
}

.btn-ok{
  height:48px;
  padding:0 18px;
  border:none;
  border-radius:14px;
  background:var(--main);
  color:#fff;
  font-family:inherit;
  font-size:15px;
  font-weight:900;
  box-shadow:0 3px 0 var(--main-deep);
}
.btn-ok:active{transform:translateY(2px);box-shadow:0 1px 0 var(--main-deep)}

.btn-ng{
  height:48px;
  width:48px;
  border-radius:14px;
  border:2px solid #E8B4A5;
  background:#fff;
  color:var(--danger);
  font-family:inherit;
  font-size:12px;
  font-weight:900;
}

.spend-panel .row,.button-row{display:flex;gap:8px;flex-wrap:wrap}

.spend-btn{
  flex:1;
  min-width:64px;
  height:52px;
  border-radius:14px;
  border:2px solid var(--main);
  background:var(--main-tint);
  color:var(--main-deep);
  font-family:inherit;
  font-size:15px;
  font-weight:900;
  min-height:auto;
  box-shadow:none;
}

.stack{display:grid;gap:10px}

.controls{display:grid;gap:12px}

.primary{
  background:var(--main);
  color:#fff;
  border:none;
  border-radius:14px;
  box-shadow:0 3px 0 var(--main-deep);
  font-weight:900;
  min-height:52px;
}
.primary:active{transform:translateY(2px);box-shadow:0 1px 0 var(--main-deep)}

.danger{
  background:#fff;
  color:var(--danger);
  border:2px solid #E8B4A5;
  border-radius:10px;
  min-height:40px;
  box-shadow:none;
  font-size:13px;
}

.notice{
  border:2px solid var(--accent);
  background:#FBEFD8;
  border-radius:var(--radius-md);
  padding:12px 14px;
  margin-bottom:14px;
  font-weight:700;
  font-size:13px;
  color:var(--accent-deep);
}

/* ==== 設定フォーム ==== */
.settings-grid{display:grid;gap:12px;margin-bottom:12px}

.mode-row,.settings-row{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  align-items:end;
  gap:8px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px;
  background:#fff;
}

.settings-row.task-row{
  grid-template-columns:1fr 1.2fr .8fr .7fr .7fr .9fr auto;
}

.settings-row.project-row{
  grid-template-columns:1fr 1.2fr .8fr .7fr .8fr 1fr .9fr .9fr auto;
}

.settings-row.vacation-row{
  grid-template-columns:1fr 1fr auto;
}

/* ==== 週次サマリー ==== */
.week{display:grid;gap:8px}
.week-row{
  display:grid;
  grid-template-columns:1fr auto;
  align-items:center;
  gap:10px;
  border:1px solid var(--line);
  border-radius:10px;
  padding:10px;
  background:#fff;
  font-size:13px;
}
.week-row strong{color:var(--main-deep)}

/* ==== アルバム ==== */
.album-week h3{margin:0 0 8px;font-size:14px}
.album-week h4{margin:8px 0 6px;color:#4A6572;font-size:13px}
.album-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(80px,1fr));
  gap:8px;
}
.album-grid img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  border:2px solid var(--line);
  border-radius:10px;
  cursor:pointer;
}

/* ==== モーダル ==== */
.modal{
  position:fixed;
  inset:0;
  background:rgba(23,59,71,.55);
  display:grid;
  place-items:center;
  padding:18px;
  z-index:20;
}
.modal[hidden]{display:none}

.modal-card{
  width:min(420px,100%);
  max-height:90vh;
  overflow:auto;
  background:var(--paper);
  border:2px solid var(--line);
  border-radius:var(--radius-lg);
  padding:22px 18px;
  box-shadow:0 12px 32px rgba(23,59,71,.18);
  display:grid;
  gap:12px;
}

.modal-card h2{font-size:17px;font-weight:900}
.modal-card p{font-size:13px;color:#4A6572}

.photo-preview,.photo-view{
  width:100%;
  max-height:50vh;
  object-fit:contain;
  border:2px solid var(--line);
  border-radius:var(--radius-md);
  background:#000;
}

/* ==== トースト ==== */
.toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  max-width:calc(100vw - 28px);
  border-radius:999px;
  background:var(--ink);
  color:#fff;
  padding:10px 18px;
  opacity:0;
  pointer-events:none;
  transition:opacity 160ms ease;
  font-weight:700;
  font-size:14px;
  z-index:30;
}
.toast.show{opacity:1}

/* ==== 紙吹雪 ==== */
.confetti{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:25}
.confetti i{
  position:absolute;
  top:-16px;
  width:9px;
  height:14px;
  animation:fall 900ms ease-out forwards;
}
@keyframes fall{
  to{transform:translateY(105vh) rotate(240deg);opacity:0}
}

/* ==== レスポンシブ ==== */
@media(max-width:380px){
  .wallet .num{font-size:52px}
  .plus{min-width:72px;font-size:17px}
  .settings-row.task-row,.settings-row.project-row,.settings-row.vacation-row,.mode-row{
    grid-template-columns:1fr;
  }
}
