:root{
  /* 生成り（和紙）ベース */
  --bg-top:#f7f2e7;
  --bg-bottom:#ece2cf;

  /* 墨色テキスト */
  --text:#34302b;
  --text-sub:#7a7164;

  /* 藍・朱・金 アクセント */
  --indigo:#3c5a6e;
  --indigo-soft:#5a7d92;
  --vermillion:#b1503b;
  --vermillion-soft:#c97058;
  --gold:#c8a86b;

  --card:#fffdf7;
  --card-sub:#f3ecdc;
  --border:#e4d9c2;
}

body{
  margin:0;
  padding:12px;
  font-family:'Zen Maru Gothic', sans-serif;
  background:
    linear-gradient(
      180deg,
      var(--bg-top) 0%,
      var(--bg-bottom) 100%
    );
  color:var(--text);
  overflow-x:hidden;
  position:relative;
  background-attachment:fixed;
  animation:fadeIn 0.2s ease;
}

@keyframes fadeIn{
  from{ opacity:0; }
  to{ opacity:1; }
}

/* 背景のぼかし（控えめに） */
body::before{
  content:"";
  position:fixed;
  width:320px;
  height:320px;
  background:rgba(200,168,107,0.12);
  border-radius:50%;
  top:-120px;
  right:-100px;
  filter:blur(60px);
  z-index:-1;
}

body::after{
  content:"";
  position:fixed;
  width:260px;
  height:260px;
  background:rgba(60,90,110,0.08);
  border-radius:50%;
  bottom:-100px;
  left:-80px;
  filter:blur(60px);
  z-index:-1;
}

/* ダークモード（墨色ベース） */
body.dark{
  background:
    linear-gradient(
      180deg,
      #25221d 0%,
      #1a1814 100%
    );
  color:#ece4d4;
}

body.dark::before{
  background:rgba(200,168,107,0.08);
}

body.dark::after{
  background:rgba(143,180,201,0.06);
}

/* タイトルエリア */
.title-bar{
  position:relative;
  display:flex;
  justify-content:flex-start;
  align-items:center;
  margin-bottom:10px;
  min-height:40px;
}

.title-bar h1{
  margin:0;
  padding-left:4px;
}


/* ダークモードボタン */
#darkToggle{
  position:static;
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 14px;
  font-size:11px;
  font-family:'Zen Maru Gothic', sans-serif;
  background:var(--card);
  color:var(--indigo);
  box-shadow:0 3px 8px rgba(52,48,43,0.08);
  transition:0.2s;
}

#darkToggle:active{
  transform:scale(0.96);
}

/* ダーク時カード */
body.dark .card,
body.dark .item,
body.dark .modal-box,
body.dark .sticky{
  background:#2c2823;
  color:#ece4d4;
  border:1px solid #46423b;
}

/* ダーク時画像背景 */
body.dark .item img,
body.dark .modal-box img{
  background:#383329;
}

/* ダーク時入力 */
body.dark .search,
body.dark .mini-search{
  background:#383329;
  color:#ece4d4;
  box-shadow:none;
  border:1px solid #46423b;
}

/* ダーク時ボタン */
body.dark .filter button,
body.dark .modal-box button,
body.dark #darkToggle,
body.dark #helpBtn,
body.dark #minimizeBtn{
  background:#383329;
  color:#ece4d4;
  border:1px solid #46423b;
}

/* ダーク時ONボタン（藍色） */
body.dark .active{
  background:var(--indigo-soft) !important;
  color:#fdf9ef !important;
  border-color:var(--indigo-soft) !important;
}

/* タイトル右側ボタン群 */
.title-buttons{
  position:absolute;
  right:0;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  gap:8px;
}

/* ヘルプボタン */
#helpBtn{
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 14px;
  font-size:11px;
  font-family:'Zen Maru Gothic', sans-serif;
  background:var(--card);
  color:var(--indigo);
  box-shadow:0 3px 8px rgba(52,48,43,0.08);
  transition:0.2s;
}

