/* ============================================================
   clöudelle journal — listing + article
   ============================================================ */
:root{
  --forest:#0f3d2e; --forest-deep:#082018; --cream:#f7f3e3; --paper:#f5f0e0;
  --gold:#c79a3f; --gold-bright:#e8c468; --gold-deep:#a87f2c; --terra:#d4582a; --ink:#23291f;
  --gold-soft:#d9c38a;
  --line:rgba(15,61,46,.12); --muted:rgba(35,41,31,.62);
  --serif:'Fraunces',Georgia,serif; --sans:'Jost',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:var(--paper);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;line-height:1.5}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ---------- site header (matches the main site exactly) ---------- */
.site-head{position:sticky;top:0;left:0;right:0;z-index:200;background:rgba(8,32,24,.92);backdrop-filter:blur(14px) saturate(1.2);-webkit-backdrop-filter:blur(14px) saturate(1.2);box-shadow:0 6px 30px rgba(0,0,0,.18)}
.site-head .wrap{display:flex;align-items:center;justify-content:space-between;height:82px;max-width:1180px;margin:0 auto;padding:0 40px}
.site-head .brand{display:flex;align-items:center}
.site-head .brand-logo{height:56px;width:auto;display:block}
.site-head .nav{display:flex;align-items:center;gap:30px}
.site-head .nav a{font-family:var(--sans);font-size:.95rem;font-weight:400;color:rgba(247,243,227,.82);position:relative;transition:color .15s;text-decoration:none}
.site-head .nav a:hover,.site-head .nav a.active{color:var(--cream)}
.site-head .nav a:not(.head-cta)::after{content:'';position:absolute;left:0;bottom:-7px;height:2px;width:0;background:var(--gold-soft);transition:width .3s}
.site-head .nav a:not(.head-cta):hover::after,.site-head .nav a.active::after{width:100%}
.site-head .head-cta{background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:var(--forest-deep)!important;padding:10px 20px;border-radius:30px;font-weight:600;font-size:.9rem}
.site-head .menu-btn{display:none;background:rgba(247,243,227,.10);border:1px solid rgba(247,243,227,.18);width:46px;height:46px;border-radius:13px;color:var(--cream);cursor:pointer;align-items:center;justify-content:center;position:relative;z-index:40}
.site-head .menu-btn .mb-bars{position:relative;width:20px;height:13px;display:block}
.site-head .menu-btn .mb-bars i{position:absolute;left:0;right:0;height:1.6px;border-radius:2px;background:var(--cream);transition:transform .3s cubic-bezier(.2,.8,.2,1),opacity .2s,background .2s}
.site-head .menu-btn .mb-bars i:nth-child(1){top:0}
.site-head .menu-btn .mb-bars i:nth-child(2){top:5.7px}
.site-head .menu-btn .mb-bars i:nth-child(3){top:11.4px}
.site-head .menu-btn.open{background:rgba(199,154,63,.16);border-color:rgba(216,184,101,.5)}
.site-head .menu-btn.open .mb-bars i:nth-child(1){transform:translateY(5.7px) rotate(45deg);background:var(--gold-bright)}
.site-head .menu-btn.open .mb-bars i:nth-child(2){opacity:0}
.site-head .menu-btn.open .mb-bars i:nth-child(3){transform:translateY(-5.7px) rotate(-45deg);background:var(--gold-bright)}
body.menu-open{overflow:hidden}
@keyframes navIn{to{opacity:1;transform:none}}

/* ---------- layout ---------- */
.wrap{max-width:1120px;margin:0 auto;padding:0 48px}
.j-empty{color:var(--muted);font-size:1.05rem;padding:50px 0 90px;text-align:center}

/* ---------- listing header ---------- */
.j-head{padding:64px 0 30px;text-align:center}
.eyebrow{font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold-deep);font-weight:600;display:inline-block}
.j-head h1{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:clamp(2.2rem,5vw,3.6rem);line-height:1.04;margin:.32em 0 0}
.j-head p{max-width:540px;margin:18px auto 0;color:var(--muted);font-size:1.02rem;line-height:1.6}

/* ---------- toolbar ---------- */
.toolbar{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;
  padding:22px 0 30px;border-bottom:1px solid var(--line);margin-bottom:40px}
