@charset "UTF-8";
/* Theme Name: styleb-press-modern-refined */

/* ==========================================================================
   Variables
   ========================================================================== */
:root {
  /* Colors */
  --color-text-main: #2c3e50;
  --color-text-light: #7f8c8d;
  --color-text-white: #ffffff;

  --color-primary: #2980b9;
  --color-primary-rgb: 41, 128, 185;
  --color-primary-hover: #3498db;
  --color-accent: #e74c3c;
  --color-bg-sidebar-widget: #ffffff;

  --color-bg-body: #f9f9f9;
  --color-bg-white: #ffffff;
  --color-bg-footer: #2c3e50;
  --color-border: #ecf0f1;

  /* Fonts */
  --font-family-base: 'Noto Sans JP', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;

  /* Spacing */
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 32px;
  --spacing-lg: 64px;
  --spacing-xl: 120px;

  /* Layout */
  --container-width: 1100px;
  --header-height: 70px;

  /* Shadows */
  --shadow-card: 0 10px 30px rgba(0, 0, 0, 0.05);
  --shadow-hover: 0 20px 40px rgba(0, 0, 0, 0.1);
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-family-base);
  font-size: 16px;
  line-height: 1.8;
  color: var(--color-text-main);
  background-color: var(--color-bg-body);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  color: var(--color-primary);
  text-decoration: none;
  transition: all 0.3s ease;
}

a:hover {
  color: var(--color-primary-hover);
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  border-radius: 4px;
  /* Subtle radius */
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 500;
}

p {
  margin-bottom: 2em;
}

/* ==========================================================================
   Animation Classes (Scroll Reveal)
   ========================================================================== */
.fade-in-up {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.165, 0.84, 0.44, 1), transform 0.8s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.fade-in-up.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ==========================================================================
   Header
   ========================================================================== */
header#masthead {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.05);
  position: sticky;
  top: 0;
  z-index: 100;
  transition: padding 0.3s;
  width: 100%;
}

.header-inner {
  /* position: relative; removed to allow nav to align to viewport */
  max-width: var(--container-width);
  margin: 0 auto;
  padding: 10px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: var(--header-height);
}

.title {
  padding: 0;
  text-align: center;
}

.logo {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-text-main);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  display: block;
  line-height: 1.2;
}

.title p {
  font-size: 0.75rem;
  color: var(--color-text-light);
  margin-top: 0;
  margin-bottom: 0;
  letter-spacing: 0.1em;
}

/* Cover / Hero */
.cover {
  color: var(--color-text-white);
  padding: var(--spacing-xl) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-top: 0;
  margin-bottom: var(--spacing-lg);
  /* Add spacing below visual */
}

/* Parallax removed for performance */
.cover[style] {
  background-attachment: scroll !important;
}

.cover::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(44, 62, 80, 0.5);
  /* Stylish dark overlay */
  z-index: 1;
}

.cover section {
  position: relative;
  z-index: 2;
  animation: fadeIn 1.5s ease-out;
}

.cover h2 {
  font-size: 2.5rem;
  margin-bottom: var(--spacing-md);
  text-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* ==========================================================================
   Navigation (Hamburger Everywhere)
   ========================================================================== */
.header_nav {
  position: absolute;
  top: 50%;
  left: 20px;
  transform: translateY(-50%);
  z-index: 1000;
  display: flex;
  align-items: center;
}

.nav-toggle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 1002;
  border-radius: 50%;
  transition: background-color 0.3s;
}

.nav-toggle:hover {
  background-color: rgba(0, 0, 0, 0.05);
}

.nav-toggle span {
  width: 24px;
  height: 2px;
  background: var(--color-text-main);
  transition: all 0.3s cubic-bezier(0.68, -0.55, 0.265, 1.55);
  position: absolute;
}

.nav-toggle span:nth-child(1) {
  transform: translateY(-8px);
}

.nav-toggle span:nth-child(3) {
  transform: translateY(8px);
}

/* Menu Content */
/* Menu Content */
.nav-menu-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 320px;
  /* Slightly wider */
  height: 100vh;
  background: #ffffff;
  /* Solid white for performance */
  /* backdrop-filter removed */
  box-shadow: none;
  /* Shadow removed when closed to prevent bleeding */
  padding-top: 100px;
  transform: translateX(-100%);
  visibility: hidden;
  /* Ensure invisible when closed */
  transition: transform 0.3s cubic-bezier(0.77, 0, 0.175, 1), box-shadow 0.3s ease, visibility 0s 0.3s;
  /* Hide visibility after transform ends */
  z-index: 1001;
}