#helpBtn:active{
  transform:scale(0.96);
}

/* ダーク時文字 */
body.dark .weather,
body.dark .time,
body.dark a,
body.dark p,
body.dark h3{
  color:#ece4d4;
}

.dark body::before,
.dark body::after{
  opacity:0.6;
}

/* タイトル */
h1{
  text-align:center;
  font-size:23px;
  font-family:'Shippori Mincho', serif;
  font-weight:700;
  color:var(--indigo);
  letter-spacing:0.18em;
  text-shadow:none;
  margin-bottom:10px;
}

/* ダークモード時 */
body.dark h1{
  color:#e8d2a8;
  text-shadow:none;
}

/* カード */
.card{
  background:var(--card);
  border-radius:18px;
  padding:14px;
  margin-top:12px;
  border:1px solid var(--border);
  box-shadow:0 8px 22px rgba(52,48,43,0.07);
}

/* sticky */
.sticky{
  position:sticky;
  top:8px;
  z-index:100;
  width:100%;
  box-sizing:border-box;
  background:var(--card);
}

/* 天気 */
.weather{
  text-align:center;
  font-size:18px;
  margin-bottom:6px;
  color:var(--text-sub);
}

/* 天気全体 */
.weather-wrap{
  display:flex;
  justify-content:center;
  align-items:flex-end;
  gap:8px;
  margin-bottom:8px;
}

/* 今の天気 */
.weather-now{
  font-size:18px;
  font-family:'Shippori Mincho', serif;
  color:var(--indigo);
}

/* 次の天気 */
.weather-next{
  font-size:11px;
  opacity:0.8;
  color:var(--text-sub);
  margin-bottom:2px;
}

/* ダークモード */
body.dark .weather-now{
  color:#e8d2a8;
}

body.dark .weather-next{
  color:#b3a89a;
}

/* 時間 */
.time{
  text-align:center;
  font-size:28px;
  font-family:'Shippori Mincho', serif;
  letter-spacing:0.06em;
  margin-bottom:10px;
  color:var(--indigo);
}

/* 検索 */
.search{
  width:100%;
  padding:12px 16px;
  border:1px solid var(--border);
  outline:none;
  border-radius:999px;
  background:var(--card);
  box-shadow:inset 0 1px 3px rgba(52,48,43,0.05);
  font-family:'Zen Maru Gothic', sans-serif;
  box-sizing:border-box;
  font-size:13px;
  color:var(--text);
}

.search:focus,
.mini-search:focus{
  border-color:var(--indigo-soft);
}

/* 画像ラッパー */
.img-wrap{
  position:relative;
  width:100%;
}

/* レベル表示 */
.level-badge{
  position:absolute;
  top:6px;
  left:6px;
  z-index:5;
  padding:1px 5px;
  border-radius:999px;
  font-size:6px;
  color:#fdf9ef;
  background:rgba(52,48,43,0.75);
  backdrop-filter:blur(4px);
}

.shadow-badge{
  position:absolute;
  bottom:6px;
  left:6px;
  z-index:5;
  padding:2px 5px;
  border-radius:999px;
  font-size:7px;
  color:#fdf9ef;
  background:rgba(52,48,43,0.7);
}

.shadow-gold{
  background:
    linear-gradient(
      180deg,
      #f0d199 0%,
      var(--gold) 100%
    );
  color:#5c4300;
}

.shadow-blue{
  background:
    linear-gradient(
      180deg,
      var(--indigo-soft) 0%,
      var(--indigo) 100%
    );
  color:#fdf9ef;
}

/* チェックボタン */
.check-btn{
  position:absolute;
  top:6px;
  right:6px;
  width:22px;
  height:22px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--card);
  font-size:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 2px 6px rgba(52,48,43,0.1);
  z-index:10;
}

/* ON状態（朱色） */
.check-btn.checked{
  background:var(--vermillion);
  border-color:var(--vermillion);
  color:#fdf9ef;
}