.cats{display:flex;flex-wrap:wrap;gap:8px}
.cat{font-size:.82rem;font-weight:500;color:var(--forest);background:transparent;border:1px solid var(--line);
  padding:8px 16px;border-radius:999px;cursor:pointer;transition:.2s;white-space:nowrap}
.cat:hover{border-color:var(--gold)}
.cat.on{background:var(--forest);border-color:var(--forest);color:var(--cream)}
.view-toggle{display:inline-flex;align-items:center;gap:4px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:4px}
.vt{display:flex;align-items:center;gap:7px;font-size:.8rem;font-weight:500;color:var(--muted);border:0;background:transparent;
  padding:8px 15px;border-radius:999px;cursor:pointer;transition:.2s;font-family:var(--sans)}
.vt svg{width:16px;height:16px}
.vt.on{background:var(--gold);color:#2a1e07;box-shadow:0 4px 12px rgba(199,154,63,.3)}

/* ---------- cover placeholder / image ---------- */
.cover{position:relative;overflow:hidden;background:linear-gradient(140deg,#2f6b3a,#0f3d2e);background-size:cover;background-position:center}
.cover::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 80% 0,rgba(255,255,255,.16),transparent 60%)}
.cover .badge{position:absolute;top:14px;left:14px;z-index:2;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;
  color:#fff;background:rgba(8,24,16,.42);backdrop-filter:blur(4px);padding:6px 12px;border-radius:999px}

/* ---------- meta ---------- */
.meta{display:flex;align-items:center;gap:10px;margin-top:18px;font-size:.82rem;color:var(--muted)}
.av{width:30px;height:30px;border-radius:50%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:600;font-size:.72rem;color:#2a1e07;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep))}
.meta .dot{width:3px;height:3px;border-radius:50%;background:var(--muted);opacity:.6}

/* ---------- featured ---------- */
.featured{display:grid;grid-template-columns:1.15fr 1fr;gap:40px;align-items:center;margin-bottom:54px;cursor:pointer}
.featured .cover{aspect-ratio:4/3;border-radius:18px}
.featured h2{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:clamp(1.7rem,3vw,2.5rem);line-height:1.08;margin:14px 0 0;transition:color .2s}
.featured:hover h2{color:var(--gold-deep)}
.featured .excerpt{color:var(--muted);font-size:1.04rem;line-height:1.65;margin:16px 0 0;max-width:42ch}
.read-more{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-weight:600;color:var(--forest);font-size:.92rem}
.read-more .arr{transition:transform .25s}
.featured:hover .read-more .arr{transform:translateX(5px)}

/* ---------- collection: GRID ---------- */
.collection.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:34px 28px}
.card{cursor:pointer;display:flex;flex-direction:column}
.card .cover{aspect-ratio:3/2;border-radius:14px;transition:transform .4s ease}
.card:hover .cover{transform:translateY(-3px)}
.card .cbody{display:flex;flex-direction:column}
.card h3{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:1.28rem;line-height:1.16;margin:16px 0 0;transition:color .2s}
.card:hover h3{color:var(--gold-deep)}
.card .excerpt{color:var(--muted);font-size:.94rem;line-height:1.55;margin:9px 0 0}

/* ---------- collection: LIST ---------- */
.collection.list{display:flex;flex-direction:column}
.collection.list .card{flex-direction:row;gap:30px;align-items:center;padding:30px 0;border-top:1px solid var(--line)}
.collection.list .card:first-child{border-top:0;padding-top:6px}
.collection.list .card:last-child{border-bottom:1px solid var(--line)}
.collection.list .card .cover{flex:0 0 300px;aspect-ratio:16/10}
.collection.list .card .cbody{flex:1}
.collection.list .card h3{font-size:1.55rem;margin-top:0}
.collection.list .card .excerpt{font-size:1rem;max-width:60ch}

/* ---------- pagination ---------- */
.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin:58px 0 84px}
.pg{min-width:42px;height:42px;padding:0 12px;border-radius:12px;border:1px solid var(--line);background:#fff;
  font-family:var(--sans);font-size:.92rem;color:var(--forest);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:.2s}
.pg:hover{border-color:var(--gold)}
.pg.on{background:var(--forest);border-color:var(--forest);color:var(--cream);font-weight:600}
.pg.nav{font-size:1.15rem}
.pg[aria-disabled="true"]{opacity:.35;cursor:default;pointer-events:none}

/* ============================================================
   ARTICLE
   ============================================================ */
.article{padding:46px 0 0}
.a-wrap{max-width:760px;margin:0 auto;padding:0 48px}
.back{display:inline-flex;align-items:center;gap:8px;font-size:.85rem;font-weight:500;color:var(--muted);margin-bottom:30px}
.back:hover{color:var(--forest)}
.a-cat{display:flex;align-items:center;gap:12px;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}
.a-cat .c{color:var(--terra)}
.a-cat .r{color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:none}
.article h1{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:clamp(2.1rem,4.4vw,3.2rem);line-height:1.06;margin:16px 0 0;letter-spacing:-.01em}
.a-meta{display:flex;align-items:center;gap:12px;margin:26px 0 0;padding-bottom:30px;border-bottom:1px solid var(--line)}
.a-meta .av{width:42px;height:42px;font-size:.95rem}
.a-meta .who b{display:block;font-weight:600;color:var(--ink);font-size:.92rem}
.a-meta .who span{font-size:.8rem;color:var(--muted)}
.a-meta .share{margin-left:auto;display:flex;gap:8px}
.a-meta .share a{width:36px;height:36px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--forest);transition:.2s}
.a-meta .share a:hover{background:var(--forest);color:var(--cream);border-color:var(--forest)}
.a-meta .share a.copied{background:var(--gold);border-color:var(--gold);color:#2a1e07}
.a-meta .share svg{width:16px;height:16px}

.a-cover{max-width:1000px;margin:38px auto;padding:0 48px}
.a-cover .cover{aspect-ratio:16/9;border-radius:18px}

.prose{font-size:1.12rem;line-height:1.78;color:#2c322a}
.prose>p{margin:0 0 1.4em}
.prose>p:first-child{font-size:1.3rem;line-height:1.6;color:var(--forest)}
.prose .lead{font-size:1.3rem;line-height:1.6;color:var(--forest)}
.prose h2{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:1.7rem;line-height:1.2;margin:1.9em 0 .5em}
.prose h3{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:1.3rem;margin:1.6em 0 .4em}
.prose a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{margin:0 0 1.4em;padding-left:1.3em}
.prose li{margin:.5em 0}
.prose blockquote{margin:1.8em 0;padding:6px 0 6px 28px;border-left:3px solid var(--gold);font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.4;color:var(--forest)}
.prose figure{margin:2em 0}
.prose img{border-radius:14px;margin:1.6em 0}
.prose figure img{margin:0}
.prose figcaption{margin-top:10px;font-size:.84rem;color:var(--muted);text-align:center}

.tags{display:flex;flex-wrap:wrap;gap:8px;margin:40px 0 0}
.tag{font-size:.8rem;color:var(--forest);background:rgba(15,61,46,.06);padding:7px 14px;border-radius:999px}

.author-card{display:flex;gap:18px;align-items:flex-start;margin:42px 0;padding:26px;background:#fff;border:1px solid var(--line);border-radius:18px}
.author-card .av{width:56px;height:56px;font-size:1.2rem}
.author-card b{font-family:var(--serif);font-size:1.15rem;color:var(--forest)}
.author-card p{margin:6px 0 0;color:var(--muted);font-size:.94rem;line-height:1.55}

.cta{background:var(--forest);background-image:radial-gradient(120% 100% at 85% 0,#13452f,var(--forest) 60%);margin-top:60px;padding:56px 0;text-align:center;color:var(--cream)}
.cta h3{font-family:var(--serif);font-weight:600;font-size:clamp(1.6rem,3vw,2.2rem);margin:0}
.cta p{color:rgba(247,243,227,.7);margin:12px 0 24px}
.cta .btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep));color:#2a1e07;font-weight:600;padding:14px 28px;border-radius:999px}

.more{padding:64px 0 84px}
.more .mh{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:30px}
.more .mh h2{font-family:var(--serif);font-weight:600;color:var(--forest);font-size:1.9rem;margin:0}
.more .mh a{font-size:.88rem;font-weight:600;color:var(--gold-deep)}
.more-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

/* ---------- site footer ---------- */
.site-foot{background:var(--forest-deep);color:rgba(247,243,227,.7)}
.sf-wrap{max-width:1180px;margin:0 auto;padding:56px 48px 30px}
.sf-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.sf-brand img{width:200px;height:auto;margin-bottom:16px}
.sf-brand p{font-size:.92rem;line-height:1.6;max-width:34ch;margin:0}
.sf-col h4{color:var(--cream);font-family:var(--serif);font-size:1.05rem;margin:0 0 14px;font-weight:600}
.sf-col a{display:block;color:rgba(247,243,227,.7);font-size:.9rem;padding:5px 0;transition:color .2s}
.sf-col a:hover{color:var(--gold-bright)}
.sf-bottom{margin-top:40px;padding-top:22px;border-top:1px solid rgba(247,243,227,.1);font-size:.82rem}
.sf-bottom a{color:var(--gold-soft)}

/* ============================================================
   RESPONSIVE — mobile is GRID ONLY (toggle hidden)
   ============================================================ */
@media(max-width:860px){
  .site-head .wrap{padding:0 22px}
  .site-head .nav{display:none}
  .site-head .menu-btn{display:flex!important}
  .site-head .nav.open{display:flex;position:fixed;inset:0;z-index:35;height:100vh;height:100svh;flex-direction:column;justify-content:center;align-items:center;gap:2px;padding:96px 32px 48px;background:radial-gradient(130% 75% at 50% 15%,rgba(199,154,63,.16),transparent 58%),linear-gradient(168deg,#0d3e2e 0%,#06190f 74%);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);overflow-y:auto}
  .site-head .nav.open::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold) 28%,var(--gold-bright) 50%,var(--gold) 72%,transparent)}
  .site-head .nav.open a:not(.head-cta){font-family:var(--serif);font-weight:500;font-size:1.75rem;line-height:1;color:var(--cream);letter-spacing:.3px;width:min(290px,80vw);text-align:center;padding:16px 0;border-bottom:1px solid rgba(247,243,227,.10);opacity:0;transform:translateY(18px);animation:navIn .55s cubic-bezier(.2,.8,.2,1) forwards}
  .site-head .nav.open a::after{display:none}
  .site-head .nav.open a.active{color:var(--gold-soft);font-style:italic}
  .site-head .nav.open a:nth-child(1){animation-delay:.06s}.site-head .nav.open a:nth-child(2){animation-delay:.12s}.site-head .nav.open a:nth-child(3){animation-delay:.18s}.site-head .nav.open a:nth-child(4){animation-delay:.24s}.site-head .nav.open a:nth-child(5){animation-delay:.30s}.site-head .nav.open a:nth-child(6){animation-delay:.36s}.site-head .nav.open a:nth-child(7){animation-delay:.42s}
  .site-head .nav.open a.head-cta{margin-top:28px;width:auto;border-bottom:none;opacity:0;transform:translateY(18px);animation:navIn .55s cubic-bezier(.2,.8,.2,1) forwards;animation-delay:.48s}

  .wrap{padding:0 22px}
  .a-wrap,.a-cover{padding:0 22px}
  .j-head{padding:46px 0 24px}
  .j-head h1{font-size:2.1rem}

  .toolbar{flex-direction:column;align-items:stretch;gap:16px}
  .view-toggle{display:none}              /* no grid/list switch on mobile */

  .featured{grid-template-columns:1fr;gap:22px}
  .featured .cover{aspect-ratio:16/10}

  /* force single-column grid cards regardless of saved view */
  .collection{display:grid!important;grid-template-columns:1fr!important;gap:26px!important}
  .collection .card{flex-direction:column!important;align-items:stretch!important;gap:0!important;padding:0!important;border:0!important}
  .collection .card .cover{flex:none!important;aspect-ratio:3/2!important}
  .collection .card h3{font-size:1.3rem!important;margin-top:14px!important}
  .collection .card .excerpt{margin-top:8px!important}

  .article h1{font-size:2rem}
  .more-grid{grid-template-columns:1fr}

  .sf-wrap{padding:40px 22px 24px}
  .sf-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:520px){
  .sf-grid{grid-template-columns:1fr}
}
