/*
Theme Name: SteadyReef
Description: Tidepool — light aqua modernism: sun-through-water, glass cards, turquoise + living coral. Custom theme for SteadyReef, based on approved prototype p1.
Version: 1.0
Author: the SteadyReef editorial team
Text Domain: steadyreef
*/

:root{
  --paper:#f6fbfb;
  --foam:#eaf5f5;
  --card:#ffffff;
  --line:#d7e8e8;
  --deep:#0c2f3f;
  --text:#2c4654;
  --soft:#5d7684;
  --tide:#0aa6a6;
  --tide-deep:#067d7f;
  --tide-tint:#d6f1f0;
  --coral:#ff6b5e;
  --coral-soft:#ffe3df;
  --sun:#ffc14d;
  --display:'Bricolage Grotesque', sans-serif;
  --body:'Albert Sans', sans-serif;
  --maxw:1200px;
  --r:18px;
  --sh:0 2px 6px rgba(12,47,63,.05),0 22px 48px -24px rgba(12,47,63,.22);
}
*{box-sizing:border-box}
html,body{overflow-x:clip}
body{margin:0;background:var(--paper);color:var(--text);font-family:var(--body);font-size:16.5px;line-height:1.66;
  background-image:radial-gradient(900px 480px at 85% -8%,rgba(10,166,166,.10),transparent 60%),radial-gradient(640px 380px at -8% 22%,rgba(255,107,94,.07),transparent 55%)}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{font-size:.72rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--tide-deep)}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* ===== header ===== */
.topbar{position:sticky;top:0;z-index:60;background:rgba(246,251,251,.9);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.tb-in{display:flex;align-items:center;gap:24px;padding:15px 0}
.brandmark{display:flex;align-items:center;gap:11px;font-family:var(--display);font-weight:800;font-size:1.45rem;color:var(--deep);letter-spacing:-.02em;white-space:nowrap}
.brandmark .blob{width:32px;height:32px;border-radius:46% 54% 55% 45%/52% 44% 56% 48%;background:linear-gradient(140deg,var(--tide),var(--tide-deep));position:relative;animation:blob 7s ease-in-out infinite;flex:none}
.brandmark .blob::after{content:"";position:absolute;inset:8px 9px 11px 7px;border-radius:inherit;background:rgba(255,255,255,.35)}
@keyframes blob{0%,100%{border-radius:46% 54% 55% 45%/52% 44% 56% 48%}50%{border-radius:55% 45% 44% 56%/46% 56% 44% 54%}}
.tnav{margin-left:auto;display:flex;gap:4px;font-size:.86rem;font-weight:600}
.tnav a{padding:9px 14px;border-radius:999px;transition:.22s;white-space:nowrap}
.tnav a:hover{background:var(--tide-tint);color:var(--tide-deep)}
.tb-toggle{display:none;margin-left:auto;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-family:var(--body);font-weight:700;font-size:.8rem;cursor:pointer;color:var(--deep)}
@media(max-width:940px){
  .tnav{display:none;position:absolute;left:0;right:0;top:100%;background:var(--card);border-bottom:1px solid var(--line);flex-direction:column;gap:0;padding:8px 28px 16px;box-shadow:var(--sh)}
  .tnav.open{display:flex}
  .tnav a{padding:13px 4px;border-radius:0;border-bottom:1px solid var(--line)}
  .tb-toggle{display:block}
}

/* ===== buttons ===== */
.btn{display:inline-block;font-size:.87rem;font-weight:700;padding:15px 28px;border-radius:999px;transition:.25s}
.btn.tide{background:linear-gradient(120deg,var(--tide),var(--tide-deep));color:#fff;box-shadow:0 14px 30px -12px rgba(10,166,166,.55)}
.btn.tide:hover{transform:translateY(-2px);box-shadow:0 18px 36px -12px rgba(10,166,166,.65)}
.btn.line{border:2px solid var(--deep);color:var(--deep)}
.btn.line:hover{background:var(--deep);color:#fff}

/* ===== home hero ===== */
.hero{padding:62px 0 36px}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:50px;align-items:center}
.chip{display:inline-flex;align-items:center;gap:9px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:.73rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--tide-deep);box-shadow:var(--sh)}
.chip::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--coral)}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,5vw,4.1rem);line-height:1.02;color:var(--deep);letter-spacing:-.03em;margin:.4em 0 .3em}
.hero h1 .tide{color:var(--tide-deep)}
.hero .lede{font-size:1.12rem;line-height:1.74;color:var(--soft);max-width:30em}
.hero .lede b{color:var(--deep)}
.cta-row{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap}
.hero-proof{display:flex;gap:28px;margin-top:34px;flex-wrap:wrap}
.hero-proof div{border-left:3px solid var(--tide-tint);padding-left:14px}
.hero-proof b{display:block;font-family:var(--display);font-weight:800;font-size:1.55rem;color:var(--deep)}
.hero-proof span{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--soft)}
.hfig{position:relative}
.hfig .main{border-radius:26px;overflow:hidden;box-shadow:var(--sh);aspect-ratio:4/3.2}
.hfig .main img{width:100%;height:100%;object-fit:cover}
.hfig .glass{position:absolute;background:rgba(255,255,255,.74);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.9);border-radius:16px;padding:13px 17px;box-shadow:var(--sh);font-size:.8rem;font-weight:600;color:var(--deep)}
.hfig .glass b{display:block;font-family:var(--display);font-weight:800;font-size:1.02rem;color:var(--tide-deep)}
.hfig .g1{left:-22px;top:16%}
.hfig .g2{right:-14px;bottom:14%}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr}.hfig .g1{left:0}.hfig .g2{right:0}}

