/* ==========================================================================
   Musokai Dojo — classic WordPress-style theme
   Palette: sumi ink, ai indigo, washi cream, shu vermilion
   ========================================================================== */

:root{
  --sumi:#1c1c1a;
  --ink:#2b2b28;
  --indigo:#213047;
  --indigo-soft:#2d4360;
  --cream:#f6f2ea;
  --cream-deep:#efe9dc;
  --paper:#fbf9f4;
  --shu:#b3382c;
  --shu-dark:#8f2c22;
  --line:#ddd6c7;
  --muted:#6e6a60;
  --maxw:1160px;
}

*{box-sizing:border-box;}
html{-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:"Lora",Georgia,"Times New Roman",serif;
  font-size:18px;
  line-height:1.74;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block;}
a{color:var(--shu);text-decoration:none;}
a:hover{color:var(--shu-dark);text-decoration:underline;text-underline-offset:2px;}

h1,h2,h3,h4{
  font-family:"Shippori Mincho","Noto Serif JP",serif;
  color:var(--sumi);
  font-weight:600;
  line-height:1.28;
  letter-spacing:.2px;
}

/* ---------- Top bar ---------- */
.topbar{
  background:var(--indigo);
  color:#d7cdbb;
  font-size:13.5px;
  letter-spacing:.4px;
}
.topbar .wrap{
  max-width:var(--maxw);margin:0 auto;padding:7px 24px;
  display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.topbar a{color:#e6dcc8;}
.topbar a:hover{color:#fff;}
.topbar .tb-right{display:flex;gap:18px;}
@media(max-width:680px){.topbar .tb-right{display:none;}}

/* ---------- Site header ---------- */
.site-header{
  background:var(--cream);
  border-bottom:1px solid var(--line);
}
.site-header .wrap{
  max-width:var(--maxw);margin:0 auto;padding:26px 24px;
  display:flex;align-items:center;gap:20px;
}
.brand{display:flex;align-items:center;gap:16px;text-decoration:none;}
.brand:hover{text-decoration:none;}
.brand img{width:62px;height:62px;border-radius:14px;box-shadow:0 2px 6px rgba(28,28,26,.18);}
.brand .titles .name{
  font-family:"Shippori Mincho",serif;font-size:30px;font-weight:700;
  color:var(--sumi);line-height:1.1;margin:0;letter-spacing:.5px;
}
.brand .titles .tag{
  font-size:14px;color:var(--muted);margin-top:4px;letter-spacing:.6px;
  font-family:"Lora",serif;font-style:italic;
}

/* ---------- Primary nav ---------- */
.primary-nav{
  background:var(--indigo);
  border-bottom:3px solid var(--shu);
  position:sticky;top:0;z-index:30;
}
.primary-nav .wrap{
  max-width:var(--maxw);margin:0 auto;padding:0 16px;
  display:flex;flex-wrap:wrap;align-items:center;
}
.nav-links{display:flex;flex-wrap:wrap;align-items:center;}
.primary-nav a{
  display:block;color:#ece3d2;font-family:"Shippori Mincho",serif;
  font-size:15.5px;letter-spacing:.6px;padding:14px 17px;text-decoration:none;
  border-bottom:3px solid transparent;margin-bottom:-3px;
}
.primary-nav a:hover,.primary-nav a.active{
  color:#fff;background:rgba(255,255,255,.06);border-bottom-color:var(--shu);
  text-decoration:none;
}
.nav-toggle{display:none;}

@media(max-width:820px){
  .primary-nav .wrap{padding:0;}
  .nav-toggle{
    display:block;width:100%;background:none;border:0;color:#ece3d2;
    font-family:"Shippori Mincho",serif;font-size:16px;letter-spacing:1px;
    padding:14px 18px;text-align:left;cursor:pointer;
  }
  .nav-links{display:none;width:100%;flex-direction:column;}
  .nav-links.open{display:flex;}
  .primary-nav a{padding:12px 18px;border-bottom:1px solid rgba(255,255,255,.08);margin:0;}
}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:36px 24px 10px;}
.layout{display:grid;grid-template-columns:1fr 320px;gap:46px;align-items:start;}
@media(max-width:900px){.layout{grid-template-columns:1fr;gap:30px;}}

/* breadcrumbs */
.crumbs{font-size:13.5px;color:var(--muted);margin:0 0 18px;letter-spacing:.3px;font-family:"Lora",serif;}
.crumbs a{color:var(--indigo-soft);}
.crumbs span{color:var(--muted);}

/* ---------- Articles / entries ---------- */
.entry-header{margin-bottom:26px;border-bottom:1px solid var(--line);padding-bottom:18px;}
.entry-title{font-size:38px;margin:0 0 12px;}
.page .entry-title,.single .entry-title{font-size:34px;}
.entry-meta{font-size:13.5px;color:var(--muted);letter-spacing:.4px;display:flex;flex-wrap:wrap;gap:6px 14px;font-family:"Lora",serif;}
.entry-meta .cat{color:var(--shu);text-transform:uppercase;letter-spacing:1px;font-size:12px;}

.entry-content h2{font-size:27px;margin:38px 0 14px;padding-bottom:6px;border-bottom:1px solid var(--line);}
.entry-content h3{font-size:21px;margin:30px 0 10px;color:var(--indigo);}
.entry-content p{margin:0 0 20px;}
.entry-content ul,.entry-content ol{margin:0 0 22px;padding-left:26px;}
.entry-content li{margin-bottom:9px;}
.entry-content blockquote{
  margin:26px 0;padding:14px 24px;border-left:4px solid var(--shu);
  background:var(--cream);font-style:italic;color:var(--ink);
}
.entry-content blockquote p:last-child{margin-bottom:0;}
.entry-content strong{color:var(--sumi);}
.entry-content .jp{font-family:"Shippori Mincho","Noto Serif JP",serif;}
.entry-content figure{margin:26px 0;}
.entry-content figcaption{font-size:13.5px;color:var(--muted);margin-top:7px;text-align:center;font-style:italic;}
.entry-content hr{border:0;border-top:1px solid var(--line);margin:34px 0;}

.lead{font-size:20px;color:var(--ink);}

/* note / callout box */
.note{
  background:var(--cream);border:1px solid var(--line);border-left:4px solid var(--indigo);
  padding:18px 22px;margin:26px 0;border-radius:3px;
}
.note p:last-child{margin-bottom:0;}
.note .note-title{font-family:"Shippori Mincho",serif;font-weight:600;color:var(--indigo);display:block;margin-bottom:6px;font-size:16px;letter-spacing:.5px;}

/* tables */
.entry-content table{width:100%;border-collapse:collapse;margin:24px 0;font-size:16px;}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:9px 13px;text-align:left;vertical-align:top;}
.entry-content th{background:var(--indigo);color:#f3ece0;font-family:"Shippori Mincho",serif;font-weight:600;letter-spacing:.5px;}
.entry-content tbody tr:nth-child(even){background:var(--cream);}

/* ---------- Post list (blog / archive) ---------- */
.post-card{padding:26px 0;border-bottom:1px solid var(--line);}
.post-card:first-child{padding-top:0;}
.post-card h2{font-size:26px;margin:0 0 8px;}
.post-card h2 a{color:var(--sumi);}
.post-card h2 a:hover{color:var(--shu);text-decoration:none;}
.post-card .excerpt{margin:10px 0 12px;color:var(--ink);}
.readmore{font-family:"Shippori Mincho",serif;font-size:14.5px;letter-spacing:.5px;}
.readmore::after{content:" →";}

/* hero (home) */
.hero{
  background:linear-gradient(rgba(28,28,26,.62),rgba(33,48,71,.72)),
    radial-gradient(circle at 30% 20%,#3a4f6e,#1b2738);
  color:#f4eee2;border-radius:5px;padding:54px 44px;margin-bottom:6px;
  border:1px solid #16202f;
}
.hero h1{color:#fff;font-size:40px;margin:0 0 14px;line-height:1.18;}
.hero .jp-sub{font-family:"Shippori Mincho",serif;color:#cdbf9f;letter-spacing:6px;font-size:17px;margin:0 0 18px;}
.hero p{font-size:18.5px;color:#e7dfcf;margin:0 0 24px;max-width:60ch;}
.btn{
  display:inline-block;background:var(--shu);color:#fff;font-family:"Shippori Mincho",serif;
  letter-spacing:.6px;padding:12px 26px;border-radius:3px;text-decoration:none;font-size:16px;
  border:1px solid var(--shu-dark);
}
.btn:hover{background:var(--shu-dark);color:#fff;text-decoration:none;}
.btn.ghost{background:transparent;border:1px solid #d8ccb4;color:#f1e9da;margin-left:10px;}
.btn.ghost:hover{background:rgba(255,255,255,.08);}

/* feature row on home */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin:34px 0 8px;}
@media(max-width:760px){.features{grid-template-columns:1fr;}}
.feature{background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:22px 22px 20px;}
.feature h3{margin:0 0 8px;font-size:19px;color:var(--indigo);}
.feature p{margin:0;font-size:16px;color:var(--ink);}

/* ---------- Sidebar widgets ---------- */
.sidebar .widget{margin-bottom:34px;}
.widget-title{
  font-family:"Shippori Mincho",serif;font-size:17px;letter-spacing:1px;color:var(--sumi);
  text-transform:uppercase;margin:0 0 14px;padding-bottom:9px;border-bottom:2px solid var(--indigo);
}
.widget p{font-size:15.5px;margin:0 0 12px;color:var(--ink);}
.widget ul{list-style:none;margin:0;padding:0;}
.widget li{border-bottom:1px solid var(--line);padding:9px 0;font-size:15.5px;line-height:1.45;}
.widget li:last-child{border-bottom:0;}
.widget li a{color:var(--indigo-soft);}
.widget li a:hover{color:var(--shu);}
.widget li .date{display:block;font-size:12.5px;color:var(--muted);margin-top:2px;font-family:"Lora",serif;}
.widget.boxed{background:var(--cream);border:1px solid var(--line);border-radius:4px;padding:22px;}
.widget.cta{background:var(--indigo);color:#ece3d2;border-radius:4px;padding:24px;}
.widget.cta .widget-title{color:#fff;border-bottom-color:var(--shu);}
.widget.cta p{color:#d8cfbe;}
.widget.cta .btn{margin-top:6px;}

/* ---------- Footer ---------- */
.site-footer{background:var(--sumi);color:#c8c1b3;margin-top:54px;padding:46px 0 28px;}
.site-footer .wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.foot-cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;}
@media(max-width:760px){.foot-cols{grid-template-columns:1fr;gap:28px;}}
.site-footer h4{color:#f2eadc;font-size:16px;letter-spacing:1px;margin:0 0 14px;text-transform:uppercase;}
.site-footer a{color:#d6cdba;}
.site-footer a:hover{color:#fff;}
.site-footer ul{list-style:none;margin:0;padding:0;}
.site-footer li{padding:5px 0;font-size:15px;}
.site-footer p{font-size:15px;line-height:1.7;margin:0 0 10px;color:#bdb6a7;}
.foot-bottom{border-top:1px solid #3a3833;margin-top:34px;padding-top:18px;font-size:13.5px;color:#928c80;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.foot-bottom .jp{font-family:"Shippori Mincho",serif;letter-spacing:3px;}

/* gallery grid */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0;}
@media(max-width:640px){.gallery-grid{grid-template-columns:repeat(2,1fr);}}
.gallery-grid .tile{
  aspect-ratio:4/3;border:1px solid var(--line);border-radius:4px;overflow:hidden;
  background:var(--cream);display:flex;align-items:center;justify-content:center;
  color:var(--muted);font-size:14px;text-align:center;padding:10px;font-family:"Shippori Mincho",serif;
}

/* contact / signup simple */
.info-list{list-style:none;padding:0;margin:0 0 22px;}
.info-list li{padding:10px 0;border-bottom:1px solid var(--line);font-size:16.5px;}
.info-list li strong{font-family:"Shippori Mincho",serif;color:var(--indigo);display:inline-block;min-width:120px;}

/* skip link */
.skip{position:absolute;left:-9999px;}
.skip:focus{left:8px;top:8px;background:#fff;padding:8px 12px;z-index:99;}