/* Open State */
.header_nav.is-open .nav-menu-container {
  transform: translateX(0);
  box-shadow: 5px 0 20px rgba(0, 0, 0, 0.1);
  /* Show shadow only when open */
  visibility: visible;
  transition: transform 0.3s cubic-bezier(0.77, 0, 0.175, 1), box-shadow 0.3s ease;
  /* Show immediately */
}

.header_nav.is-open .nav-toggle span:nth-child(1) {
  transform: rotate(45deg);
}

.header_nav.is-open .nav-toggle span:nth-child(2) {
  opacity: 0;
}

.header_nav.is-open .nav-toggle span:nth-child(3) {
  transform: rotate(-45deg);
}

/* Menu List */
.nav-menu-container ul {
  padding: 0;
  margin: 0;
  list-style: none;
  /* Explicitly remove dots */
}

.nav-menu-container li {
  border: none;
  opacity: 0;
  transform: translateX(-20px);
  transition: opacity 0.3s ease, transform 0.3s ease;
  list-style: none;
  /* Explicitly remove dots */
}

.header_nav.is-open .nav-menu-container li {
  opacity: 1;
  transform: translateX(0);
}

/* Stagger animation for items */
.header_nav.is-open .nav-menu-container li:nth-child(1) {
  transition-delay: 0.1s;
}

.header_nav.is-open .nav-menu-container li:nth-child(2) {
  transition-delay: 0.2s;
}

.header_nav.is-open .nav-menu-container li:nth-child(3) {
  transition-delay: 0.3s;
}

.header_nav.is-open .nav-menu-container li:nth-child(4) {
  transition-delay: 0.4s;
}

.header_nav.is-open .nav-menu-container li:nth-child(5) {
  transition-delay: 0.5s;
}

.nav-menu-container a {
  display: block;
  padding: 15px 40px;
  color: var(--color-text-main);
  font-weight: 400;
  font-size: 1.1rem;
  position: relative;
  overflow: hidden;
}

.nav-menu-container a::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  background: var(--color-primary);
  transform: scaleY(0);
  transition: transform 0.3s;
}

.nav-menu-container a:hover {
  background-color: var(--color-bg-body);
  color: var(--color-primary);
}

.nav-menu-container a:hover::before {
  transform: scaleY(1);
}

/* ==========================================================================
   Main Content
   ========================================================================== */
main {
  width: 90%;
  max-width: var(--container-width);
  margin: -40px auto var(--spacing-lg);
  /* Pull up over cover slightly */
  background: var(--color-bg-white);
  box-shadow: var(--shadow-card);
  padding: var(--spacing-lg);
  border-radius: 8px;
  /* Slightly more rounded */
  position: relative;
  z-index: 10;
}

article {
  max-width: 800px;
  margin: 0 auto;
}

.post h1 {
  font-size: 2.2rem;
  margin-bottom: var(--spacing-md);
  text-align: center;
  position: relative;
  padding-bottom: var(--spacing-sm);
}

.post h1::after {
  content: '';
  display: block;
  width: 40px;
  height: 2px;
  background: var(--color-primary);
  margin: var(--spacing-sm) auto 0;
}

.post h2 {
  font-size: 1.75rem;
  padding-left: 0;
  border-left: none;
  margin-top: var(--spacing-lg);
  margin-bottom: var(--spacing-md);
  display: flex;
  align-items: center;
}

.post h2::before {
  content: '';
  display: block;
  width: 6px;
  height: 30px;
  background: var(--color-primary);
  margin-right: 15px;
  border-radius: 3px;
  box-shadow: 0 4px 6px rgba(41, 128, 185, 0.4);
}

.post h3 {
  font-size: 1.4rem;
  margin-top: var(--spacing-lg);
  border-bottom: 2px solid var(--color-border);
  padding-bottom: 10px;
  display: inline-block;
}

/* Button Refinement */
.wp-block-button__link {
  background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-hover) 100%);
  border-radius: 50px;
  /* Pill shape */
  color: #fff;
  padding: 12px 30px;
  box-shadow: 0 4px 15px rgba(41, 128, 185, 0.3);
  font-weight: 500;
  letter-spacing: 0.05em;
  transform: translateY(0);
  transition: all 0.3s ease;
}

.wp-block-button__link:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(41, 128, 185, 0.4);
  opacity: 1;
}

/* Custom Boxes */
.solid_box,
.dashed_box,
.color_box {
  border-radius: 8px;
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-md);
}

.solid_box {
  border: 1px solid var(--color-border);
}

.dashed_box {
  border: 1px dashed var(--color-text-light);
}

