/*
Theme Name: Loomflo Blog
Theme URI: https://loomflo.com
Author: Loomflo
Author URI: https://loomflo.com
Description: Custom blog theme matching the Loomflo marketing site — warm sage/sky palette, Sora + Fraunces + JetBrains Mono, asymmetric editorial article layout. Built for blog.loomflo.com so WordPress posts feel native to the main site.
Version: 1.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: loomflo
Tags: blog, custom-colors, editor-style, featured-images, threaded-comments
*/

/* ============================================================
   LOOMFLO BLOG — Daylight greenish-white theme
   ============================================================ */
:root{
  --bg:#f7f8f6; --bg-2:#eef1ec; --surface:#ffffff; --surface-2:#f3f5f2;
  --line:rgba(22,48,61,.10); --line-2:rgba(22,48,61,.18);
  --navy:#16303d; --fg:#16303d; --fg-soft:#44606b; --fg-mute:#6b7e86;
  --accent:#3e8e7e; --accent-soft:#6fb89a; --accent-deep:#6aa6d8; --on-accent:#ffffff;
  --grad:linear-gradient(95deg,#6fb89a,#6aa6d8);
  --sh-sm:0 1px 2px rgba(22,48,61,.06);
  --sh:0 18px 44px -22px rgba(22,48,61,.22);
  --sh-lg:0 40px 90px -44px rgba(22,48,61,.26);
  --r:18px; --maxw:1080px;
  --e:cubic-bezier(.16,1,.3,1);
  --fd:"Sora",system-ui,sans-serif; --fb:"Outfit",system-ui,sans-serif;
  --fm:"JetBrains Mono",ui-monospace,monospace; --fserif:"Fraunces",Georgia,serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);background:var(--bg);color:var(--fg);line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,44px)}
.narrow{max-width:780px}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--fd);font-weight:600;letter-spacing:-.025em;line-height:1.1;color:var(--navy)}
.mono{font-family:var(--fm);font-size:11px;letter-spacing:.2em;text-transform:uppercase}
.kick{display:inline-flex;align-items:center;gap:10px;color:var(--fg-mute)}
.kick::before{content:"";width:22px;height:1px;background:var(--accent)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--fd);font-weight:500;font-size:15px;padding:14px 24px;border-radius:999px;border:1px solid transparent;cursor:pointer;text-decoration:none;transition:transform .4s var(--e),box-shadow .3s,background .3s,border-color .3s,color .3s}
.btn:hover{text-decoration:none}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--accent);color:var(--on-accent);box-shadow:0 12px 26px -14px var(--accent)}
.btn-primary:hover{background:var(--accent-soft);transform:translateY(-2px)}
.btn-ghost{background:var(--surface);border-color:var(--line-2);color:var(--navy);box-shadow:var(--sh-sm)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ============================ NAV (scoped to header so it never clashes
   with WordPress's own .nav-links used in pagination) ============================ */
header{position:sticky;top:0;z-index:20;background:rgba(247,248,246,.82);backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid var(--line)}
.admin-bar header{top:32px}
.nav{position:relative;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 0}
.brand{display:flex;align-items:center;gap:10px}
.brand .wave{width:30px;height:20px;flex:0 0 auto}
.brand b{font-family:var(--fserif);font-weight:600;font-size:21px;letter-spacing:-.01em;color:var(--navy)}
header .nav-links{display:flex;align-items:center;gap:18px}
header .nav-links a{color:var(--fg-mute);font-family:var(--fd);font-size:14px}
header .nav-links a:hover{color:var(--accent);text-decoration:none}
header .nav-links a.current{color:var(--navy)}
.nav-cta{display:flex;align-items:center;gap:12px}
.nav-cta a.btn-primary,.nav-cta a.btn-primary:hover{color:var(--on-accent)}
.menu-btn{display:none;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--line-2);border-radius:12px;background:var(--surface);color:var(--navy);cursor:pointer;transition:border-color .25s,color .25s}
.menu-btn:hover{border-color:var(--accent);color:var(--accent)}
.menu-btn svg{width:22px;height:22px}
@media(max-width:760px){
  .menu-btn{display:inline-flex}
  header .nav-links{position:absolute;top:calc(100% + 10px);left:0;right:0;flex-direction:column;align-items:stretch;gap:3px;background:rgba(255,255,255,.97);backdrop-filter:blur(18px) saturate(140%);border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--sh);opacity:0;visibility:hidden;transform:translateY(-8px);transition:opacity .28s,transform .28s var(--e),visibility .28s}
  header .nav-links.show{opacity:1;visibility:visible;transform:none}
  header .nav-links a{padding:13px 15px;border-radius:10px;font-size:15px;color:var(--navy)}
  header .nav-links a:hover{background:color-mix(in srgb,var(--accent) 9%,transparent)}
}

