/* =========================================================
   STUDYMO PRINT v2 — ちびむす型ポータル構成
   非対称2カラム（メイン広 + 右サイドバー狭）・リンク密度高め
   ========================================================= */
:root{
  --paper:#FAF9F6;
  --white:#FFFFFF;
  --ink:#26292E;
  --ink-soft:#585D64;
  --ink-faint:#8B9097;
  --red:#D93A2B;        /* 赤ペン */
  --red-deep:#B92C1F;
  --red-soft:#FBEAE7;
  --blue:#3563A0;       /* 罫線ブルー */
  --blue-soft:#EAF1F9;
  --line:#E5E2DB;
  --line-soft:#EFEDE7;
  --shadow:0 1px 2px rgba(38,41,46,.05),0 6px 18px rgba(38,41,46,.05);
  --font-disp:"Zen Maru Gothic",system-ui,sans-serif;
  --font-body:"BIZ UDPGothic","Hiragino Sans",system-ui,sans-serif;
  --wrap:1160px;
}
*{box-sizing:border-box}
body{
  margin:0; font-family:var(--font-body); color:var(--ink); line-height:1.8;
  background:var(--paper); font-size:14px;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{color:var(--red)}
h1,h2,h3,h4{font-family:var(--font-disp);font-weight:700;margin:0;line-height:1.4}
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:16px}
:focus-visible{outline:3px solid var(--red);outline-offset:2px;border-radius:4px}

