
    :root{
      /* Theme palette */
      --kauri: #2f5b4b;         /* kauri green */
      --seafoam: #6fb7b2;       /* seafoam blue */
      --charcoal: #171a1b;      /* volcanic charcoal */
      --mist: #eef3f1;          /* cloud mist */
      --paper: #f7faf8;         /* airy whites */
      --berry: #a63d5d;         /* pōhutukawa berry */
      --ink: #14201b;
      --stroke: rgba(20, 32, 27, .16);
      --stroke2: rgba(255,255,255,.12);
      --shadow: 0 18px 48px rgba(15, 25, 21, .10);
      --shadow-soft: 0 10px 26px rgba(15, 25, 21, .12);
      --radius: 18px;
      --radius2: 26px;
      --max: 1200px;

      --serif: ui-serif, "Iowan Old Style", "Palatino Linotype", Palatino, Georgia, serif;
      --sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Inter, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif;
    }

    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      color:var(--ink);
      font-family:var(--sans);
      background:
        radial-gradient(1200px 420px at 14% -10%, rgba(111,183,178,.22), transparent 62%),
        radial-gradient(900px 420px at 88% 6%, rgba(47,91,75,.18), transparent 62%),
        linear-gradient(180deg, var(--paper), var(--mist));
      line-height:1.65;
      letter-spacing:.01em;
    }

    /* Soft paper grain */
    body::before{
      content:"";
      position:fixed;
      inset:0;
      pointer-events:none;
      background:
        repeating-linear-gradient(0deg, rgba(20,32,27,.028) 0 1px, transparent 1px 6px),
        repeating-linear-gradient(90deg, rgba(20,32,27,.018) 0 1px, transparent 1px 7px);
      mix-blend-mode:multiply;
      opacity:.35;
    }

    a{color:#1f7f86; text-decoration-thickness:.08em; text-underline-offset:.22em}
    a:hover{color:#17656b}
    :focus-visible{
      outline:3px solid rgba(111,183,178,.55);
      outline-offset:3px;
      border-radius:10px;
    }

    .container{
      width:min(var(--max), calc(100% - 2rem));
      margin-inline:auto;
    }

    /* ===== Header / Nav ===== */
    header{
      position:sticky;
      top:0;
      z-index:50;
      background:rgba(247,250,248,.78);
      backdrop-filter: blur(10px);
      border-bottom:1px solid rgba(20,32,27,.10);
    }
    .topbar{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:1rem;
      padding:.8rem 0;
    }

    .brand{
      display:flex;
      align-items:center;
      gap:.9rem;
      min-width: 14rem;
    }
    .mark{
      width:44px; height:44px;
      border-radius:14px;
      background:
        radial-gradient(14px 14px at 30% 30%, rgba(255,255,255,.65), transparent 60%),
        linear-gradient(135deg, rgba(111,183,178,.92), rgba(47,91,75,.92));
      box-shadow: 0 14px 34px rgba(25, 44, 37, .14);
      position:relative;
      border:1px solid rgba(255,255,255,.55);
    }
    .mark::after{
      content:"";
      position:absolute;
      inset:10px 9px 11px 10px;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.42);
      transform: rotate(-18deg);
    }
    .brand .name{
      display:flex;
      flex-direction:column;
      line-height:1.05;
    }
    .brand .name strong{
      font-family:var(--serif);
      font-weight:650;
      letter-spacing:.04em;
      text-transform: lowercase;
      font-size:1.05rem;
      color:rgba(20,32,27,.92);
    }
    .brand .name span{
      font-size:.78rem;
      color:rgba(20,32,27,.65);
      letter-spacing:.08em;
    }

    /* IMPORTANT: nav contains only ul/li/a per instruction */
    nav ul{
      list-style:none;
      padding:0; margin:0;
      display:flex;
      align-items:center;
      gap:.2rem;
    }
    nav a{
      display:inline-block;
      padding:.55rem .85rem;
      border-radius:999px;
      color:rgba(20,32,27,.80);
      text-decoration:none;
      border:1px solid transparent;
      transition: transform .35s ease, background .35s ease, border-color .35s ease, box-shadow .35s ease, color .35s ease;
      letter-spacing:.05em;
      font-size:.92rem;
    }
    nav a:hover{
      background:rgba(111,183,178,.14);
      border-color: rgba(20,32,27,.10);
      transform: translateY(-1px);
      box-shadow: 0 10px 22px rgba(15,25,21,.08);
      color:rgba(20,32,27,.92);
    }

    /* Burger: pure CSS */
    .navwrap{
      display:flex;
      align-items:center;
      gap:1rem;
    }

    #nav-toggle{
      position:absolute;
      width:1px;height:1px;
      overflow:hidden;
      clip:rect(0 0 0 0);
      white-space:nowrap;
      border:0;
      padding:0;margin:-1px;
    }

    .burger{
      display:none;
      align-items:center;
      justify-content:center;
      width:46px;height:44px;
      border-radius:14px;
      border:1px solid rgba(20,32,27,.12);
      background:rgba(255,255,255,.55);
      box-shadow: 0 14px 34px rgba(15,25,21,.08);
      cursor:pointer;
      transition: transform .35s ease, box-shadow .35s ease, background .35s ease, border-color .35s ease;
    }
    .burger:hover{
      transform: translateY(-1px);
      box-shadow: 0 18px 44px rgba(15,25,21,.10);
      border-color: rgba(111,183,178,.35);
    }
    .burger-lines{
      width:18px;height:12px;
      position:relative;
    }
    .burger-lines span{
      position:absolute;
      left:0; right:0;
      height:2px;
      background:rgba(20,32,27,.70);
      border-radius:2px;
      transition: transform .35s ease, top .35s ease, opacity .35s ease;
    }
    .burger-lines span:nth-child(1){top:0}
    .burger-lines span:nth-child(2){top:5px}
    .burger-lines span:nth-child(3){top:10px}

    /* Modal trigger button (header) */
    .header-actions{
      display:flex;
      align-items:center;
      gap:.6rem;
    }
    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:.5rem;
      padding:.62rem 1rem;
      border-radius:999px;
      border:1px solid rgba(20,32,27,.16);
      background:rgba(255,255,255,.62);
      color:rgba(20,32,27,.88);
      text-decoration:none;
      font-size:.92rem;
      letter-spacing:.05em;
      transition: transform .35s ease, box-shadow .45s ease, background .35s ease, border-color .35s ease, color .35s ease;
      box-shadow: 0 14px 34px rgba(15,25,21,.08);
      white-space:nowrap;
    }
    .btn:hover{
      transform: translateY(-1px);
      border-color: rgba(111,183,178,.45);
      box-shadow: 0 18px 48px rgba(15,25,21,.12);
      background: rgba(111,183,178,.14);
    }
    .btn.primary{
      background: linear-gradient(135deg, rgba(47,91,75,.95), rgba(111,183,178,.92));
      border-color: rgba(255,255,255,.40);
      color: rgba(255,255,255,.92);
      box-shadow: 0 18px 50px rgba(35, 70, 57, .25);
    }
    .btn.primary:hover{
      background: linear-gradient(135deg, rgba(47,91,75,1), rgba(111,183,178,1));
      box-shadow: 0 22px 60px rgba(35, 70, 57, .28);
    }

    /* Mobile nav behavior */
    @media (max-width: 1199.98px){
      .burger{display:inline-flex}
      .navwrap{
        align-items:stretch;
      }

      nav{
        position:fixed;
        inset: 74px 0 auto 0;
        background: rgba(247,250,248,.92);
        backdrop-filter: blur(10px);
        border-bottom: 1px solid rgba(20,32,27,.10);
        transform: translateY(-120%);
        transition: transform .45s ease;
      }
      nav ul{
        width:min(var(--max), calc(100% - 2rem));
        margin:0 auto;
        padding: .6rem 0 1rem;
        flex-direction:column;
        align-items:stretch;
        gap:.35rem;
      }
      nav a{
        border-radius: 16px;
        padding:.85rem 1rem;
        border:1px solid rgba(20,32,27,.10);
        background: rgba(255,255,255,.60);
      }

      #nav-toggle:checked ~ nav{
        transform: translateY(0);
      }
      #nav-toggle:checked + label .burger-lines span:nth-child(1){top:5px; transform: rotate(45deg)}
      #nav-toggle:checked + label .burger-lines span:nth-child(2){opacity:0}
      #nav-toggle:checked + label .burger-lines span:nth-child(3){top:5px; transform: rotate(-45deg)}
    }

    /* ===== HERO ===== */
    .hero{
      position:relative;
      padding: 1.2rem 0 1.6rem;
    }
    .hero-shell{
      display:grid;
      gap:1.1rem;
      align-items:stretch;
    }
    .hero-card{
      border-radius: var(--radius2);
      border:1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(900px 320px at 16% 12%, rgba(111,183,178,.18), transparent 62%),
        radial-gradient(900px 360px at 92% 22%, rgba(47,91,75,.16), transparent 60%),
        rgba(255,255,255,.66);
      box-shadow: var(--shadow);
      overflow:hidden;
      position:relative;
    }
    .hero-card::after{
      /* gentle tidal curve */
      content:"";
      position:absolute;
      inset:auto -8% -28% -8%;
      height: 220px;
      background: radial-gradient(closest-side, rgba(111,183,178,.22), transparent 70%);
      transform: rotate(-6deg);
      pointer-events:none;
      opacity:.9;
    }
    .hero-inner{
      display:grid;
      gap:1rem;
      padding: 1.25rem;
      position:relative;
      z-index:1;
    }
    .hero h1{
      margin:0;
      font-family: var(--serif);
      font-weight:700;
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: clamp(1.55rem, 2.7vw, 2.5rem);
      line-height:1.15;
      color: rgba(20,32,27,.94);
    }
    .hero p{
      margin:0;
      color: rgba(20,32,27,.74);
      font-size: 1.02rem;
      max-width: 62ch;
    }
    .hero-meta{
      display:flex;
      flex-wrap:wrap;
      gap:.6rem;
      align-items:center;
    }
    .pill{
      display:inline-flex;
      align-items:center;
      gap:.5rem;
      padding:.5rem .75rem;
      border-radius: 999px;
      border:1px solid rgba(20,32,27,.12);
      background: rgba(255,255,255,.60);
      color: rgba(20,32,27,.78);
      font-size:.88rem;
      letter-spacing:.03em;
      box-shadow: 0 10px 22px rgba(15,25,21,.06);
    }
    .dot{
      width:10px;height:10px;border-radius:999px;
      background: rgba(111,183,178,.95);
      box-shadow: 0 0 0 5px rgba(111,183,178,.14);
    }

    /* Slider block: max 600px height */
    .slider{
      border-top: 1px solid rgba(20,32,27,.10);
      margin-top: .6rem;
      padding-top: 1rem;
    }
    .slides{
      position:relative;
      height: min(56vh, 600px);
      min-height: 280px;
      border-radius: 22px;
      overflow:hidden;
      border:1px solid rgba(20,32,27,.10);
      box-shadow: var(--shadow-soft);
      background: rgba(0,0,0,.05);
    }
    .slides figure{
      margin:0;
      position:absolute;
      inset:0;
      opacity:0;
      transform: scale(1.02);
      transition: opacity .9s ease, transform 1.1s ease;
    }
    .slides img{
      width:100%;
      height:100%;
      object-fit: cover;
      filter: saturate(.96) contrast(.98) brightness(1.02);
    }
    .slides figcaption{
      position:absolute;
      left:1rem;
      bottom:1rem;
      right:1rem;
      display:flex;
      flex-wrap:wrap;
      gap:.5rem;
      align-items:center;
      justify-content:space-between;
      padding:.85rem 1rem;
      border-radius: 18px;
      background: rgba(23,26,27,.42);
      border:1px solid rgba(255,255,255,.18);
      color: rgba(255,255,255,.92);
      backdrop-filter: blur(8px);
    }
    .slides figcaption strong{
      font-weight:650;
      letter-spacing:.06em;
      text-transform: lowercase;
    }
    .slides figcaption span{
      color: rgba(255,255,255,.78);
      font-size:.92rem;
      letter-spacing:.04em;
    }

    /* Pure CSS slider via keyframes */
    .slides figure:nth-child(1){animation: zenfade 18s infinite}
    .slides figure:nth-child(2){animation: zenfade 18s infinite 6s}
    .slides figure:nth-child(3){animation: zenfade 18s infinite 12s}
    @keyframes zenfade{
      0%{opacity:0; transform: scale(1.03)}
      6%{opacity:1; transform: scale(1)}
      33%{opacity:1; transform: scale(1)}
      39%{opacity:0; transform: scale(1.03)}
      100%{opacity:0; transform: scale(1.03)}
    }

    .hero-cta{
      display:flex;
      flex-wrap:wrap;
      gap:.65rem;
      align-items:center;
      margin-top:.1rem;
    }
    .link-quiet{
      display:inline-flex;
      align-items:center;
      gap:.55rem;
      padding:.55rem .2rem;
      color: rgba(20,32,27,.72);
      text-decoration:none;
      border-radius: 12px;
      transition: background .35s ease, color .35s ease;
    }
    .link-quiet:hover{
      background: rgba(111,183,178,.12);
      color: rgba(20,32,27,.90);
    }
    .leafline{
      height:1px;
      background: linear-gradient(90deg, transparent, rgba(20,32,27,.14), rgba(111,183,178,.35), rgba(20,32,27,.14), transparent);
      margin: .8rem 0 0;
      border-radius: 999px;
    }

    @media (min-width: 768px){
      .hero-inner{padding: 1.6rem}
      .hero-shell{gap:1.25rem}
    }
    @media (min-width: 1200px){
      .hero{padding: 1.4rem 0 2.1rem}
      .hero-shell{
        grid-template-columns: 1.05fr .95fr;
        gap: 1.4rem;
      }
      .slider{margin-top:0; padding-top:0; border-top:0}
      .hero-card{min-height: 520px}
      .hero-inner{padding: 2rem}
    }

    /* ===== Sections ===== */
    main{
      padding: 1.2rem 0 2.2rem;
    }
    .section{
      padding: 1.1rem 0 1.35rem;
    }
    .section-head{
      display:flex;
      flex-direction:column;
      gap:.35rem;
      margin-bottom: .9rem;
    }
    .section h2{
      margin:0;
      font-family: var(--serif);
      font-weight: 700;
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: clamp(1.2rem, 2.1vw, 1.7rem);
    }
    .section p.lead{
      margin:0;
      color: rgba(20,32,27,.70);
      max-width: 72ch;
    }

    .grid{
      display:grid;
      grid-template-columns: 1fr;
      gap: .9rem;
    }

    article.card{
      border-radius: var(--radius);
      border: 1px solid rgba(20,32,27,.10);
      overflow:hidden;
      background: rgba(255,255,255,.68);
      box-shadow: 0 14px 36px rgba(15,25,21,.08);
      transition: transform .45s ease, box-shadow .45s ease, border-color .45s ease, background .45s ease;
      position:relative;
    }
    article.card:hover{
      transform: translateY(-3px);
      box-shadow: 0 22px 60px rgba(15,25,21,.12);
      border-color: rgba(111,183,178,.35);
    }
    .thumb{
      aspect-ratio: 16 / 10;
      width:100%;
      background: rgba(0,0,0,.06);
      border-bottom: 1px solid rgba(20,32,27,.10);
      position:relative;
      overflow:hidden;
    }
    .thumb img{
      width:100%;
      height:100%;
      object-fit:cover;
      transition: transform .9s ease, filter .6s ease;
      filter: saturate(.95) contrast(.98);
    }
    article.card:hover .thumb img{
      transform: scale(1.05);
      filter: saturate(1) contrast(1);
    }
    .thumb::after{
      content:"";
      position:absolute;
      inset:auto 0 0 0;
      height:42%;
      background: linear-gradient(180deg, transparent, rgba(23,26,27,.22));
      pointer-events:none;
    }
    .card-body{
      padding: .95rem 1rem 1.05rem;
      display:flex;
      flex-direction:column;
      gap:.55rem;
    }
    .kicker{
      display:flex;
      align-items:center;
      gap:.5rem;
      color: rgba(20,32,27,.68);
      font-size:.86rem;
      letter-spacing:.06em;
      text-transform: uppercase;
    }
    .kicker i{
      width:10px;height:10px;border-radius:999px;
      background: rgba(111,183,178,.95);
      box-shadow: 0 0 0 5px rgba(111,183,178,.14);
      display:inline-block;
    }
    .card-body h3{
      margin:0;
      font-size: 1.06rem;
      line-height:1.25;
      letter-spacing:.03em;
      font-weight: 700;
    }
    .card-body p{
      margin:0;
      color: rgba(20,32,27,.70);
    }
    .card-actions{
      margin-top:.3rem;
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:.8rem;
      border-top: 1px solid rgba(20,32,27,.08);
      padding-top:.65rem;
    }
    .tag{
      display:inline-flex;
      align-items:center;
      gap:.45rem;
      padding:.34rem .6rem;
      border-radius:999px;
      border:1px solid rgba(20,32,27,.12);
      background: rgba(255,255,255,.62);
      font-size:.82rem;
      color: rgba(20,32,27,.72);
      letter-spacing:.03em;
    }
    .read{
      text-decoration:none;
      display:inline-flex;
      align-items:center;
      gap:.45rem;
      padding:.35rem .6rem;
      border-radius:999px;
      border:1px solid rgba(20,32,27,.14);
      color: rgba(20,32,27,.78);
      background: rgba(255,255,255,.50);
      transition: background .35s ease, border-color .35s ease, transform .35s ease, box-shadow .45s ease;
    }
    .read:hover{
      background: rgba(111,183,178,.14);
      border-color: rgba(111,183,178,.40);
      transform: translateY(-1px);
      box-shadow: 0 14px 30px rgba(15,25,21,.10);
    }

    /* Section individuality */
    .section.s1 .section-head{
      padding: 1rem 1rem;
      border-radius: var(--radius);
      border:1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(700px 220px at 10% 0%, rgba(111,183,178,.18), transparent 60%),
        rgba(255,255,255,.62);
      box-shadow: 0 12px 30px rgba(15,25,21,.07);
    }

    .section.s2{
      background:
        radial-gradient(900px 260px at 90% 10%, rgba(166,61,93,.10), transparent 60%),
        linear-gradient(180deg, rgba(111,183,178,.10), transparent 40%);
      border-top: 1px solid rgba(20,32,27,.08);
      border-bottom: 1px solid rgba(20,32,27,.08);
    }
    .section.s2 article.card{
      background: rgba(255,255,255,.60);
    }
    .section.s2 article.card:hover{
      border-color: rgba(166,61,93,.26);
    }
    .section.s2 .kicker i{
      background: rgba(166,61,93,.88);
      box-shadow: 0 0 0 5px rgba(166,61,93,.12);
    }

    .section.s3 .grid{
      gap: .75rem; /* denser */
    }
    .section.s3 article.card{
      border-radius: 16px;
      background:
        radial-gradient(700px 240px at 15% 0%, rgba(47,91,75,.16), transparent 62%),
        rgba(255,255,255,.62);
    }
    .section.s3 article.card:hover{
      transform: translateY(-2px);
      border-color: rgba(47,91,75,.28);
      box-shadow: 0 20px 56px rgba(15,25,21,.11);
    }

    @media (min-width: 768px){
      .grid{grid-template-columns: repeat(2, 1fr); gap: 1rem}
      .section{padding: 1.35rem 0 1.7rem}
      .card-body{padding: 1.05rem 1.1rem 1.15rem}
    }
    @media (min-width: 1200px){
      .grid{grid-template-columns: repeat(3, 1fr); gap: 1.1rem}
    }

    /* ===== Blog list block ===== */
    .blogblock{
      padding: 1.4rem 0 2rem;
    }
    .blogwrap{
      border-radius: var(--radius2);
      border:1px solid rgba(20,32,27,.10);
      background: rgba(255,255,255,.66);
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .bloghead{
      padding: 1.15rem 1.15rem;
      display:flex;
      flex-direction:column;
      gap:.35rem;
      border-bottom:1px solid rgba(20,32,27,.08);
      background:
        radial-gradient(900px 260px at 15% 0%, rgba(111,183,178,.18), transparent 60%),
        rgba(255,255,255,.55);
    }
    .bloghead h2{
      margin:0;
      font-family:var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: clamp(1.15rem, 2vw, 1.6rem);
    }
    .bloghead p{margin:0; color: rgba(20,32,27,.70)}
    .bloglist{
      list-style:none;
      padding:0;
      margin:0;
      display:grid;
      grid-template-columns: 1fr;
    }
    .bloglist li{
      border-top: 1px solid rgba(20,32,27,.08);
    }
    .bloglist li:first-child{border-top:0}
    .bloglist a{
      display:grid;
      grid-template-columns: 110px 1fr;
      gap:.95rem;
      align-items:center;
      padding: .95rem 1.1rem;
      text-decoration:none;
      color: inherit;
      transition: background .35s ease, transform .35s ease;
    }
    .bloglist a:hover{
      background: rgba(111,183,178,.10);
      transform: translateY(-1px);
    }
    .blogthumb{
      width:110px;
      aspect-ratio: 1 / 1;
      border-radius: 18px;
      overflow:hidden;
      border:1px solid rgba(20,32,27,.10);
      background: rgba(0,0,0,.05);
      box-shadow: 0 12px 30px rgba(15,25,21,.08);
    }
    .blogthumb img{width:100%;height:100%;object-fit:cover;filter:saturate(.95)}
    .blogmeta{
      display:flex;
      flex-direction:column;
      gap:.3rem;
      min-width:0;
    }
    .blogmeta strong{
      font-size: 1rem;
      line-height:1.25;
      letter-spacing:.02em;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }
    .blogmeta span{
      font-size:.92rem;
      color: rgba(20,32,27,.70);
      max-width: 70ch;
    }
    @media (min-width: 768px){
      .bloglist{grid-template-columns: 1fr 1fr}
      .bloglist li{border-top:0; border-left: 1px solid rgba(20,32,27,.08)}
      .bloglist li:nth-child(odd){border-left:0}
      .bloglist a{grid-template-columns: 120px 1fr}
      .blogthumb{width:120px}
    }

    /* ===== Content (center) ===== */
    .content{
      padding: 1.1rem 0 1.8rem;
    }
    .content-shell{
      width:min(920px, calc(100% - 2rem));
      margin-inline:auto;
      background: rgba(255,255,255,.70);
      border:1px solid rgba(20,32,27,.10);
      border-radius: var(--radius2);
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .content-top{
      padding: 1.2rem 1.15rem 0;
    }
    .content-media{
      margin: 0 auto;
      width: 100%;
      max-width: 860px;
      border-radius: 22px;
      overflow:hidden;
      border:1px solid rgba(20,32,27,.10);
      box-shadow: 0 18px 48px rgba(15,25,21,.10);
      background: rgba(0,0,0,.05);
    }
    .content-media img{
      width:100%;
      height:auto;
      display:block;
    }
    .rating{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:1rem;
      margin: .9rem auto 0;
      width: 100%;
      max-width: 860px;
      padding: .75rem .9rem;
      border-radius: 16px;
      border:1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(700px 180px at 10% 0%, rgba(111,183,178,.18), transparent 60%),
        rgba(255,255,255,.62);
      color: rgba(20,32,27,.82);
    }
    .rating strong{
      letter-spacing:.06em;
      text-transform: uppercase;
      font-size:.85rem;
      display:inline-flex;
      align-items:center;
      gap:.55rem;
    }
    .stars{
      display:flex;
      gap:.25rem;
      align-items:center;
      color: rgba(47,91,75,.92);
      font-size:1rem;
      letter-spacing:.08em;
      user-select:none;
    }
    .divider{
      height:1px;
      background: linear-gradient(90deg, transparent, rgba(20,32,27,.14), rgba(111,183,178,.32), rgba(20,32,27,.14), transparent);
      margin: 1.1rem 0;
    }

    .articlewrap{
      padding: 0 1.15rem 1.2rem;
    }
    .content article[itemscope]{
      padding: 0;
    }
    .content article h1{
      margin:0;
      font-family: var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: clamp(1.4rem, 2.4vw, 2.05rem);
      line-height:1.18;
    }
    .byline{
      margin:.55rem 0 0;
      color: rgba(20,32,27,.68);
      display:flex;
      flex-wrap:wrap;
      gap:.55rem;
      align-items:center;
      font-size:.95rem;
    }
    .byline .sep{
      width:4px;height:4px;border-radius:999px;background: rgba(20,32,27,.30);
      display:inline-block;
    }

    .bodytext{
      margin-top: 1rem;
      color: rgba(20,32,27,.78);
      font-size: 1.02rem;
    }
    .callout{
      margin: 1rem 0;
      padding: .95rem 1rem;
      border-radius: 18px;
      border: 1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(1000px 260px at 10% 0%, rgba(47,91,75,.18), transparent 62%),
        linear-gradient(135deg, rgba(47,91,75,.12), rgba(111,183,178,.10)),
        rgba(255,255,255,.54);
      position:relative;
      overflow:hidden;
    }
    .callout::after{
      /* subtle fern watermark */
      content:"";
      position:absolute;
      inset:-20% -10% -20% -10%;
      background:
        radial-gradient(closest-side, rgba(255,255,255,.22), transparent 68%),
        repeating-linear-gradient(125deg, rgba(20,32,27,.04) 0 2px, transparent 2px 10px);
      transform: rotate(-8deg);
      opacity:.35;
      pointer-events:none;
    }
    .callout p{margin:0; position:relative; z-index:1}
    .callout p strong{font-family:var(--serif); letter-spacing:.05em; text-transform: lowercase}

    .prevnext{
      display:flex;
      flex-wrap:wrap;
      gap:.7rem;
      align-items:center;
      justify-content:space-between;
      padding: 1rem 1.15rem 1.25rem;
      border-top: 1px solid rgba(20,32,27,.08);
      background: rgba(255,255,255,.52);
    }
    .prevnext a{
      text-decoration:none;
      display:inline-flex;
      align-items:center;
      gap:.55rem;
      padding:.65rem .9rem;
      border-radius: 999px;
      border:1px solid rgba(20,32,27,.14);
      background: rgba(255,255,255,.62);
      color: rgba(20,32,27,.82);
      transition: transform .35s ease, box-shadow .45s ease, background .35s ease, border-color .35s ease;
    }
    .prevnext a:hover{
      transform: translateY(-1px);
      border-color: rgba(111,183,178,.45);
      background: rgba(111,183,178,.14);
      box-shadow: 0 18px 48px rgba(15,25,21,.10);
    }

    .comments{
      padding: 1.2rem 1.15rem 1.35rem;
      border-top: 1px solid rgba(20,32,27,.08);
    }
    .comments h2{
      margin:0 0 .65rem;
      font-family:var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: 1.35rem;
    }
    .comments .empty{
      border-radius: 18px;
      border:1px dashed rgba(20,32,27,.22);
      background: rgba(255,255,255,.52);
      padding: .95rem 1rem;
      color: rgba(20,32,27,.65);
    }

    form{
      margin-top: .9rem;
      display:grid;
      gap:.75rem;
    }
    label{
      display:grid;
      gap:.35rem;
      font-size:.92rem;
      color: rgba(20,32,27,.74);
      letter-spacing:.02em;
    }
    input, textarea{
      width:100%;
      padding:.75rem .85rem;
      border-radius: 16px;
      border:1px solid rgba(20,32,27,.14);
      background: rgba(255,255,255,.66);
      color: rgba(20,32,27,.90);
      transition: border-color .35s ease, box-shadow .45s ease, background .35s ease;
      font: inherit;
    }
    textarea{min-height: 120px; resize: vertical}
    input:focus-visible, textarea:focus-visible{
      border-color: rgba(111,183,178,.55);
      box-shadow: 0 0 0 6px rgba(111,183,178,.18);
      outline: none;
      background: rgba(255,255,255,.78);
    }
    .form-actions{
      display:flex;
      flex-wrap:wrap;
      gap:.65rem;
      align-items:center;
      justify-content:flex-start;
    }

    /* ===== Related ===== */
    .related{
      padding: 1.2rem 1.15rem 1.4rem;
      border-top: 1px solid rgba(20,32,27,.08);
      background:
        radial-gradient(900px 240px at 92% 0%, rgba(166,61,93,.08), transparent 60%),
        rgba(255,255,255,.50);
    }
    .related h2{
      margin:0 0 .75rem;
      font-family:var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: 1.35rem;
    }
    .related-grid{
      display:grid;
      grid-template-columns: 1fr;
      gap:.9rem;
    }
    .rel{
      display:grid;
      grid-template-columns: 120px 1fr;
      gap:.85rem;
      align-items:center;
      border-radius: 18px;
      border:1px solid rgba(20,32,27,.10);
      background: rgba(255,255,255,.62);
      box-shadow: 0 14px 34px rgba(15,25,21,.08);
      overflow:hidden;
      transition: transform .35s ease, box-shadow .45s ease, border-color .35s ease;
    }
    .rel:hover{
      transform: translateY(-2px);
      box-shadow: 0 20px 56px rgba(15,25,21,.12);
      border-color: rgba(166,61,93,.22);
    }
    .rel img{
      width:120px;
      height:120px;
      object-fit:cover;
      border-right:1px solid rgba(20,32,27,.10);
      filter:saturate(.95);
    }
    .rel div{
      padding: .75rem .85rem .85rem 0;
      min-width:0;
    }
    .rel strong{
      display:block;
      letter-spacing:.02em;
      line-height:1.25;
      margin-bottom:.25rem;
      white-space:nowrap;
      overflow:hidden;
      text-overflow:ellipsis;
    }
    .rel span{color: rgba(20,32,27,.70); font-size:.92rem}

    @media (min-width: 768px){
      .related-grid{grid-template-columns: 1fr 1fr}
    }

    /* ===== Contacts ===== */
    .contacts{
      padding: 1.6rem 0 2.4rem;
    }
    .contact-card{
      border-radius: var(--radius2);
      border:1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(900px 260px at 10% 0%, rgba(47,91,75,.16), transparent 60%),
        rgba(255,255,255,.66);
      box-shadow: var(--shadow);
      overflow:hidden;
    }
    .contact-grid{
      display:grid;
      grid-template-columns: 1fr;
    }
    .contact-grid > div{
      padding: 1.15rem 1.15rem 1.25rem;
    }
    .contact-grid > div + div{
      border-top: 1px solid rgba(20,32,27,.08);
    }
    .contact-card h2{
      margin:0 0 .55rem;
      font-family:var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: 1.55rem;
    }
    .contact-card p{margin:.25rem 0 0; color: rgba(20,32,27,.72)}
    .map{
      border-radius: 18px;
      overflow:hidden;
      border:1px solid rgba(20,32,27,.12);
      background: rgba(0,0,0,.05);
      box-shadow: 0 14px 36px rgba(15,25,21,.10);
      aspect-ratio: 16 / 10;
    }
    .map iframe{width:100%;height:100%;border:0}
    .address{
      display:grid;
      gap:.25rem;
      margin-top: .65rem;
      color: rgba(20,32,27,.78);
    }
    .address strong{
      font-size:.95rem;
      letter-spacing:.06em;
      text-transform: uppercase;
      color: rgba(20,32,27,.70);
    }
    @media (min-width: 1200px){
      .contact-grid{
        grid-template-columns: 1.05fr .95fr;
      }
      .contact-grid > div + div{
        border-top: 0;
        border-left: 1px solid rgba(20,32,27,.08);
      }
    }

    /* ===== Aside promos + modal form ===== */
    aside{
      padding: 1.2rem 0 2.4rem;
    }
    .aside-shell{
      display:grid;
      gap: 1rem;
    }
    .promos{
      display:grid;
      grid-template-columns: 1fr;
      gap:.85rem;
    }
    .promo{
      border-radius: var(--radius);
      border:1px solid rgba(20,32,27,.10);
      background:
        radial-gradient(800px 220px at 10% 0%, rgba(111,183,178,.16), transparent 62%),
        rgba(255,255,255,.62);
      box-shadow: 0 14px 36px rgba(15,25,21,.08);
      padding: 1rem 1rem;
      transition: transform .35s ease, box-shadow .45s ease, border-color .35s ease;
    }
    .promo:hover{
      transform: translateY(-2px);
      box-shadow: 0 20px 56px rgba(15,25,21,.12);
      border-color: rgba(111,183,178,.35);
    }
    .promo h3{
      margin:0 0 .25rem;
      font-size:1.02rem;
      letter-spacing:.03em;
    }
    .promo p{margin:0; color: rgba(20,32,27,.70)}
    .promo a{display:inline-flex; margin-top:.65rem}

    @media (min-width: 768px){
      .promos{grid-template-columns: 1fr 1fr}
    }
    @media (min-width: 1200px){
      .aside-shell{
        grid-template-columns: 1.3fr .7fr;
        align-items:start;
      }
      .promos{grid-template-columns: 1fr}
    }

    /* Pure CSS centered modal via :target */
    .modal{
      position:fixed;
      inset:0;
      display:none;
      place-items:center;
      z-index:80;
      padding: 1.2rem;
    }
    .modal:target{
      display:grid;
    }
    .modal .backdrop{
      position:absolute;
      inset:0;
      background: rgba(23,26,27,.55);
      backdrop-filter: blur(8px);
    }
    .modal .panel{
      position:relative;
      width:min(560px, 100%);
      border-radius: 24px;
      border:1px solid rgba(255,255,255,.18);
      background:
        radial-gradient(900px 240px at 20% 0%, rgba(111,183,178,.18), transparent 62%),
        rgba(255,255,255,.92);
      box-shadow: 0 28px 90px rgba(0,0,0,.28);
      overflow:hidden;
    }
    .modal .panel header{
      position:relative;
      background: transparent;
      backdrop-filter:none;
      border:0;
      padding: 1.05rem 1.1rem .6rem;
    }
    .modal .panel header h2{
      margin:0;
      font-family: var(--serif);
      letter-spacing:.06em;
      text-transform: lowercase;
      font-size: 1.45rem;
      color: rgba(20,32,27,.92);
    }
    .modal .panel header p{
      margin:.25rem 0 0;
      color: rgba(20,32,27,.70);
    }
    .modal .panel .body{
      padding: .6rem 1.1rem 1.1rem;
    }
    .modal .close{
      position:absolute;
      top:.9rem; right:.9rem;
      text-decoration:none;
      width:42px;height:42px;
      display:grid;
      place-items:center;
      border-radius: 14px;
      border:1px solid rgba(20,32,27,.14);
      background: rgba(255,255,255,.70);
      color: rgba(20,32,27,.80);
      transition: transform .35s ease, background .35s ease, border-color .35s ease;
    }
    .modal .close:hover{
      transform: translateY(-1px);
      background: rgba(111,183,178,.14);
      border-color: rgba(111,183,178,.45);
    }

    /* ===== Footer ===== */
    footer{
      background: linear-gradient(180deg, rgba(23,26,27,1), rgba(15,16,16,1));
      color: rgba(255,255,255,.82);
      border-top: 1px solid rgba(255,255,255,.10);
      position:relative;
      overflow:hidden;
    }
    footer::before{
      /* Rangitoto silhouette motif */
      content:"";
      position:absolute;
      left:-5%;
      right:-5%;
      bottom:-1px;
      height: 180px;
      background:
        radial-gradient(140px 120px at 18% 100%, rgba(47,91,75,.55), transparent 70%),
        radial-gradient(220px 160px at 40% 100%, rgba(47,91,75,.45), transparent 72%),
        radial-gradient(320px 220px at 62% 100%, rgba(47,91,75,.38), transparent 74%),
        radial-gradient(220px 160px at 82% 100%, rgba(47,91,75,.40), transparent 74%);
      filter: blur(0px);
      opacity:.65;
      pointer-events:none;
    }
    footer::after{
      /* lantern glow */
      content:"";
      position:absolute;
      inset:-40% -10% auto -10%;
      height: 260px;
      background: radial-gradient(closest-side, rgba(111,183,178,.18), transparent 68%);
      opacity:.55;
      pointer-events:none;
    }
    .foot{
      position:relative;
      z-index:1;
      padding: 2rem 0 1.4rem;
    }
    .footgrid{
      display:grid;
      grid-template-columns: 1fr;
      gap: 1rem;
      align-items:start;
    }
    .slogan{
      margin:0;
      font-family: var(--serif);
      letter-spacing:.08em;
      text-transform: lowercase;
      font-size: 1.45rem;
      color: rgba(255,255,255,.92);
    }
    .about{
      margin:.55rem 0 0;
      color: rgba(255,255,255,.72);
      max-width: 70ch;
    }
    .social{
      display:flex;
      flex-wrap:wrap;
      gap:.6rem;
      align-items:center;
      margin-top:.8rem;
    }
    .social a{
      color: rgba(255,255,255,.82);
      text-decoration:none;
      padding:.6rem .85rem;
      border-radius:999px;
      border:1px solid rgba(255,255,255,.14);
      background: rgba(255,255,255,.06);
      transition: transform .35s ease, border-color .35s ease, background .35s ease, box-shadow .45s ease, color .35s ease;
    }
    .social a:hover{
      transform: translateY(-1px);
      border-color: rgba(111,183,178,.45);
      background: rgba(111,183,178,.14);
      box-shadow: 0 18px 48px rgba(0,0,0,.24);
      color: rgba(255,255,255,.92);
    }
    .copy{
      margin: 1.2rem 0 0;
      padding-top: 1rem;
      border-top: 1px solid rgba(255,255,255,.10);
      color: rgba(255,255,255,.62);
      font-size:.92rem;
      letter-spacing:.03em;
    }
    @media (min-width: 1200px){
      .footgrid{
        grid-template-columns: 1.1fr .9fr;
        gap: 2rem;
      }
    }

    /* Reduce motion */
    @media (prefers-reduced-motion: reduce){
      *{transition:none !important; animation:none !important; scroll-behavior:auto !important}
    }
  