/* wave divider */
.wave{height:44px;background:url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 50" preserveAspectRatio="none"><path d="M0 25 Q150 0 300 25 T600 25 T900 25 T1200 25 V50 H0 Z" fill="%23eaf5f5"/></svg>') repeat-x bottom/1200px 100%}
.foam{background:var(--foam)}

/* ===== home steps ===== */
.steps{padding:58px 0 64px}
.sec-head{text-align:center;max-width:640px;margin:0 auto 40px}
.sec-head h2{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,3.4vw,2.7rem);color:var(--deep);letter-spacing:-.02em;margin:.3em 0}
.sec-head h2 em{font-style:normal;color:var(--tide-deep)}
.sec-head p{color:var(--soft)}
.s-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.s-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);transition:.3s;display:flex;flex-direction:column;position:relative}
.s-card:hover{transform:translateY(-6px)}
.s-card .ph{aspect-ratio:16/9.8;overflow:hidden}
.s-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.s-card:hover .ph img{transform:scale(1.05)}
.s-card .n{position:absolute;top:14px;left:14px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);backdrop-filter:blur(6px);display:grid;place-items:center;font-family:var(--display);font-weight:800;font-size:1.05rem;color:var(--tide-deep);box-shadow:var(--sh)}
.s-card .bd{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1}
.s-card h3{font-family:var(--display);font-weight:700;font-size:1.28rem;color:var(--deep);margin:0 0 .4rem;letter-spacing:-.01em}
.s-card p{font-size:.92rem;color:var(--soft);margin:0 0 14px}
.s-card .go{margin-top:auto;font-size:.76rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--coral)}
@media(max-width:900px){.s-grid{grid-template-columns:1fr}}

/* ===== category tiles ===== */
.shelfband{padding:64px 0}
.band-head{display:flex;align-items:end;gap:22px;margin-bottom:30px;flex-wrap:wrap}
.band-head h2{font-family:var(--display);font-weight:800;font-size:clamp(1.9rem,3.2vw,2.6rem);color:var(--deep);letter-spacing:-.02em;margin:0}
.band-head h2 em{font-style:normal;color:var(--tide-deep)}
.band-head p{color:var(--soft);margin:0 0 5px;max-width:30em}
.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tile{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);aspect-ratio:16/11}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.tile:hover img{transform:scale(1.06)}
.tile .veil{position:absolute;inset:0;background:linear-gradient(188deg,rgba(12,47,63,0) 38%,rgba(12,47,63,.87))}
.tile .lab{position:absolute;left:20px;right:20px;bottom:15px;color:#fff}
.tile .lab .k{font-size:.63rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:#7fe5e0}
.tile .lab h3{font-family:var(--display);font-weight:700;font-size:1.25rem;margin:.2rem 0 0;letter-spacing:-.01em}
.tile .cnt{position:absolute;top:13px;right:13px;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);border-radius:999px;padding:5px 12px;font-size:.71rem;font-weight:700;color:var(--deep)}
@media(max-width:920px){.tile-grid{grid-template-columns:1fr 1fr}}
@media(max-width:580px){.tile-grid{grid-template-columns:1fr}}

/* ===== latest cards ===== */
.latest{padding:56px 0 76px}
.lt-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.lt-card{display:grid;grid-template-columns:120px 1fr;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:13px;align-items:center;box-shadow:var(--sh);transition:.26s}
.lt-card:hover{transform:translateY(-3px);border-color:var(--tide)}
.lt-card .ph{aspect-ratio:1/1;border-radius:12px;overflow:hidden}
.lt-card .ph img{width:100%;height:100%;object-fit:cover}
.lt-card .k{font-size:.63rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--tide-deep)}
.lt-card h3{font-family:var(--display);font-weight:700;font-size:1.08rem;color:var(--deep);margin:.22rem 0 .18rem;line-height:1.3;letter-spacing:-.01em}
.lt-card p{font-size:.84rem;color:var(--soft);margin:0}
@media(max-width:880px){.lt-grid{grid-template-columns:1fr}}

