
:root{--ink:#1a1a1a;--muted:#566;--soft:#f8f7f5;--accent:#3d6f6a;}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:#fff;line-height:1.5}
a{color:inherit;text-decoration:underline;text-decoration-color:#cbd5d1}
header.site{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.78);backdrop-filter:blur(8px);border-bottom:1px solid rgba(0,0,0,.06)}
.header-inner{max-width:1100px;margin:auto;display:flex;align-items:center;justify-content:space-between;padding:12px 20px}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.3px}
.brand img{width:24px;height:24px;border-radius:6px}
nav a{margin-left:16px;text-decoration:none;color:var(--ink);opacity:.85}
nav a:hover{opacity:1}
.container{max-width:1100px;margin:auto;padding:24px 20px}

.hero{position:relative;min-height:68vh;max-height:820px;overflow:clip;isolation:isolate}
.hero-media,.hero-media>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 42%}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,.45),rgba(255,255,255,.2) 40%,rgba(255,255,255,.55));mix-blend-mode:screen;pointer-events:none}
.hero-overlay{position:sticky;top:clamp(84px,12vh,140px);z-index:2;margin-inline:auto;max-width:980px;padding:clamp(16px,3vw,32px);text-align:center;color:#1a1a1a;backdrop-filter:blur(2px);will-change:opacity,transform;transition:opacity .3s ease,transform .3s ease}
.hero-title{font-size:clamp(22px,3.2vw,38px);line-height:1.2;font-weight:600;letter-spacing:.2px}
.hero-sub{margin-top:.6rem;font-size:clamp(15px,1.3vw,18px);line-height:1.55;opacity:.92}
.hero-tagline{margin-top:.9rem;font-weight:600;letter-spacing:.3px;opacity:.95}
.hero-logo{position:absolute;left:14px;top:14px;z-index:3;opacity:.9;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12))}
.hero-logo img{width:56px;height:56px;border-radius:12px;border:1px solid rgba(0,0,0,.05)}
@media (max-width: 640px){.hero{min-height:52vh} .hero-overlay{top:64px;padding:16px} .hero-logo img{width:48px;height:48px}}

.grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.card{border:1px solid rgba(0,0,0,.08);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 6px 20px rgba(0,0,0,.05)}
.card img{width:100%;height:220px;object-fit:cover}
.card .pad{padding:14px}
.card h3{margin:0;font-size:18px}
.card p{margin:.4rem 0 0;color:var(--muted);font-size:15px}
.btnrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.btn{display:inline-block;padding:10px 14px;border-radius:999px;border:1px solid #dfe7e5;background:#eef4f3;text-decoration:none}
.btn.solid{background:#2f6e67;border-color:#2f6e67;color:#fff;text-decoration:none}

.footer{border-top:1px solid rgba(0,0,0,.06);background:var(--soft)}
.footer .container{display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;align-items:center;padding-top:18px;padding-bottom:18px;color:var(--muted)}

.linen{background:url('assets/linen.png') center/cover fixed; min-height:68vh; display:grid; place-items:center; text-align:center}
.linen .bubble{background:rgba(255,255,255,.66); backdrop-filter: blur(6px); border:1px solid rgba(0,0,0,.06); padding:28px 22px; border-radius:18px; width:min(680px,92vw)}
.gallery{columns: 1; column-gap:18px}
@media(min-width:700px){.gallery{columns: 2}}
@media(min-width:1100px){.gallery{columns: 3}}
.gallery img{width:100%; margin:0 0 18px; border-radius:14px; display:block; break-inside:avoid; box-shadow:0 6px 18px rgba(0,0,0,.06)}