/* 名前 */
.item-name{
  height:34px;
  display:flex;
  align-items:center;
  justify-content:center;
  line-height:1.2;
  font-size:11px;
}

/* ×ボタン */
#clearBtn{
  position:absolute;
  right:12px;
  top:50%;
  transform:translateY(-50%);
  border:1px solid var(--border);
  width:28px;
  height:28px;
  border-radius:50%;
  background:var(--card);
  box-shadow:0 2px 6px rgba(52,48,43,0.08);
  font-size:15px;
  display:none;
  color:var(--text-sub);
}

/* フィルター */
.filter{
  display:flex;
  gap:8px;
  margin-top:8px;
}

.filter-4 button{
  padding:8px 4px;
  font-size:10px;
}

/* ボタン */
.filter button,
.modal-box button{
  flex:1;
  border:1px solid var(--border);
  border-radius:999px;
  padding:10px;
  font-family:'Zen Maru Gothic', sans-serif;
  font-size:11px;
  background:var(--card-sub);
  color:var(--text-sub);
  box-shadow:none;
  transition:0.15s;
}

/* 押した時 */
.filter button:active,
.modal-box button:active{
  transform:
    translateY(1px)
    scale(0.97);
}

/* ON状態（藍色） */
.active{
  background:var(--indigo) !important;
  color:#fdf9ef !important;
  border-color:var(--indigo) !important;
  font-weight:700;
  box-shadow:0 4px 10px rgba(60,90,110,0.25);
}

/* グリッド */
.grid{
  display:grid;
  grid-template-columns:
    repeat(4,1fr);
  gap:10px;
  margin-top:14px;
}

/* アイテム */
.item{
  background:var(--card);
  border-radius:18px;
  padding:10px;
  text-align:center;
  font-size:11px;
  border:1px solid var(--border);
  box-shadow:0 6px 16px rgba(52,48,43,0.06);
  transition:0.15s;
  position:relative;
  overflow:hidden;
}

/* hover */
.item:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 20px rgba(52,48,43,0.1);
}

/* 押した時 */
.item:active{
  transform:scale(0.96);
}

/* 複数選択中 */
.item.selected{
  outline:3px solid var(--vermillion-soft);
  outline-offset:-3px;
}

.item img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:contain;
  background:var(--card-sub);
  border-radius:14px;
  padding:2px;
  box-sizing:border-box;
  margin-bottom:6px;
  display:block;
}

/* モーダル */
#modal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(40,36,30,0.5);
  backdrop-filter:blur(5px);
  z-index:999;
}

.modal-box{
  background:var(--card);
  margin:60px auto;
  padding:18px;
  width:90%;
  max-width:320px;
  border-radius:22px;
  text-align:center;
  border:1px solid var(--gold);
  box-shadow:0 20px 40px rgba(52,48,43,0.15);
}

/* モーダル画像 */
.modal-box img{
  background:var(--card-sub);
  border-radius:14px;
  padding:8px;
  margin-bottom:10px;
}

#m_name{
  font-family:'Shippori Mincho', serif;
  color:var(--indigo);
  letter-spacing:0.08em;
}

body.dark #m_name{
  color:#e8d2a8;
}

/* モーダル情報横並び */
.modal-info-row{
  display:flex;
  justify-content:center;
  align-items:flex-start;
  margin-top:10px;
  color:var(--text-sub);
}

body.dark .modal-info-row{
  color:#b3a89a;
}

/* 左 */
.modal-left{
  width:130px;
  text-align:left;
}

#m_time{
  white-space:nowrap;
}

/* 右 */
.modal-right{
  width:90px;
  text-align:left;
  font-size:11px;
  line-height:1.5;
  margin-left:60px;
}

/* 最小化 */
.minimized .top-content{
  display:none;
}

.update-popup-box{
  background:var(--card);
  color:var(--text);
  border:1px solid var(--gold);
}

body.dark .update-popup-box{
  background:#2c2823;
  color:#ece4d4;
  border:1px solid #46423b;
}