/* page hero */
.phero{padding:72px 0 36px;position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.phero .glow{position:absolute;width:55vw;height:55vw;right:-18vw;top:-26vw;border-radius:50%;filter:blur(120px);background:radial-gradient(circle,rgba(111,184,154,.26),transparent 65%);pointer-events:none}
.phero h1{font-size:clamp(34px,6vw,62px);letter-spacing:-.035em;position:relative;margin-top:16px}
.phero h1 em{font-style:normal;color:var(--accent)}
.phero p{color:var(--fg-soft);font-size:clamp(16px,1.5vw,19px);max-width:60ch;margin-top:18px}
.blog-head{padding-bottom:34px}

/* ============================ BLOG LISTING ============================ */
.blog-list{padding:42px 0 84px}
.thumb{position:relative;display:block;background:var(--grad);overflow:hidden}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.thumb .ph{position:absolute;inset:0;display:grid;place-items:center;background:radial-gradient(120% 120% at 0% 0%,rgba(255,255,255,.22),transparent 55%),var(--grad)}
.thumb .ph svg{width:48px;height:48px;color:rgba(255,255,255,.9)}
.tagchip{display:inline-flex;align-items:center;width:max-content;font-family:var(--fm);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.tagchip.t-blog{background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent)}
.tagchip.t-news{background:color-mix(in srgb,var(--accent-deep) 16%,transparent);color:var(--accent-deep)}
.pmeta{display:flex;align-items:center;gap:10px;margin-top:auto;font-family:var(--fm);font-size:11px;letter-spacing:.04em;color:var(--fg-mute)}
.pmeta .dot{width:3px;height:3px;border-radius:50%;background:var(--fg-mute);flex:0 0 auto}

.feat{display:grid;grid-template-columns:1.05fr .95fr;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--surface);box-shadow:var(--sh);margin-bottom:42px;transition:transform .4s var(--e),box-shadow .4s}
.feat:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);text-decoration:none}
.feat .thumb{min-height:310px}
.feat .body{padding:clamp(26px,3.4vw,44px);display:flex;flex-direction:column;justify-content:center}
.feat .tagchip{margin-bottom:16px}
.feat h2{font-size:clamp(22px,3vw,33px);margin-bottom:13px;color:var(--navy);line-height:1.12}
.feat p{color:var(--fg-soft);font-size:15.5px;margin-bottom:22px}
@media(max-width:760px){.feat{grid-template-columns:1fr}.feat .thumb{min-height:200px}}

.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:26px}
.pcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--surface);box-shadow:var(--sh-sm);transition:transform .4s var(--e),box-shadow .4s,border-color .3s}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-2);text-decoration:none}
.pcard .thumb{height:186px}
.pcard .body{display:flex;flex-direction:column;flex:1;padding:22px 22px 24px}
.pcard .tagchip{margin-bottom:13px}
.pcard h3{font-size:18.5px;line-height:1.28;color:var(--navy);margin-bottom:9px}
.pcard p{color:var(--fg-soft);font-size:14px;margin-bottom:18px;flex:1}
.empty{text-align:center;color:var(--fg-mute);font-size:15px;padding:64px 0}

