@import url('https://fonts.googleapis.com/css2?family=M+PLUS+Rounded+1c:wght@300;400;500&display=swap');

/* ── Variables ── */
:root {
  --pink:   #FDB4DC;
  --blue:   #3614F8;
  --cream:  #FFF8F0;
  --border: rgba(54,20,248,0.13);
  --font:   'M PLUS Rounded 1c', sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body {
  font-family: var(--font);
  background: var(--cream);
  color: var(--blue);
  -webkit-font-smoothing: antialiased;
}

/* ── Animations ── */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(22px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes fadeIn {
  from { opacity:0; } to { opacity:1; }
}
@keyframes slideRight {
  from { opacity:0; transform:translateX(-16px); }
  to   { opacity:1; transform:translateX(0); }
}
@keyframes slideDown {
  from { opacity:0; transform:translateY(-14px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes scaleIn {
  from { opacity:0; transform:scale(0.96); }
  to   { opacity:1; transform:scale(1); }
}
@keyframes ringPulse {
  0%   { box-shadow: 0 0 0 0    rgba(253,180,220,0.65); }
  70%  { box-shadow: 0 0 0 13px rgba(253,180,220,0); }
  100% { box-shadow: 0 0 0 0    rgba(253,180,220,0); }
}
@keyframes drift {
  0%,100% { transform:translateY(0)    rotate(0deg); }
  50%      { transform:translateY(-9px) rotate(5deg); }
}
@keyframes blobMorph {
  0%,100% { border-radius:60% 40% 55% 45% / 50% 55% 45% 50%; }
  33%     { border-radius:45% 55% 40% 60% / 55% 45% 55% 45%; }
  66%     { border-radius:55% 45% 60% 40% / 45% 55% 45% 55%; }
}
@keyframes overlayPulse {
  0%,100% { opacity:1; } 50% { opacity:0.88; }
}
@keyframes shimmer {
  0%   { background-position:-200% center; }
  100% { background-position: 200% center; }
}
@keyframes floatPetal {
  0%   { transform:translateY(0)     rotate(0deg)   scale(1); opacity:0.38; }
  50%  { transform:translateY(-14px) rotate(12deg)  scale(1.05); opacity:0.55; }
  100% { transform:translateY(0)     rotate(0deg)   scale(1); opacity:0.38; }
}
@keyframes sparkle {
  0%,100% { opacity:0.45; transform:scale(1); }
  50%     { opacity:0.9;  transform:scale(1.3); }
}

/* scroll-reveal */
.reveal {
  opacity:0; transform:translateY(20px);
  transition:opacity 0.65s ease, transform 0.65s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }
.d1 { transition-delay:0.08s; }
.d2 { transition-delay:0.18s; }
.d3 { transition-delay:0.28s; }

/* ── Cocoon干渉リセット ── */
#main, main.main {
  width:100% !important; max-width:none !important;
  margin:0 !important; padding:0 !important;
}
#contents {
  width:100% !important; max-width:none !important;
  padding:0 !important; margin:0 !important;
}
.container { width:100% !important; max-width:none !important; }
.content {
  width:100% !important; max-width:none !important;
  margin:0 !important; padding:0 !important;
}
.article {
  margin:0 !important; padding:0 !important;
  border:none !important; box-shadow:none !important;
  background:transparent !important;
}
.entry-content { margin:0 !important; padding:0 !important; }

/* ============================================================
   NAVIGATION
   ============================================================ */
#header, #header-container {
  background: var(--cream) !important;
  border-bottom: 1px solid var(--border) !important;
  box-shadow: none !important;
  animation: slideDown 0.5s ease both;
}
#site-name, .site-name-text, .logo-header {
  font-family: var(--font) !important;
  font-size: 17px !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  color: var(--blue) !important;
}
#navi .navi-in > ul > li > a,
.global-nav li a {
  font-family: var(--font) !important;
  font-size: 10px !important;
  letter-spacing: 0.14em !important;
  color: var(--blue) !important;
  opacity: 0.55;
  text-decoration: none !important;
  position: relative; padding-bottom: 4px !important;
  transition: opacity 0.2s;
}
#navi .navi-in > ul > li > a::after,
.global-nav li a::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1.5px;
  background: var(--pink);
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.25s ease;
}
#navi .navi-in > ul > li > a:hover { opacity:1 !important; }
#navi .navi-in > ul > li > a:hover::after { transform:scaleX(1); }

/* ============================================================
   HERO
   ============================================================ */