.color_box {
  background: #f0f7fb;
  border-left: 4px solid var(--color-primary);
}

/* ==========================================================================
   Footer
   ========================================================================== */
footer {
  background: var(--color-bg-footer);
  padding-top: var(--spacing-xl);
  color: #bdc3c7;
}

.googlemap iframe {
  width: 100%;
  height: 400px;
  /* filter removed for performance */
}

.googlemap:hover iframe {
  filter: grayscale(0%);
}

address {
  font-style: normal;
  text-align: center;
  padding: var(--spacing-lg);
  color: #fff;
}

.copy {
  background: rgba(0, 0, 0, 0.2);
  color: #7f8c8d;
  text-align: center;
  padding: var(--spacing-md);
  font-size: 0.8rem;
  /* Constrain content width */
  width: 100%;
}

.copy .inner {
  max-width: var(--container-width);
  margin: 0 auto;
  padding: 0 20px;
}

.copy a {
  color: #ecf0f1;
}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media (max-width: 768px) {
  :root {
    --spacing-lg: 40px;
    --spacing-xl: 80px;
  }

  .title {
    text-align: right;
    padding-right: 20px;
  }

  /* Logo moves right when menu is on left */

  main {
    width: 100%;
    border-radius: 0;
    box-shadow: none;
    margin-top: 0;
  }
}

/* ==========================================================================
   Widget Styles
   ========================================================================== */
.sidebar .widget {
  background: var(--color-bg-sidebar-widget);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-md);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  width: 100%;
  border-radius: 8px;
  /* Match article width */
  max-width: 800px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.sidebar .widget:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
}

.sidebar .widget h2 {
  font-size: 1.25rem;
  margin-bottom: var(--spacing-sm);
  padding-bottom: var(--spacing-xs);
  border-bottom: 2px solid var(--color-border);
  color: var(--color-primary);
  display: block;
  /* Ensure it behaves like a block */
}

.sidebar .widget h2::before {
  /* Reset existing h2::before styles if they interfere, or adapt them */
  display: none;
}

/* Specific Widget: CTA */
aside .cta {
  background: var(--color-bg-sidebar-widget);
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-md);

  /* Match alignment with other widgets */
  max-width: 800px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

aside .cta h2 {
  color: var(--color-primary);
  /* Match normal widget headers */
  margin-top: 0;
  border-bottom: 2px solid var(--color-border);
  /* Match widget header style */
  padding-bottom: var(--spacing-xs);
  margin-bottom: var(--spacing-sm);
}

/* Footer Widgets Refinement */
footer .googlemap {
  margin-bottom: 0;
  /* Remove gap */
}

footer address {
  background: rgba(0, 0, 0, 0.3);
  margin-top: 0;
}

/* ==========================================================================
   Layout Improvements (50/50 & Formatting)
   ========================================================================== */

/* Grid Layout */
.site-content {
  max-width: var(--container-width);
  margin: 0 auto;
  padding: 0 20px;
  display: block;
  /* One column layout */
  /* Remove grid properties */
  padding: 0 20px;
}

/* Override Main Styles for Grid */
main {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  box-shadow: none;
  background: transparent;
  margin-bottom: var(--spacing-lg);
}

.sidebar {
  width: 100%;
  margin: 0 auto;
  /* Align with main */
}

/* Card look for Article inside Main */
main article {
  background: var(--color-bg-white);
  padding: var(--spacing-md);
  /* Reduced padding for more content space */
  border-radius: 8px;
  box-shadow: var(--shadow-card);
  /* Ensure it fills the main container, similar to widgets */
  width: 100%;
  max-width: 800px;
  /* Align to standard readable width */
  margin: 0 auto;
  /* Center it */
}

/* Ensure images fit */
main article img {
  height: auto;
}

/* Footer Full Width Extensions */
footer .googlemap,
footer address {
  width: 100vw;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw;
  margin-right: -50vw;
  max-width: none;
}

footer .googlemap iframe {
  width: 100%;
  display: block;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .site-content {
    /* Grid is already removed */
    margin-top: 40px;
    /* Add spacing on mobile too */
  }

  main article {
    padding: var(--spacing-md);
  }

  /* Sidebar widgets match main layout */
  .sidebar .widget,
  aside .cta {
    max-width: none;
    width: 100%;
  }
}

/* Header Spacing for Desktop */
.site-content {
  margin-top: var(--spacing-lg);
}

/* Map Responsive fix */
@media (max-width: 768px) {
  .google-map-embed iframe {
    height: 300px !important;
    /* Force smaller height on mobile */
  }
}