/* ===== ヘッダー ===== */
.head-top{background:var(--white);border-bottom:1px solid var(--line)}
.head-top .wrap{display:flex;align-items:center;gap:18px;padding-block:14px;flex-wrap:wrap}
.brand{display:flex;flex-direction:column;line-height:1.3}
.brand .logo{display:flex;align-items:center;gap:8px;font-family:var(--font-disp);font-weight:700;font-size:26px;color:var(--ink)}
.brand .logo .maru{width:28px;height:28px;border-radius:50%;border:3.5px solid var(--red);display:inline-grid;place-items:center;color:var(--red);font-size:14px;transform:rotate(-8deg)}
.brand .logo small{color:var(--red);font-size:12px;font-weight:700;letter-spacing:.14em;margin-left:2px}
.brand .tagline{font-size:11px;color:var(--ink-faint)}
.head-search{margin-left:auto;display:flex;border:1.5px solid var(--line);border-radius:8px;overflow:hidden;background:#fff;min-width:260px}
.head-search input{border:none;padding:9px 12px;font-family:var(--font-body);font-size:13px;flex:1;background:transparent}
.head-search input:focus{outline:none}
.head-search button{border:none;background:var(--red);color:#fff;font-weight:700;font-family:var(--font-body);padding:0 16px;cursor:pointer;font-size:13px}
.head-search button:hover{background:var(--red-deep)}

/* ===== グローバルナビ（学年帯） ===== */
.gnav{background:var(--blue);border-bottom:3px solid var(--red)}
.gnav ul{list-style:none;margin:0 auto;padding:0 16px;max-width:var(--wrap);display:flex;flex-wrap:wrap}
.gnav a{display:block;padding:10px 15px;color:#fff;font-weight:700;font-size:13.5px;border-right:1px solid rgba(255,255,255,.18)}
.gnav li:first-child a{border-left:1px solid rgba(255,255,255,.18)}
.gnav a:hover{background:rgba(255,255,255,.14);color:#fff}
.gnav a.hot{background:var(--red)}
.gnav a.hot:hover{background:var(--red-deep)}

/* ===== 2カラムレイアウト（非対称） ===== */
.layout{display:grid;grid-template-columns:1fr 296px;gap:22px;align-items:start;padding-block:22px}
.main,.side{min-width:0}

/* ===== 汎用ボックス ===== */
.box{background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);margin-bottom:22px;overflow:hidden}
.box-h{display:flex;align-items:center;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line);background:linear-gradient(#fff,#FBFAF7)}
.box-h::before{content:"";width:5px;height:20px;border-radius:3px;background:var(--red)}
.box-h h2{font-size:17px}
.box-h .more{margin-left:auto;font-size:12px;color:var(--ink-soft);font-weight:700}
.box-h .more:hover{color:var(--red)}
.box-b{padding:14px 16px}

/* ===== 新着情報 ===== */
.news li{display:flex;gap:12px;align-items:baseline;padding:7px 2px;border-bottom:1px dotted var(--line);font-size:13.5px}
.news{list-style:none;margin:0;padding:0}
.news li:last-child{border:none}
.news .d{color:var(--ink-faint);font-size:12px;flex:none;width:76px}
.news .tag{flex:none;font-size:10px;font-weight:700;color:#fff;background:var(--red);border-radius:3px;padding:1px 7px}
.news .tag.b{background:var(--blue)}
.news a{flex:1}

/* ===== コラボ・特集バナー ===== */
.banners{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bn{display:flex;align-items:center;gap:12px;border:1px solid var(--line);border-radius:8px;padding:12px 14px;background:#fff;transition:border-color .12s}
.bn:hover{border-color:var(--red)}
.bn .ic{width:42px;height:42px;border-radius:8px;flex:none;display:grid;place-items:center;background:var(--blue-soft);color:var(--blue);font-family:var(--font-disp);font-weight:700;font-size:17px}
.bn .t{font-weight:700;font-size:13.5px;line-height:1.45}
.bn .s{font-size:11px;color:var(--ink-faint)}
.bn.pr .ic{background:var(--red-soft);color:var(--red)}

/* ===== 教科セクション（リンク密度高） ===== */
.subject .box-h::before{background:var(--blue)}
.grade-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.grade-row a{font-size:12px;font-weight:700;border:1.5px solid var(--line);border-radius:20px;padding:4px 12px;background:#fff;color:var(--ink-soft)}
.grade-row a:hover{border-color:var(--red);color:var(--red)}
.linkcols{display:grid;grid-template-columns:repeat(3,1fr);gap:2px 18px}
.linkcols a{display:flex;gap:7px;align-items:baseline;font-size:13.5px;padding:5px 2px;border-bottom:1px dotted var(--line-soft)}
.linkcols a::before{content:"▶";font-size:9px;color:var(--red);flex:none;transform:translateY(-1px)}
.linkcols a .n{color:var(--ink-faint);font-size:11px;margin-left:auto;flex:none}
.linkcols a:hover{background:var(--red-soft)}
.sub-note{font-size:11px;color:var(--ink-faint);margin-top:8px}

/* ===== 無限プリントPR帯 ===== */
.mugen{display:flex;align-items:center;gap:18px;background:linear-gradient(120deg,#fff,#FDF6F0);border:1.5px solid var(--red);border-radius:10px;padding:16px 18px;margin-bottom:22px}
.mugen .badge{flex:none;font-family:var(--font-disp);font-weight:700;color:#fff;background:var(--red);border-radius:8px;padding:8px 12px;font-size:15px;line-height:1.3;text-align:center}
.mugen .t{font-weight:700;font-size:15px}
.mugen .s{font-size:12.5px;color:var(--ink-soft)}
.mugen .btn{margin-left:auto}
.btn{display:inline-flex;align-items:center;gap:7px;background:var(--red);color:#fff;font-weight:700;font-family:var(--font-body);font-size:13.5px;border:none;border-radius:8px;padding:10px 18px;cursor:pointer;box-shadow:var(--shadow);white-space:nowrap}
.btn:hover{background:var(--red-deep);color:#fff}

/* ===== サイドバー ===== */
.sbox{background:var(--white);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);margin-bottom:18px;overflow:hidden}
.sbox-h{padding:9px 14px;font-family:var(--font-disp);font-weight:700;font-size:14px;background:var(--blue);color:#fff}
.sbox-h.r{background:var(--red)}
.sbox-b{padding:10px 14px}
.smenu{list-style:none;margin:0;padding:0}
.smenu a{display:flex;gap:8px;align-items:baseline;padding:7px 2px;font-size:13px;border-bottom:1px dotted var(--line-soft)}
.smenu li:last-child a{border:none}
.smenu a::before{content:"▶";font-size:9px;color:var(--blue);flex:none}
.rank{list-style:none;margin:0;padding:0;counter-reset:r}
.rank a{display:flex;gap:10px;align-items:baseline;padding:8px 2px;font-size:13px;border-bottom:1px dotted var(--line-soft);counter-increment:r}
.rank li:last-child a{border:none}
.rank a::before{content:counter(r);flex:none;width:22px;height:22px;border-radius:50%;background:var(--line-soft);color:var(--ink-soft);font-family:var(--font-disp);font-weight:700;font-size:12px;display:grid;place-items:center;transform:translateY(3px)}
.rank li:nth-child(-n+3) a::before{background:var(--red);color:#fff}
.ad-rect{margin:0 auto;min-height:250px;max-width:300px;border:1px dashed var(--line);border-radius:8px;display:grid;place-items:center;font-size:11px;color:var(--ink-faint);background:#FCFBF8}
.ad-note{text-align:center;font-size:10px;color:var(--ink-faint);letter-spacing:.12em;margin-bottom:4px}
.line-btn{display:flex;justify-content:center;align-items:center;gap:8px;background:#06C755;color:#fff!important;font-weight:700;border-radius:8px;padding:11px;font-size:14px}
.line-btn:hover{filter:brightness(.94)}
.sbox-b .note{font-size:11px;color:var(--ink-faint);margin:8px 0 0}

/* ===== フッター ===== */
.foot{background:var(--blue);color:#fff;margin-top:10px}
.foot .wrap{padding-block:26px;display:flex;flex-wrap:wrap;gap:10px 26px;font-size:12.5px}
.foot a{color:#D8E4F3}
.foot a:hover{color:#fff}
.foot .cp{margin-left:auto;color:#B9CCE6}

@media (max-width:920px){
  .layout{grid-template-columns:1fr}
  .linkcols{grid-template-columns:1fr 1fr}
  .banners{grid-template-columns:1fr}
  .head-search{min-width:0;width:100%}
  .mugen{flex-wrap:wrap}
  .mugen .btn{margin-left:0;width:100%;justify-content:center}
}
@media (max-width:560px){
  .linkcols{grid-template-columns:1fr}
  .gnav a{padding:9px 11px;font-size:12.5px}
}