/* ===== trust ===== */
.trustband{padding:6px 0 72px}
.tr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tr-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:26px 26px 28px;box-shadow:var(--sh)}
.tr-card h3{font-family:var(--display);font-weight:700;font-size:1.2rem;color:var(--deep);margin:0 0 .45rem;letter-spacing:-.01em}
.tr-card p{font-size:.91rem;color:var(--soft);margin:0}
@media(max-width:880px){.tr-grid{grid-template-columns:1fr}}

/* ===== archive / category ===== */
.cathero{padding:46px 0 8px}
.crumbs{font-size:.78rem;font-weight:600;color:var(--soft);margin-bottom:16px}
.crumbs a:hover{color:var(--tide-deep)}
.cathero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:42px;align-items:center;margin-bottom:34px}
.cathero h1{font-family:var(--display);font-weight:800;font-size:clamp(2rem,3.8vw,3rem);color:var(--deep);letter-spacing:-.02em;margin:.25em 0 .3em;line-height:1.06}
.cathero p{color:var(--soft);max-width:36em}
.cathero .count{display:inline-block;margin-top:12px;background:var(--tide-tint);color:var(--tide-deep);border-radius:999px;padding:7px 16px;font-size:.74rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.cathero .ph{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);aspect-ratio:16/10}
.cathero .ph img{width:100%;height:100%;object-fit:cover}
@media(max-width:900px){.cathero-grid{grid-template-columns:1fr}}
.rows{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding-bottom:46px}
.row-card{display:grid;grid-template-columns:132px 1fr;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);transition:.25s;align-items:center}
.row-card:hover{transform:translateY(-3px);border-color:var(--tide)}
.row-card .ph{height:100%;min-height:112px;overflow:hidden}
.row-card .ph img{width:100%;height:100%;object-fit:cover}
.row-card .bd{padding:15px 19px}
.row-card .k{font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--tide-deep)}
.row-card h3{font-family:var(--display);font-weight:700;font-size:1.08rem;color:var(--deep);margin:.25rem 0 .2rem;line-height:1.3}
.row-card p{font-size:.84rem;color:var(--soft);margin:0}
@media(max-width:880px){.rows{grid-template-columns:1fr}}
@media(max-width:520px){.row-card{grid-template-columns:1fr}.row-card .ph{aspect-ratio:16/8}}
.pagination{display:flex;gap:8px;justify-content:center;padding:6px 0 56px;font-size:.85rem;font-weight:600}
.pagination .page-numbers{padding:10px 16px;border:1px solid var(--line);border-radius:999px;background:var(--card)}
.pagination .page-numbers.current{background:var(--deep);color:#fff;border-color:var(--deep)}
.pagination a.page-numbers:hover{border-color:var(--tide)}

/* ===== article ===== */
.post{max-width:760px;margin:0 auto;padding:44px 28px 30px}
.post .crumbs{margin-bottom:18px}
.post .k{font-size:.7rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--tide-deep)}
.post h1{font-family:var(--display);font-weight:800;font-size:clamp(1.85rem,4vw,2.85rem);color:var(--deep);line-height:1.1;margin:.4em 0 .4em;letter-spacing:-.02em}
.post .meta-line{display:flex;align-items:center;gap:13px;font-size:.82rem;font-weight:600;color:var(--soft);padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:26px}
.post .meta-line .blob{width:30px;height:30px;border-radius:46% 54% 55% 45%/52% 44% 56% 48%;background:linear-gradient(140deg,var(--tide),var(--tide-deep));flex:none}
.post .meta-line b{color:var(--deep)}
.post .feat{border-radius:var(--r);overflow:hidden;box-shadow:var(--sh);margin:0 0 28px}
.post .feat img{width:100%;height:auto}

