:root {
  --navy: #0d2135;
  --deep: #07141f;
  --teal: #1a8c82;
  --teal-light: #21b3a6;
  --sand: #f5efe6;
  --cream: #faf7f2;
  --warm-white: #ffffff;
  --ink: #1a1a2e;
  --mid: #4a5568;
  --light: #8a95a3;
  --border: #e2ddd6;
  --accent: #c9773a;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--ink);overflow-x:hidden;}
.topbar{background:var(--navy);color:rgba(255,255,255,0.7);font-size:0.72rem;letter-spacing:0.08em;text-transform:uppercase;text-align:center;padding:8px 20px;}
.topbar a{color:var(--teal-light);text-decoration:none;}
header{background:var(--warm-white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;box-shadow:0 2px 20px rgba(13,33,53,0.07);}
.header-inner{max-width:1280px;margin:0 auto;padding:0 16px;display:flex;align-items:center;justify-content:space-between;height:64px;}
.logo{display:flex;flex-direction:column;line-height:1;text-decoration:none;}
.logo-top{font-family:'Playfair Display',serif;font-weight:900;font-size:1.2rem;color:var(--navy);}
.logo-sub{font-size:0.6rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--teal);font-weight:500;margin-top:2px;}
.logo-dot{color:var(--accent);}
nav{display:none;}
.btn-subscribe{background:var(--navy);color:#fff;font-size:0.75rem;font-weight:600;padding:8px 14px;border-radius:4px;text-decoration:none;}
.hero{background:var(--navy);position:relative;overflow:hidden;padding:48px 16px;display:flex;align-items:center;}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(26,140,130,0.18) 0%,transparent 60%),linear-gradient(135deg,#07141f 0%,#0d2135 60%,#112840 100%);}
.hero-waves{display:none;}
.hero-content{position:relative;width:100%;}
.hero-label{display:inline-flex;align-items:center;gap:8px;background:rgba(26,140,130,0.2);border:1px solid rgba(26,179,166,0.3);color:var(--teal-light);font-size:0.65rem;letter-spacing:0.14em;text-transform:uppercase;font-weight:600;padding:4px 10px;border-radius:2px;margin-bottom:16px;}
.hero h1{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:900;color:#fff;line-height:1.15;margin-bottom:14px;}
.hero h1 em{font-style:italic;color:var(--teal-light);}
.hero-desc{color:rgba(255,255,255,0.6);font-size:0.9rem;line-height:1.7;margin-bottom:20px;}
.hero-meta{display:flex;flex-wrap:wrap;gap:10px;font-size:0.8rem;color:rgba(255,255,255,0.45);}
.main-content{max-width:1280px;margin:0 auto;padding:32px 16px;}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;}
.section-title{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--navy);}
.section-link{font-size:0.8rem;color:var(--teal);text-decoration:none;}
.posts-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:40px;}
.card-post{background:var(--warm-white);border-radius:8px;overflow:hidden;text-decoration:none;color:inherit;border:1px solid var(--border);display:flex;flex-direction:column;}
.card-post-img{height:160px;background:var(--sand);display:flex;align-items:center;justify-content:center;font-size:2.5rem;}
.card-post-body{padding:16px;}
.card-cat{font-size:0.65rem;font-weight:600;letter-spacing:0.1em;text-transform:uppercase;color:var(--teal);margin-bottom:6px;}
.card-post-body h3{font-family:'Playfair Display',serif;font-size:1rem;color:var(--navy);margin-bottom:6px;line-height:1.4;}
.card-post-body p{font-size:0.82rem;color:var(--mid);line-height:1.6;margin-bottom:10px;}
.card-meta{font-size:0.72rem;color:var(--light);}
.newsletter-band{background:var(--navy);padding:48px 16px;text-align:center;}
.newsletter-content{max-width:560px;margin:0 auto;}
.newsletter-content h2{font-family:'Playfair Display',serif;font-size:1.6rem;color:#fff;margin-bottom:10px;}
.newsletter-content p{color:rgba(255,255,255,0.6);margin-bottom:20px;font-size:0.9rem;}
.newsletter-form{display:flex;flex-direction:column;gap:8px;max-width:420px;margin:0 auto;}
.newsletter-form input{padding:12px 16px;border:1px solid rgba(255,255,255,0.2);background:rgba(255,255,255,0.1);color:#fff;border-radius:4px;font-size:0.9rem;width:100%;}
.newsletter-form button{background:var(--teal);color:#fff;border:none;padding:12px 20px;border-radius:4px;font-weight:600;cursor:pointer;width:100%;}
footer{background:var(--deep);color:rgba(255,255,255,0.6);padding:40px 16px 24px;}
.footer-inner{max-width:1280px;margin:0 auto;}
.footer-top{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:24px;}
.footer-brand p{font-size:0.82rem;line-height:1.7;margin-top:10px;}
.footer-col h5{color:#fff;font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;margin-bottom:12px;}
.footer-col a{display:inline-block;color:rgba(255,255,255,0.5);text-decoration:none;font-size:0.82rem;margin-right:12px;margin-bottom:8px;}
.footer-col a:hover{color:var(--teal-light);}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.1);padding-top:20px;font-size:0.75rem;display:flex;flex-direction:column;gap:8px;}
.kg-width-wide{margin:0;}
.kg-width-full{margin:0 -16px;}
.kg-canvas{max-width:100%;margin:0 auto;}
.post-full{max-width:100%;margin:32px auto;padding:0 16px;}
.post-full h1{font-family:'Playfair Display',serif;font-size:1.8rem;color:var(--navy);margin-bottom:12px;}
.post-content{margin-top:24px;font-size:0.95rem;line-height:1.8;color:var(--ink);}
@media(min-width:768px){
  nav{display:flex;align-items:center;gap:2px;}
  nav a{font-size:0.8rem;font-weight:500;color:var(--mid);text-decoration:none;padding:6px 12px;border-radius:4px;transition:color 0.2s,background 0.2s;}
  nav a:hover{color:var(--navy);background:var(--sand);}
  .header-inner{padding:0 32px;height:72px;}
  .logo-top{font-size:1.55rem;}
  .hero{padding:80px 32px;}
  .hero-waves{display:block;}
  .hero h1{font-size:3rem;}
  .posts-grid{grid-template-columns:repeat(3,1fr);}
  .newsletter-form{flex-direction:row;}
  .newsletter-form input{width:auto;}
  .newsletter-form button{width:auto;}
  .footer-top{grid-template-columns:2fr 1fr 1fr;}
  .footer-bottom{flex-direction:row;justify-content:space-between;}
  .main-content{padding:48px 32px;}
  .kg-width-wide{margin:0 -80px;}
  .kg-width-full{margin:0 -100vw;}
  .post-full{max-width:740px;padding:0 32px;}
}
