@charset "UTF-8";

/*
Theme Name: Ekko Child
Description: Cocoon child theme for ekkohappy.com notebook editorial styling.
Author: NAKAK10
Template: cocoon-master
Version: 0.1.0
Text Domain: ekko-child
*/

:root {
  --ekko-bg: #f6efe3;
  --ekko-bg-soft: #fbf7ef;
  --ekko-paper: #fffdf8;
  --ekko-ink: #3b3028;
  --ekko-muted: #75695d;
  --ekko-line: #ded2c2;
  --ekko-coral: #a85f3a;
  --ekko-coral-deep: #744631;
  --ekko-coral-soft: #efe1d2;
  --ekko-rose: #c97872;
  --ekko-shadow: 0 1px 3px rgba(64, 45, 31, 0.04);
  --ekko-radius: 8px;
  --ekko-sans: -apple-system, BlinkMacSystemFont, "Hiragino Sans", "Yu Gothic", "YuGothic", sans-serif;
  --ekko-serif: "Hiragino Mincho ProN", "Yu Mincho", "YuMincho", "Noto Serif JP", serif;
}

body {
  background: var(--ekko-bg);
  color: var(--ekko-ink);
  font-family: var(--ekko-sans);
  letter-spacing: 0;
  text-rendering: optimizeLegibility;
}

a {
  color: var(--ekko-coral-deep);
}

a:hover {
  color: var(--ekko-coral);
}

#container,
.container,
.header-container,
.navi,
.footer {
  background: transparent;
}

.header-container {
  border-bottom: 1px solid var(--ekko-line);
}

.header {
  padding: 26px 16px 14px;
}

.logo {
  text-align: left;
}

.logo-text,
.site-name-text {
  color: var(--ekko-ink);
  font-family: var(--ekko-serif);
  font-size: clamp(27px, 4vw, 40px);
  font-weight: 600;
  letter-spacing: 0.02em;
  line-height: 1.2;
}

.tagline {
  color: var(--ekko-muted);
  font-size: 12px;
  line-height: 1.7;
  margin: 0 0 6px;
  text-align: left;
}

.navi {
  border-bottom: 1px solid var(--ekko-line);
}

.navi-in > ul {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  justify-content: flex-start;
  padding: 0;
}

.navi-in > ul > li,
.navi-in > ul > li a {
  border-radius: 0;
}

.navi-in > ul > li {
  border-right: 1px solid rgba(222, 210, 194, 0.72);
}

.navi-in > ul > li:first-child {
  border-left: 1px solid rgba(222, 210, 194, 0.72);
}

.navi-in > ul > li a {
  color: var(--ekko-ink);
  border-bottom: 2px solid transparent;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
  padding: 12px 16px 10px;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.navi-in > ul > li a:hover,
.navi-in > ul > li.current-menu-item > a {
  background: rgba(255, 253, 248, 0.45);
  border-bottom-color: var(--ekko-coral);
  color: var(--ekko-coral-deep);
}

.content {
  margin-top: 26px;
}

.main,
.sidebar {
  background: transparent;
  border: 0;
}

.main {
  padding: 0;
}

.article,
.entry-card-wrap,
.related-entry-card-wrap,
.pagination .page-numbers,
.pager-links a,
.comment-area,
.comment-respond,
.toc {
  background: rgba(255, 253, 248, 0.88);
  border: 1px solid var(--ekko-line);
  box-shadow: var(--ekko-shadow);
}

.article {
  border-radius: 10px;
  padding: clamp(22px, 4vw, 40px);
}

.entry-title,
.article h1,
.article h2,
.article h3,
.widget-title {
  color: var(--ekko-ink);
  font-family: var(--ekko-serif);
  letter-spacing: 0.005em;
}

.article h1,
.entry-title {
  font-size: clamp(28px, 4vw, 42px);
  line-height: 1.35;
}

.article h2 {
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--ekko-line);
  border-radius: 0;
  border-top: 1px solid var(--ekko-line);
  padding: 13px 0 13px 14px;
  position: relative;
}

.article h2::before {
  background: var(--ekko-coral);
  content: "";
  inset: 16px auto 16px 0;
  position: absolute;
  width: 3px;
}

.article h3 {
  border-bottom: 1px dashed var(--ekko-line);
  padding-bottom: 8px;
}