.prose{font-size:1.03rem;line-height:1.76}
.prose h2{font-family:var(--display);font-weight:700;font-size:1.62rem;color:var(--deep);line-height:1.16;margin:1.7em 0 .6em;letter-spacing:-.015em}
.prose h3{font-family:var(--display);font-weight:700;font-size:1.24rem;color:var(--text);margin:1.4em 0 .5em}
.prose p{margin:0 0 1.15em}
.prose a{color:var(--tide-deep);text-decoration:underline;text-underline-offset:2px;text-decoration-color:rgba(10,166,166,.4);transition:.2s}
.prose a:hover{text-decoration-color:var(--tide-deep)}
.prose ul,.prose ol{margin:0 0 1.2em;padding-left:1.4em}
.prose li{margin:.4em 0}
.prose figure{margin:1.8em 0;border-radius:var(--r);overflow:hidden;box-shadow:var(--sh)}
.prose figure img{width:100%;height:auto;display:block}
.prose img{border-radius:var(--r)}
.prose table{width:100%;border-collapse:collapse;margin:1.6em 0;font-size:.92rem;background:var(--card);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.prose thead th{background:var(--deep);color:#eafafa;font-size:.74rem;font-weight:700;letter-spacing:.07em;text-transform:uppercase;text-align:left;padding:12px 14px}
.prose td{padding:11px 14px;border-top:1px solid var(--line);vertical-align:top}
.prose tbody tr:nth-child(even){background:var(--foam)}
@media(max-width:768px){.prose table{display:block;width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}}
.prose blockquote{margin:1.6em 0;padding:18px 24px;border-left:4px solid var(--tide);background:var(--foam);border-radius:0 var(--r) var(--r) 0;color:var(--text)}

/* FAQ */
.nib-faq{margin:2.2em 0 0}
.nib-faq h2{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--deep);margin:0 0 .6em}
.nib-faq details{background:var(--card);border:1px solid var(--line);border-radius:14px;margin:0 0 10px;padding:0 20px;box-shadow:var(--sh)}
.nib-faq summary{cursor:pointer;font-family:var(--display);font-weight:700;font-size:1.02rem;color:var(--deep);padding:16px 30px 16px 0;list-style:none;position:relative}
.nib-faq summary::-webkit-details-marker{display:none}
.nib-faq summary::after{content:"+";position:absolute;right:2px;top:50%;transform:translateY(-50%);font-size:1.3rem;font-weight:400;color:var(--tide-deep);transition:.25s}
.nib-faq details[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.nib-faq details p{padding:0 0 16px;margin:0;color:var(--text)}

/* sources + read next */
.srcs{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;margin:2.4em 0 0;font-size:.92rem;box-shadow:var(--sh)}
.srcs h2{font-family:var(--display);font-weight:700;font-size:1.18rem;color:var(--deep);margin:0 0 .7rem}
.srcs ol{margin:0;padding-left:1.2rem}
.srcs li{margin:.45rem 0;color:var(--soft)}
.srcs a{color:var(--tide-deep);text-decoration:underline;text-underline-offset:2px;font-weight:600;word-break:break-word}
.srcs a:hover{color:var(--coral)}
.readnext{margin:2.2em 0 0}
.readnext h2{font-family:var(--display);font-weight:700;font-size:1.35rem;color:var(--deep);margin:0 0 .8rem}
.readnext ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.readnext a{display:flex;gap:12px;align-items:baseline;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 18px;font-family:var(--display);font-weight:700;font-size:1rem;color:var(--deep);transition:.22s}
.readnext a::before{content:"→";color:var(--coral)}
.readnext a:hover{border-color:var(--tide);transform:translateX(4px)}
.teambox{display:flex;gap:18px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:24px;margin:2.4em 0 60px;box-shadow:var(--sh)}
.teambox .blob{width:54px;height:54px;border-radius:46% 54% 55% 45%/52% 44% 56% 48%;background:linear-gradient(140deg,var(--tide),var(--tide-deep));flex:none}
.teambox h3{font-family:var(--display);font-weight:700;font-size:1.12rem;color:var(--deep);margin:0 0 .3rem}
.teambox p{font-size:.9rem;color:var(--soft);margin:0}

/* ===== pages / misc ===== */
.pagebody{max-width:760px;margin:0 auto;padding:48px 28px 70px}
.pagebody h1{font-family:var(--display);font-weight:800;font-size:2.3rem;color:var(--deep);letter-spacing:-.02em}
.bigmsg{text-align:center;padding:110px 28px}
.bigmsg h1{font-family:var(--display);font-weight:800;font-size:2.7rem;color:var(--deep);margin:.2em 0 .3em}
.bigmsg p{color:var(--soft)}
.searchform{display:flex;gap:10px;max-width:480px;margin:26px auto 0}
.searchform input{flex:1;padding:14px 20px;border:1px solid var(--line);border-radius:999px;background:var(--card);font-family:var(--body);font-size:1rem;color:var(--text)}
.searchform button{border:0;cursor:pointer}

/* ===== footer ===== */
.foot{background:var(--deep);color:#9fc0c8;padding:54px 0 38px;font-size:.92rem;margin-top:36px}
.fo-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:42px}
.foot .brandmark{color:#fff}
.foot h4{font-size:.7rem;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:#7fe5e0;margin:0 0 14px}
.foot ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.foot a:hover{color:#fff}
.fo-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:40px;padding-top:20px;display:flex;justify-content:space-between;gap:14px;font-size:.78rem;flex-wrap:wrap}
@media(max-width:880px){.fo-grid{grid-template-columns:1fr}}