.omiso-hero {
  position: relative;
  height: 60vh;
  min-height: 380px;
  max-height: 520px;
  background: var(--blue);
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.omiso-hero__svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  animation: scaleIn 1.1s ease both;
}
.petal { animation: floatPetal 5s ease-in-out infinite; }
.petal:nth-child(2) { animation-delay: 0.8s; animation-duration: 6.5s; }
.petal:nth-child(3) { animation-delay: 1.6s; animation-duration: 5.8s; }
.petal:nth-child(4) { animation-delay: 2.4s; animation-duration: 7s; }
.sparkle-dot { animation: sparkle 3s ease-in-out infinite; }
.sparkle-dot:nth-child(2) { animation-delay: 1s; }
.sparkle-dot:nth-child(3) { animation-delay: 2s; }
.omiso-hero__fade-b {
  position:absolute; inset:0;
  background:linear-gradient(to top,
    rgba(54,20,248,0.72) 0%,
    rgba(54,20,248,0.28) 38%,
    transparent 62%);
  animation: overlayPulse 7s ease-in-out infinite 1.5s;
}
.omiso-hero__content {
  position:relative; z-index:3;
  padding:0 52px 52px;
  max-width:500px;
}
.omiso-hero__tag {
  display:block;
  font-size:9px; letter-spacing:0.32em; text-transform:uppercase;
  color:var(--pink); opacity:0.9; margin-bottom:12px;
  animation: slideRight 0.6s ease both 0.7s;
}
.omiso-hero__title {
  font-size:clamp(26px,3.6vw,46px); font-weight:300;
  line-height:1.25; color:var(--cream); margin-bottom:14px;
  animation: fadeUp 0.7s ease both 0.85s;
}
.omiso-hero__title strong { font-weight:500; color:var(--pink); }
.omiso-hero__sub {
  font-size:11px; color:var(--cream); opacity:0.62;
  line-height:1.95; margin-bottom:30px; letter-spacing:0.03em;
  animation: fadeUp 0.6s ease both 1.05s;
}
.omiso-hero__btns {
  display:flex; gap:10px; flex-wrap:wrap;
  animation: fadeUp 0.6s ease both 1.2s;
}

/* ── Buttons ── */
.btn-omiso-primary {
  display:inline-block; padding:11px 30px;
  background:var(--pink); color:var(--blue) !important;
  font-family:var(--font); font-size:10px; font-weight:500;
  letter-spacing:0.16em; text-decoration:none !important;
  border:none; border-radius:100px; cursor:pointer;
  transition:transform 0.18s, box-shadow 0.18s;
  animation: ringPulse 2.5s ease-out infinite 2.4s;
}
.btn-omiso-primary:hover {
  transform:translateY(-2px) scale(1.03);
  box-shadow:0 6px 24px rgba(253,180,220,0.55);
}
.btn-omiso-ghost {
  display:inline-block; padding:10px 30px;
  background:transparent; color:var(--cream) !important;
  font-family:var(--font); font-size:10px; font-weight:400;
  letter-spacing:0.16em; text-decoration:none !important;
  border:1.5px solid rgba(253,180,220,0.42); border-radius:100px; cursor:pointer;
  transition:border-color 0.2s, background 0.2s, transform 0.18s;
}
.btn-omiso-ghost:hover {
  border-color:var(--pink); background:rgba(253,180,220,0.1);
  transform:translateY(-2px);
}
.btn-omiso-blue {
  display:inline-block; padding:11px 28px;
  background:var(--blue); color:var(--pink) !important;
  font-family:var(--font); font-size:10px; font-weight:500;
  letter-spacing:0.16em; text-decoration:none !important;
  border:none; border-radius:100px; cursor:pointer;
  transition:transform 0.18s, box-shadow 0.18s;
}
.btn-omiso-blue:hover {
  transform:translateY(-2px);
  box-shadow:0 6px 24px rgba(54,20,248,0.3);
}

/* ============================================================
   CATEGORY STRIP
   ============================================================ */
.omiso-cats {
  display:flex; border-bottom:1px solid var(--border);
  background:var(--cream); overflow-x:auto;
}
.omiso-cats::-webkit-scrollbar { display:none; }
.omiso-cats__item {
  flex:1; flex-shrink:0; white-space:nowrap;
  padding:13px 8px; text-align:center;
  font-family:var(--font); font-size:9px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--blue); opacity:0.45;
  border-right:1px solid var(--border); cursor:pointer;
  position:relative; overflow:hidden;
  transition:opacity 0.2s, background 0.2s;
}
.omiso-cats__item:last-child { border-right:none; }
.omiso-cats__item::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--blue); transform:scaleX(0); transform-origin:center;
  transition:transform 0.25s ease;
}
.omiso-cats__item:hover { opacity:0.85; background:rgba(253,180,220,0.1); }
.omiso-cats__item:hover::after,
.omiso-cats__item.is-active::after { transform:scaleX(1); }
.omiso-cats__item.is-active {
  opacity:1; font-weight:500; background:rgba(253,180,220,0.2);
}

