*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:"Noto Sans JP",-apple-system,BlinkMacSystemFont,"Hiragino Kaku Gothic ProN","Hiragino Sans",Meiryo,sans-serif;line-height:1.8;color:#3d3d3d;background:#faf8f6}
img{max-width:100%;height:auto}
a{color:#b06d7a;text-decoration:none;transition:color 0.2s}
a:hover{color:#8e4f5c}
.container{max-width:960px;margin:0 auto;padding:0 1.25rem}

/* Header */
.site-header{background:#fff;border-bottom:1px solid #f0e8e4;padding:0;position:sticky;top:0;z-index:100}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:60px}
.logo{font-family:"Playfair Display",serif;font-size:1.3rem;font-weight:700;color:#3d3d3d;letter-spacing:0.02em}
.logo span{color:#c08a95}
.logo:hover{text-decoration:none;color:#3d3d3d}
.site-nav ul{display:flex;gap:1.5rem;list-style:none}
.site-nav a{color:#666;font-size:0.9rem;font-weight:500;letter-spacing:0.04em}
.site-nav a:hover{color:#b06d7a}
.menu-toggle{display:none;background:none;border:none;font-size:1.4rem;cursor:pointer;color:#666;padding:0.25rem}

/* Footer */
.site-footer{background:#fff;border-top:1px solid #f0e8e4;padding:2.5rem 0 1.5rem;margin-top:4rem;font-size:0.85rem;color:#888}
.footer-content{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem}
.footer-brand strong{font-family:"Playfair Display",serif;font-size:1.1rem;color:#3d3d3d}
.footer-brand p{margin-top:0.25rem;color:#999}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{color:#888}
.footer-links a:hover{color:#b06d7a}
.footer-bottom{text-align:center;padding-top:1rem;border-top:1px solid #f0f0f0;color:#aaa;font-size:0.8rem}
.footer-bottom a{color:#888}

/* Hero */
.hero{text-align:center;padding:4rem 1.25rem 3rem;background:linear-gradient(135deg,#fdf6f3 0%,#f8ede8 50%,#fdf6f3 100%);position:relative}
.hero::after{content:"";position:absolute;bottom:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#c08a95,#e8b4c0,#c08a95)}
.hero-title{font-size:1.6rem;font-weight:700;color:#3d3d3d;margin-bottom:0.75rem;letter-spacing:0.03em}
.hero-sub{font-size:0.95rem;color:#888;max-width:520px;margin:0 auto;line-height:1.7}

/* Section Title */
.section-title{font-size:1.15rem;font-weight:700;color:#3d3d3d;margin-bottom:1.25rem;padding-bottom:0.4rem;border-bottom:2px solid #f0e0d8;letter-spacing:0.03em;position:relative}
.section-title::after{content:"";position:absolute;bottom:-2px;left:0;width:50px;height:2px;background:#c08a95}

/* Categories */
.featured-categories{padding:2.5rem 0 1.5rem}
.category-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:0.75rem}
.category-card{display:block;padding:1.25rem 1rem;border-radius:10px;text-align:center;background:var(--accent,#f0e0d8);transition:transform 0.2s,box-shadow 0.2s;position:relative;overflow:hidden}
.category-card::before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,0.3);opacity:0;transition:opacity 0.2s}
.category-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.08)}
.category-card:hover::before{opacity:1}
.category-card:hover{text-decoration:none}
.category-card h3{font-size:0.95rem;font-weight:700;color:#3d3d3d;margin-bottom:0.3rem;position:relative}
.category-card .count{font-size:0.75rem;color:#888;position:relative}

/* Post Grid */
.latest-posts{padding:1.5rem 0 2.5rem}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.25rem}
.post-card{border:1px solid #eee;border-radius:12px;overflow:hidden;background:#fff;transition:transform 0.2s,box-shadow 0.2s}
.post-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,0.06)}
.post-card-body{padding:1.5rem}
.post-meta{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.5rem;flex-wrap:wrap}
.post-category{display:inline-block;padding:0.15rem 0.6rem;border-radius:20px;font-size:0.75rem;background:#f8ede8;color:#b06d7a;font-weight:500}
.post-rating{font-size:0.8rem;color:#d4a020;letter-spacing:0.1em}
.post-card h2,.post-card h3{font-size:1rem;font-weight:700;margin-bottom:0.5rem;line-height:1.5}
.post-card h2 a,.post-card h3 a{color:#3d3d3d}
.post-card h2 a:hover,.post-card h3 a:hover{color:#b06d7a}
.post-card p{font-size:0.85rem;color:#888;margin-bottom:0.75rem;line-height:1.6}
.read-more{font-size:0.85rem;font-weight:500;color:#b06d7a}
.read-more:hover{color:#8e4f5c}

/* Page Header */
.page-header{padding:2.5rem 0 1.5rem}
.page-header h1{font-size:1.5rem;font-weight:700;color:#3d3d3d}
.page-desc{font-size:0.9rem;color:#888;margin-top:0.5rem}

/* Post List */
.post-list{padding:0 0 2.5rem}

/* Review Detail */
.review-detail{padding:2.5rem 0 3rem}
.review-header{margin-bottom:2rem}
.review-meta-top{display:flex;align-items:center;gap:0.75rem;margin-bottom:0.75rem;font-size:0.8rem;color:#999}
.review-header h1{font-size:1.5rem;font-weight:700;color:#3d3d3d;line-height:1.5;margin-bottom:0.75rem}
.review-rating{display:flex;align-items:center;gap:0.5rem;margin-bottom:0.75rem}
.review-rating .stars{font-size:1.1rem;color:#d4a020;letter-spacing:0.15em}
.review-rating .rating-text{font-size:0.85rem;color:#888;font-weight:500}
.review-desc{font-size:0.95rem;color:#666;line-height:1.7}

/* Content Styling */
.review-content{font-size:0.95rem;line-height:1.9;color:#3d3d3d;max-width:720px}
.review-content h2{font-size:1.2rem;font-weight:700;margin:2rem 0 0.75rem;padding-bottom:0.35rem;border-bottom:2px solid #f0e0d8;color:#3d3d3d}
.review-content h3{font-size:1.05rem;font-weight:700;margin:1.5rem 0 0.5rem;color:#3d3d3d}
.review-content p{margin-bottom:1rem}
.review-content ul,.review-content ol{padding-left:1.25rem;margin-bottom:1rem}
.review-content li{margin-bottom:0.4rem}
.review-content strong{color:#3d3d3d}
.review-content blockquote{border-left:3px solid #c08a95;padding:0.75rem 1rem;margin:1rem 0;background:#fdf6f3;border-radius:0 6px 6px 0;color:#666;font-size:0.9rem}

/* CTA */
.review-cta{text-align:center;margin:2.5rem 0;padding:2rem;background:linear-gradient(135deg,#fdf6f3,#f8ede8);border-radius:12px}
.cta-label{font-size:0.9rem;color:#666;margin-bottom:1rem}
.btn-cta{display:inline-block;padding:0.85rem 2.5rem;border-radius:50px;font-size:0.95rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#c08a95,#b06d7a);transition:transform 0.2s,box-shadow 0.2s}
.btn-cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(176,109,122,0.3);color:#fff;text-decoration:none}
.cta-note{font-size:0.75rem;color:#aaa;margin-top:0.75rem}

/* Info Card */
.review-info{border:1px solid #eee;border-radius:12px;padding:1.5rem;margin-top:2.5rem;background:#fff}
.review-info h3{font-size:1rem;font-weight:700;margin-bottom:1rem;color:#3d3d3d}
.review-info dl div{display:flex;padding:0.5rem 0;border-bottom:1px solid #f5f0ee}
.review-info dl div:last-child{border-bottom:none}
.review-info dt{width:30%;font-size:0.85rem;color:#888;font-weight:500}
.review-info dd{width:70%;font-size:0.85rem;color:#3d3d3d}

/* Features */
.features{padding:2rem 0 3rem}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.feature-item{text-align:center;padding:1.5rem}
.feature-icon{font-size:1.5rem;margin-bottom:0.5rem}
.feature-item h3{font-size:0.9rem;font-weight:700;margin-bottom:0.3rem}
.feature-item p{font-size:0.8rem;color:#888}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:0.5rem;list-style:none;margin-top:2rem}
.pagination a,.pagination span{display:inline-block;padding:0.4rem 0.8rem;border-radius:6px;font-size:0.85rem;color:#666;background:#fff;border:1px solid #eee}
.pagination a:hover{background:#f8ede8;border-color:#c08a95;color:#b06d7a}
.pagination .active span{background:#c08a95;color:#fff;border-color:#c08a95}

/* Responsive */
@media(max-width:768px){
  html{font-size:14px}
  .hero{padding:2.5rem 1rem}
  .hero-title{font-size:1.3rem}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .post-grid{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr;gap:0.5rem}
  .feature-item{padding:1rem}
  .site-nav{display:none;position:absolute;top:60px;left:0;right:0;background:#fff;border-bottom:1px solid #eee;padding:0.5rem 1.25rem}
  .site-nav.open{display:block}
  .site-nav ul{flex-direction:column;gap:0}
  .site-nav li{border-bottom:1px solid #f5f0ee}
  .site-nav a{display:block;padding:0.75rem 0}
  .menu-toggle{display:block}
  .review-info dt{width:40%}
  .review-info dd{width:60%}
}