body.dark .update-popup-box p,
body.dark .update-popup-box h3{
  color:#ece4d4;
}

/* ヘルプモーダル */
.help-modal-box{
  background:var(--card);
  color:var(--text);
  border:1px solid var(--gold);
}

/* ダークモード */
body.dark .help-modal-box{
  background:#2c2823;
  color:#ece4d4;
  border:1px solid #46423b;
}

/* ヘルプ内の文字 */
body.dark .help-modal-box p,
body.dark .help-modal-box h3,
body.dark .help-modal-box strong{
  color:#ece4d4;
}

h3{
  font-family:'Shippori Mincho', serif;
  color:var(--indigo);
  letter-spacing:0.06em;
}

body.dark h3{
  color:#e8d2a8;
}

/* ボタン */
#minimizeBtn{
  border:1px solid var(--border);
  border-radius:999px;
  width:32px;
  height:32px;
  font-size:18px;
  background:var(--card);
  color:var(--indigo);
  box-shadow:0 3px 8px rgba(52,48,43,0.08);
  font-family:'Zen Maru Gothic', sans-serif;
}

/* 最小化時の情報 */
.mini-header{
  display:flex;
  align-items:center;
}

.mini-info{
  display:none;
  align-items:center;
  gap:8px;
  margin-top:8px;
  flex:1;
}

.minimized{
  display:flex;
  align-items:center;
}

.minimized .mini-info{
  display:flex;
}

/* 検索欄 */
.mini-search{
  flex:1;
  padding:8px 12px;
  font-size:11px;
}

/* 時間・天気 */
.mini-status{
  text-align:right;
  white-space:nowrap;
  font-size:11px;
  color:var(--text-sub);
}

#miniTime{
  font-size:14px;
  font-family:'Shippori Mincho', serif;
  color:var(--indigo);
}

#miniWeather{
  font-size:10px;
  opacity:0.8;
}

body.dark #miniTime{
  color:#e8d2a8;
}

/* リンク色 */
a{
  color:var(--vermillion);
}

/* 認証バッジ */
.auth-btn{
  position:absolute;
  bottom:6px;
  right:6px;
  width:22px;
  height:22px;
  border-radius:50%;
  border:1px solid var(--border);
  background:var(--card);
  font-size:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:10;
}

.auth-btn.checked{
  background:var(--gold);
  border-color:var(--gold);
}

/* シェアボタン */
#shareBtn{
  border:1px solid var(--border);
  border-radius:999px;
  padding:8px 14px;
  font-size:14px;
  background:var(--card);
  color:var(--indigo);
}

body.dark #shareBtn{
  background:#383329;
  color:#ece4d4;
  border-color:#46423b;
}

/* シェアモーダル */
#shareModal{
  display:none;
  position:fixed;
  inset:0;
  background:rgba(40,36,30,0.5);
  backdrop-filter:blur(5px);
  z-index:999;
}

#shareModal .modal-box{
  max-width:340px;
}

#shareCanvas{
  width:100%;
  border-radius:14px;
  border:1px solid var(--border);
  margin-bottom:10px;
}

/* ナビゲーションバー */
.site-nav{
  display:flex;
  gap:6px;
  margin-bottom:10px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  scrollbar-width:none;
}

.site-nav::-webkit-scrollbar{
  display:none;
}

.site-nav-item{
  flex-shrink:0;
  padding:7px 16px;
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px;
  font-family:'Zen Maru Gothic', sans-serif;
  background:var(--card-sub);
  color:var(--text-sub);
  text-decoration:none;
  transition:0.15s;
}

.site-nav-item.active{
  background:var(--indigo);
  border-color:var(--indigo);
  color:#fdf9ef;
  font-weight:700;
}

body.dark .site-nav-item{
  background:var(--card-sub);
  color:var(--text-sub);
  border-color:var(--border);
}

body.dark .site-nav-item.active{
  background:var(--indigo-soft);
  border-color:var(--indigo-soft);
  color:#fdf9ef;
}