/* ============================================================
   JOURNAL
   ============================================================ */
.omiso-journal {
  display:grid; grid-template-columns:1fr 280px;
  border-bottom:1px solid var(--border);
}
.omiso-journal__featured { border-right:1px solid var(--border); }
.omiso-journal__feat-thumb {
  width:100%; aspect-ratio:16/8; object-fit:cover; display:block;
  background:rgba(253,180,220,0.2); position:relative; overflow:hidden;
}
.omiso-journal__feat-thumb::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.07),transparent);
  background-size:200% 100%; animation:shimmer 3.5s ease-in-out infinite;
}
.omiso-journal__feat-body { padding:24px 32px 32px; }
.omiso-journal__cat {
  display:block; font-size:9px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--blue); opacity:0.4; margin-bottom:9px;
}
.omiso-journal__title {
  font-size:20px; font-weight:500; color:var(--blue);
  line-height:1.55; margin-bottom:12px;
}
.omiso-journal__desc {
  font-size:12px; color:var(--blue); opacity:0.52;
  line-height:1.95; margin-bottom:22px;
}
.omiso-journal__side { display:flex; flex-direction:column; }
.omiso-journal__side-label {
  padding:16px 22px 12px; font-size:9px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--blue); opacity:0.38; border-bottom:1px solid var(--border);
}
.omiso-journal__side-item {
  padding:16px 22px; border-bottom:1px solid var(--border);
  cursor:pointer; position:relative; overflow:hidden;
  transition:background 0.18s, padding-left 0.22s;
}
.omiso-journal__side-item:last-child { border-bottom:none; }
.omiso-journal__side-item::before {
  content:''; position:absolute; left:0; top:0; bottom:0; width:3px;
  background:var(--pink); transform:scaleY(0); transform-origin:center;
  transition:transform 0.2s ease; border-radius:0 2px 2px 0;
}
.omiso-journal__side-item:hover { background:rgba(253,180,220,0.09); padding-left:28px; }
.omiso-journal__side-item:hover::before { transform:scaleY(1); }
.omiso-journal__side-cat {
  font-size:8px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--blue); opacity:0.36; margin-bottom:6px;
}
.omiso-journal__side-title { font-size:12px; color:var(--blue); line-height:1.6; }

/* ============================================================
   CARDS
   ============================================================ */
.omiso-section { padding:50px 44px; background:var(--cream); }
.omiso-section__header {
  display:flex; justify-content:space-between; align-items:baseline; margin-bottom:26px;
}
.omiso-section__label {
  font-size:9px; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--blue); opacity:0.4; margin-bottom:4px;
}
.omiso-section__title { font-size:26px; font-weight:300; color:var(--blue); }
.omiso-section__more {
  font-size:9px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--blue); opacity:0.4; text-decoration:none;
  border-bottom:1px solid rgba(54,20,248,0.16); padding-bottom:2px;
  transition:opacity 0.2s;
}
.omiso-section__more:hover { opacity:0.9; }
.omiso-cards { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.omiso-card {
  border-radius:16px; overflow:hidden;
  border:1px solid var(--border); background:#fff; cursor:pointer;
  transition:transform 0.25s, box-shadow 0.25s;
}
.omiso-card:hover { transform:translateY(-5px); box-shadow:0 12px 36px rgba(54,20,248,0.1); }
.omiso-card__thumb {
  width:100%; aspect-ratio:4/3; object-fit:cover; display:block;
  background:rgba(253,180,220,0.18);
  transition:transform 0.35s;
}
.omiso-card:hover .omiso-card__thumb { transform:scale(1.04); }
.omiso-card__body { padding:14px 16px 18px; }
.omiso-card__cat {
  font-size:8px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--blue); opacity:0.4; margin-bottom:6px;
}
.omiso-card__title { font-size:13px; color:var(--blue); line-height:1.65; }

/* ============================================================
   ABOUT
   ============================================================ */