.article p,
.article li,
.entry-content p,
.entry-content li {
  font-size: 16px;
  line-height: 1.9;
}

.date-tags,
.post-date,
.post-update,
.entry-card-info,
.related-entry-card-info {
  color: var(--ekko-muted);
}

.entry-card-wrap,
.related-entry-card-wrap {
  border-radius: var(--ekko-radius);
  margin-bottom: 14px;
  overflow: hidden;
  transition: background-color 0.2s ease, border-color 0.2s ease;
}

.entry-card-wrap:hover,
.related-entry-card-wrap:hover {
  background: var(--ekko-bg-soft);
  border-color: #c9aa92;
}

.entry-card,
.related-entry-card {
  padding: 14px;
}

.entry-card-thumb,
.related-entry-card-thumb,
.eye-catch-wrap img {
  border-radius: 6px;
  overflow: hidden;
}

.entry-card-title,
.related-entry-card-title {
  color: var(--ekko-ink);
  font-family: var(--ekko-sans);
  font-size: clamp(17px, 2vw, 21px);
  line-height: 1.55;
  letter-spacing: 0;
}

.entry-card-snippet,
.related-entry-card-snippet {
  color: var(--ekko-muted);
  line-height: 1.85;
}

.cat-label,
.cat-link,
.tag-link,
.tagcloud a {
  background: #fbf3e9;
  border: 1px solid #d8c7b4;
  border-radius: 4px;
  color: var(--ekko-coral-deep);
  font-size: 12px;
  font-weight: 600;
  line-height: 1;
  padding: 5px 7px;
}

.entry-card-categorys .entry-category,
.related-entry-card-categorys .entry-category {
  background: transparent;
  border: 0;
  border-radius: 0;
  color: var(--ekko-muted);
  font-weight: 500;
  padding: 0;
}

.entry-card-categorys .entry-category + .entry-category::before,
.related-entry-card-categorys .entry-category + .entry-category::before {
  color: #a99a8c;
  content: " / ";
}

.breadcrumb,
.breadcrumb a {
  color: var(--ekko-muted);
}

.sidebar {
  padding: 0;
}

.widget {
  background: transparent;
  border: 0;
  border-radius: 0;
  border-top: 1px solid var(--ekko-line);
  box-shadow: none;
  margin-bottom: 20px;
  padding: 18px 0;
}

.widget:first-child {
  border-top: 0;
  padding-top: 0;
}

.widget .widget-title,
.widget-sidebar-title.widget-title {
  background: transparent;
  border-bottom: 1px solid var(--ekko-line);
  border-radius: 0;
  font-family: var(--ekko-sans);
  font-size: 15px;
  letter-spacing: 0.02em;
  margin-bottom: 12px;
  padding: 0 0 9px;
}

.widget ul {
  margin-bottom: 0;
}

.widget li {
  border-bottom: 1px solid rgba(222, 210, 194, 0.75);
  padding: 8px 0;
}

.widget li:last-child {
  border-bottom: 0;
}

.pagination,
.pager-links {
  gap: 8px;
}

.pagination .page-numbers,
.pager-links a,
.pagination-next-link,
.comment-btn,
input[type="submit"],
button[type="submit"] {
  border-color: rgba(168, 95, 58, 0.28);
  border-radius: 6px;
  color: var(--ekko-coral-deep);
}