/* ============================ ARTICLE ============================ */
.art-hero{padding:50px 0 0}
.art-hero .readmore{display:inline-flex;align-items:center;gap:6px;font-family:var(--fd);font-size:14px;font-weight:500;color:var(--accent)}
.art-hero .readmore:hover{text-decoration:none}
.art-hero h1{font-size:clamp(28px,5vw,52px);letter-spacing:-.035em;line-height:1.07;color:var(--navy);max-width:21ch;margin-top:8px}
.art-hero .excerpt{color:var(--fg-soft);font-size:clamp(16px,1.6vw,19px);margin-top:20px;max-width:62ch}
.art-meta{display:flex;align-items:center;gap:11px;flex-wrap:wrap;margin-top:22px;font-family:var(--fm);font-size:11.5px;letter-spacing:.05em;color:var(--fg-mute)}
.art-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--fg-mute)}
.art-cover{margin-top:40px;border-radius:24px;overflow:hidden;aspect-ratio:16/8;box-shadow:var(--sh)}
.art-cover img{width:100%;height:100%;object-fit:cover}
.article-body{padding:42px 0 28px}
.article-body>*:first-child{margin-top:0}
.article-body p{color:var(--fg-soft);font-size:16.5px;line-height:1.78;margin-bottom:20px}
.article-body h2{font-size:clamp(22px,2.6vw,28px);margin:42px 0 14px;color:var(--navy)}
.article-body h3{font-size:19px;margin:30px 0 10px;color:var(--navy)}
.article-body h4{font-size:16.5px;margin:24px 0 8px;color:var(--navy)}
.article-body ul,.article-body ol{margin:0 0 22px 22px;color:var(--fg-soft);font-size:16.5px}
.article-body li{margin-bottom:10px}
.article-body strong{color:var(--navy)}
.article-body a{color:var(--accent);text-decoration:underline}
.article-body blockquote{border-left:3px solid var(--accent);background:color-mix(in srgb,var(--accent) 6%,transparent);border-radius:0 12px 12px 0;padding:18px 24px;margin:30px 0;font-family:var(--fserif);font-size:20px;line-height:1.45;color:var(--navy)}
.article-body blockquote p{font-size:inherit;color:inherit;margin-bottom:0}
.article-body img,.article-body .wp-block-image{margin:26px 0}
.article-body img{border-radius:16px}
.article-body figcaption,.wp-caption-text{font-family:var(--fm);font-size:12px;color:var(--fg-mute);text-align:center;margin-top:8px;letter-spacing:.02em}
.article-body pre{background:var(--navy);color:#eaf2ee;padding:20px 22px;border-radius:14px;overflow:auto;font-family:var(--fm);font-size:13.5px;margin:26px 0}
.article-body code{font-family:var(--fm);font-size:.9em;background:var(--surface-2);padding:2px 6px;border-radius:6px}
.article-body pre code{background:none;padding:0}
.alignleft{float:left;margin:6px 26px 18px 0}
.alignright{float:right;margin:6px 0 18px 26px}
.aligncenter{display:block;margin-inline:auto}
.wp-block-image.alignwide,.alignwide{max-width:min(1080px,92vw);margin-inline:calc(50% - min(540px,46vw))}

.art-foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;border-top:1px solid var(--line);margin-top:18px;padding-top:30px}
.art-share{display:flex;gap:10px}
.art-share a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--line-2);color:var(--fg-soft);transition:transform .3s var(--e),border-color .25s,color .25s}
.art-share a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);text-decoration:none}
.art-share svg{width:17px;height:17px}
.more{padding:48px 0 84px;margin-top:34px;border-top:1px solid var(--line)}
.more h4{font-family:var(--fm);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);margin-bottom:24px}

/* ============================ PAGINATION ============================ */
.navigation.pagination{padding:50px 0 0}
.navigation.pagination .nav-links{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.page-numbers{display:grid;place-items:center;min-width:42px;height:42px;padding:0 14px;border:1px solid var(--line-2);border-radius:12px;background:var(--surface);color:var(--fg-soft);font-family:var(--fd);font-size:14px}
.page-numbers:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.page-numbers.current{background:var(--navy);border-color:var(--navy);color:#fff}

/* ============================ FOOTER ============================ */
footer{border-top:1px solid var(--line);padding:48px 0 34px;background:var(--bg-2)}
.foot{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
.foot .links{display:flex;gap:20px;flex-wrap:wrap}
.foot a{color:var(--fg-soft);font-size:14px}
.foot a:hover{color:var(--accent);text-decoration:none}
.foot .cr{font-family:var(--fm);font-size:11px;letter-spacing:.05em;color:var(--fg-mute)}

/* generic page (about, etc.) reuses article prose */
.page-body{padding:42px 0 80px}

@media (prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.001ms!important;animation-duration:.001ms!important}}