.omiso-about {
  display:grid; grid-template-columns:1fr 1fr;
  border-top:1px solid var(--border); background:var(--blue);
}
.omiso-about__left { padding:58px 52px; border-right:1px solid rgba(253,180,220,0.16); }
.omiso-about__right { padding:58px 52px; display:flex; align-items:center; }
.omiso-about__eyebrow {
  font-size:9px; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--pink); opacity:0.65; margin-bottom:12px;
}
.omiso-about__heading {
  font-size:24px; font-weight:300; color:var(--cream);
  line-height:1.5; margin-bottom:16px;
}
.omiso-about__body {
  font-size:12px; line-height:2; color:var(--cream); opacity:0.54; margin-bottom:28px;
}
.omiso-about__photo {
  width:100%; aspect-ratio:1; border-radius:50%; object-fit:cover; display:block;
  background:rgba(253,180,220,0.1); border:2px solid rgba(253,180,220,0.2);
  animation:drift 6s ease-in-out infinite;
}

/* ============================================================
   PANELS
   ============================================================ */
.omiso-panels { display:grid; grid-template-columns:1fr 1fr; border-top:1px solid var(--border); }
.omiso-panel {
  padding:50px 52px; border-right:1px solid var(--border);
  position:relative; overflow:hidden;
}
.omiso-panel:last-child { border-right:none; }
.omiso-panel::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:120px; height:120px;
  background:rgba(253,180,220,0.11); border-radius:50%;
  animation:blobMorph 10s ease-in-out infinite;
}
.omiso-panel__num { font-size:60px; font-weight:300; color:rgba(253,180,220,0.48); line-height:1; margin-bottom:8px; }
.omiso-panel__label {
  font-size:9px; letter-spacing:0.26em; text-transform:uppercase;
  color:var(--blue); opacity:0.4; margin-bottom:8px;
}
.omiso-panel__title { font-size:22px; font-weight:300; color:var(--blue); margin-bottom:13px; line-height:1.45; }
.omiso-panel__desc { font-size:11px; line-height:1.95; color:var(--blue); opacity:0.52; margin-bottom:24px; }

/* ============================================================
   FOOTER
   ============================================================ */
#footer, .omiso-footer {
  padding:28px 44px !important;
  display:flex !important;
  justify-content:space-between !important;
  align-items:center !important;
  border-top:1px solid var(--border) !important;
  background:var(--cream) !important;
  position:relative; overflow:hidden;
}
#footer::before, .omiso-footer::before {
  content:''; position:absolute; bottom:-28px; left:50%; transform:translateX(-50%);
  width:260px; height:52px; background:rgba(253,180,220,0.1); border-radius:50%;
  animation:blobMorph 12s ease-in-out infinite;
}
.omiso-footer__logo { font-size:14px; font-weight:500; letter-spacing:0.07em; color:var(--blue); }
.omiso-footer__links { display:flex; gap:20px; list-style:none; }
.omiso-footer__links a {
  font-size:9px; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--blue); opacity:0.36; text-decoration:none; transition:opacity 0.2s;
}
.omiso-footer__links a:hover { opacity:0.9; }
.omiso-footer__copy { font-size:9px; color:var(--blue); opacity:0.24; }

/* ============================================================
   RESPONSIVE SP
   ============================================================ */
@media (max-width: 768px) {
  .omiso-hero { height:58vw; min-height:230px; max-height:310px; }
  .omiso-hero__content { padding:0 20px 24px; max-width:100%; }
  .omiso-hero__title { font-size:20px; }
  .omiso-hero__sub { display:none; }
  .btn-omiso-primary, .btn-omiso-ghost { padding:9px 18px; font-size:9px; }

  .omiso-journal { grid-template-columns:1fr; }
  .omiso-journal__featured { border-right:none; border-bottom:1px solid var(--border); }

  .omiso-cards { grid-template-columns:1fr; gap:12px; }
  .omiso-section { padding:36px 20px; }

  .omiso-about { grid-template-columns:1fr; }
  .omiso-about__left { padding:36px 20px; border-right:none; border-bottom:1px solid rgba(253,180,220,0.16); }
  .omiso-about__right { padding:28px 20px; }
  .omiso-about__photo { border-radius:14px; aspect-ratio:16/9; }

  .omiso-panels { grid-template-columns:1fr; }
  .omiso-panel { padding:32px 20px; border-right:none; border-bottom:1px solid var(--border); }
  .omiso-panel:last-child { border-bottom:none; }

  #footer, .omiso-footer {
    flex-direction:column !important; gap:14px !important;
    padding:22px 20px !important; text-align:center !important;
  }
}