.pagination .page-numbers.current,
.pagination .page-numbers:hover,
.pager-links a:hover,
.pagination-next-link:hover,
.comment-btn:hover,
input[type="submit"]:hover,
button[type="submit"]:hover {
  background: var(--ekko-coral);
  border-color: var(--ekko-coral);
  color: #fff;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="search"],
textarea,
select {
  background: var(--ekko-paper);
  border: 1px solid var(--ekko-line);
  border-radius: 6px;
  color: var(--ekko-ink);
  padding: 12px 14px;
}

input:focus,
textarea:focus,
select:focus {
  border-color: var(--ekko-coral);
  box-shadow: 0 0 0 3px rgba(168, 95, 58, 0.14);
  outline: 0;
}

.comment-area,
.comment-respond {
  border-radius: var(--ekko-radius);
  margin-top: 24px;
  padding: 24px;
}

.footer {
  border-top: 1px solid var(--ekko-line);
  color: var(--ekko-muted);
  margin-top: 44px;
  padding: 32px 16px;
}

.footer a {
  color: var(--ekko-coral-deep);
}

@media (max-width: 834px) {
  .header {
    padding-top: 18px;
  }

  .navi-in > ul {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0;
  }

  .navi-in > ul > li a {
    font-size: 13px;
    white-space: nowrap;
  }

  .navi-in > ul > li {
    flex: 0 0 auto;
  }

  .content {
    margin-top: 18px;
  }

  .article,
  .comment-area,
  .comment-respond {
    border-radius: 8px;
  }

  .entry-card,
  .related-entry-card {
    padding: 12px;
  }
}

@media (max-width: 480px) {
  body {
    background: var(--ekko-bg);
  }

  .header {
    padding: 12px 14px 8px;
  }

  .tagline {
    display: none;
  }

  .logo-text,
  .site-name-text {
    font-size: 26px;
    line-height: 1.15;
  }

  .navi-in > ul > li a {
    align-items: center;
    display: flex;
    min-height: 38px;
    padding: 8px 13px 7px;
  }

  .content {
    margin-top: 10px;
  }

  .footer {
    margin-bottom: 56px;
  }

  .article {
    padding: 20px 16px;
  }

  .article p,
  .article li,
  .entry-content p,
  .entry-content li {
    font-size: 15px;
    line-height: 1.9;
  }

  .entry-card-wrap,
  .related-entry-card-wrap,
  .widget {
    margin-bottom: 10px;
  }

  .entry-card,
  .related-entry-card,
  .new-entry-card {
    align-items: flex-start;
    display: flex;
    gap: 9px;
    min-width: 0;
    padding: 9px;
  }

  .entry-card-thumb,
  .related-entry-card-thumb,
  .new-entry-card-thumb {
    float: none;
    flex: 0 0 min(34vw, 112px);
    margin: 0;
    max-width: 112px;
    width: min(34vw, 112px);
  }

  .entry-card-thumb img,
  .related-entry-card-thumb img,
  .new-entry-card-thumb img {
    aspect-ratio: 16 / 9;
    height: auto;
    object-fit: cover;
    width: 100%;
  }

  .entry-card-content,
  .related-entry-card-content,
  .new-entry-card-content {
    flex: 1 1 auto;
    margin-left: 0;
    min-width: 0;
    overflow-wrap: anywhere;
    width: auto;
  }

  .entry-card-thumb .cat-label,
  .related-entry-card-thumb .cat-label,
  .new-entry-card-thumb .cat-label {
    display: none;
  }

  .entry-card-meta,
  .related-entry-card-meta,
  .new-entry-card-meta {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 4px 7px;
    justify-content: flex-end;
    margin-top: 6px;
  }

  .entry-card-info,
  .related-entry-card-info,
  .new-entry-card-info {
    flex: 0 0 auto;
    order: 2;
  }

  .entry-card-meta .entry-card-categorys,
  .related-entry-card-meta .related-entry-card-categorys,
  .new-entry-card-meta .new-entry-card-categorys,
  .e-card-meta .e-card-categorys {
    align-items: center;
    display: flex;
    flex: 0 1 auto;
    flex-wrap: wrap;
    gap: 4px;
    justify-content: flex-end;
    min-width: 0;
    order: 1;
  }

  .entry-card-categorys .entry-category,
  .related-entry-card-categorys .entry-category,
  .new-entry-card-categorys .entry-category {
    background: #fbf3e9;
    border: 1px solid #d8c7b4;
    border-radius: 4px;
    color: var(--ekko-coral-deep);
    display: inline-flex;
    font-size: 10px;
    font-weight: 600;
    line-height: 1;
    max-width: 100%;
    overflow: hidden;
    padding: 4px 6px;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .entry-card-categorys .entry-category:not(:first-child),
  .related-entry-card-categorys .entry-category:not(:first-child),
  .new-entry-card-categorys .entry-category:not(:first-child) {
    display: none;
  }

  .entry-card-title,
  .related-entry-card-title,
  .new-entry-card-title {
    font-size: 15px;
    line-height: 1.45;
  }

  .entry-card-snippet,
  .related-entry-card-snippet,
  .new-entry-card-snippet {
    font-size: 13px;
    line-height: 1.6;
  }
}
