/* ============================================================
   SiyaWorks — "Bloom" design system  (HalfSage-inspired, all light)
   ============================================================ */
:root{
  /* lotus spectrum */
  --magenta:#e8418a; --rose:#f06aa6; --violet:#9b5de5; --violet-deep:#7c4fe0;
  --blue:#2f6fe0;    --teal:#1fb6c9; --gold:#f4a81e; --leaf:#3fae66;
  /* warm surfaces */
  --cream:#fcfaf5; --cream-2:#f5f2ea; --tint:#fdeede;
  --ink:#241d2b; --ink-2:#3a3340; --ink-70:#5b5364; --ink-50:#867d90; --ink-30:rgba(36,29,43,.30);
  --brass:#a9763e; --line:#ece7db; --line-2:#f2eee3;
  /* soft band tints */
  --soft-rose:#ffe9f2; --soft-violet:#f1ebff; --soft-blue:#e6efff; --soft-teal:#e2f6f8; --soft-gold:#fff3da;
  /* type */
  --display:"Bricolage Grotesque",system-ui,sans-serif;
  --sans:"DM Sans",system-ui,-apple-system,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;
  /* motion */
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:88px;}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden;padding-top:72px;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
::selection{background:var(--magenta);color:#fff;}

/* ---------- keyframes ---------- */
@keyframes sw-float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes sw-floatslow{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-16px) rotate(4deg)}}
@keyframes sw-blink{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes sw-marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes sw-orbit{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}
@keyframes sw-breathe{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-12px) scale(1.015)}}
@keyframes sw-spectrum{to{background-position:220% 0}}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,28px);}
.sec{padding:clamp(56px,8vw,92px) 0;}
.sec-sm{padding:clamp(40px,6vw,68px) 0;}

/* ---------- type ---------- */
h1,h2,h3,h4,.display,.title{font-family:var(--display);font-weight:700;letter-spacing:-.03em;line-height:1.02;}
.display{font-size:clamp(40px,6.6vw,72px);}
.title{font-size:clamp(30px,4.2vw,46px);letter-spacing:-.025em;}
h3.sub{font-size:clamp(20px,2.4vw,27px);letter-spacing:-.02em;}
.lede{font-size:clamp(17px,1.6vw,20px);color:var(--ink-70);max-width:56ch;line-height:1.6;}
.muted{color:var(--ink-50);}
.grad-text{background:linear-gradient(100deg,var(--magenta),var(--violet) 48%,var(--blue) 80%,var(--teal));-webkit-background-clip:text;background-clip:text;color:transparent;}
/* hand-drawn underline accent (like HalfSage) */
.uline{position:relative;color:var(--magenta);white-space:nowrap;}
.uline svg{position:absolute;left:0;bottom:-.18em;width:100%;height:.42em;}

/* ---------- kicker / pill ---------- */
.kicker{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--magenta);background:var(--soft-rose);padding:7px 13px;border-radius:999px;}
.kicker .dot{width:7px;height:7px;border-radius:99px;background:var(--magenta);display:inline-block;animation:sw-blink 1.8s infinite;}
.kicker.plain{background:none;padding:0;color:var(--brass);}
.eyebrow{font-family:var(--mono);font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--magenta);}

/* ---------- spectrum bar ---------- */
.spectrum{height:6px;background:linear-gradient(90deg,var(--magenta),var(--rose),var(--violet),var(--blue),var(--teal),var(--gold));background-size:220% 100%;animation:sw-spectrum 9s linear infinite;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-weight:700;font-size:15.5px;padding:14px 24px;border-radius:13px;cursor:pointer;border:0;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s,border-color .25s;white-space:nowrap;}
.btn .arr{transition:transform .25s var(--ease);}
.btn:hover .arr{transform:translateX(4px);}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:0 10px 24px rgba(232,65,138,.32);}
.btn-primary:hover{background:#db2f7c;transform:translateY(-2px);box-shadow:0 14px 30px rgba(232,65,138,.4);}
.btn-bloom{color:#fff;background:linear-gradient(100deg,var(--magenta),var(--violet) 60%,var(--blue));background-size:160% 100%;box-shadow:0 12px 28px rgba(155,93,229,.32);}
.btn-bloom:hover{transform:translateY(-2px);background-position:100% 0;box-shadow:0 16px 36px rgba(155,93,229,.42);}
.btn-ghost{background:#fff;border:1.5px solid var(--line);color:var(--ink);}
.btn-ghost:hover{border-color:var(--magenta);color:var(--magenta);transform:translateY(-2px);}
.btn-soft{background:var(--cream-2);color:var(--ink-2);}
.btn-soft:hover{background:#ebe6d9;transform:translateY(-2px);}

/* ---------- navigation (HalfSage style) ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;background:rgba(252,250,245,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,4vw,28px);height:72px;display:flex;align-items:center;gap:26px;}
.brand{display:flex;align-items:center;gap:11px;cursor:pointer;}
.brand img{width:38px;height:38px;transition:transform .4s var(--ease);}
.brand:hover img{transform:scale(1.05);}
.brand .bw{font-family:var(--display);font-weight:700;font-size:21px;letter-spacing:-.02em;color:var(--ink);}
.brand .bw em{color:var(--magenta);font-style:normal;}
.nav-links{display:flex;align-items:center;gap:2px;margin-left:6px;}
.nav-links a.lnk{font-family:var(--sans);font-weight:600;font-size:15px;color:var(--ink-2);padding:9px 13px;border-radius:9px;transition:background .2s,color .2s;}
.nav-links a.lnk:hover{background:#f0ece0;}
.nav-links a.lnk.active{color:var(--magenta);background:var(--soft-rose);}
.nav-spacer{flex:1;}
.nav-cta{margin-left:2px;}
.nav-burger{display:none;margin-left:auto;width:44px;height:44px;border-radius:11px;border:0;background:#f0ece0;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;}
.nav-burger span{width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease);}
.mobile-menu{position:fixed;inset:0;z-index:79;background:var(--cream);display:flex;flex-direction:column;justify-content:center;gap:4px;padding:0 32px;transform:translateY(-100%);transition:transform .5s var(--ease);}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu a{font-family:var(--display);font-weight:700;font-size:32px;letter-spacing:-.02em;padding:13px 0;border-bottom:1px solid var(--line);}
.mobile-menu .mm-cta{margin-top:22px;border-bottom:0;}
@media(max-width:880px){.nav-links,.nav-cta{display:none;}.nav-burger{display:flex;}}

/* ---------- cards / boxes ---------- */
.card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:26px;transition:transform .22s var(--ease),box-shadow .22s var(--ease),border-color .22s;}
.card:hover{transform:translateY(-6px);box-shadow:0 24px 44px -24px rgba(36,29,43,.4);border-color:#ddd6c6;}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
@media(max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}}

/* dotted texture + colored tile helpers */
.dotted{position:relative;}
.dotted::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.22) 1.8px,transparent 1.8px);background-size:18px 18px;pointer-events:none;}

/* status / category pill */
.pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;padding:5px 10px;border-radius:999px;font-weight:500;}
.chip{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:12px;letter-spacing:.02em;text-transform:uppercase;color:var(--ink-2);background:#f0ece0;border-radius:999px;padding:8px 14px;font-weight:500;}

/* floating accent shapes */
.fshape{position:absolute;z-index:0;border-radius:22px;}
.fshape.circle{border-radius:999px;}

/* eyebrow row */
.eyebrow-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:32px;}

/* soft tinted band */
.band{border-radius:26px;padding:clamp(34px,5vw,52px);position:relative;overflow:hidden;}
.band-rose{background:linear-gradient(120deg,var(--soft-gold),var(--soft-rose));border:1px solid #f2e4cf;}
.band-violet{background:linear-gradient(120deg,var(--soft-violet),var(--soft-blue));border:1px solid #e4ddf6;}

/* ---------- footer (light) ---------- */
.foot{margin-top:0;border-top:1px solid var(--line);background:var(--cream-2);}
.foot-inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,7vw,64px) clamp(20px,4vw,28px) 30px;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:36px;}
@media(max-width:860px){.foot-inner{grid-template-columns:1fr 1fr;gap:30px;}}
@media(max-width:520px){.foot-inner{grid-template-columns:1fr;}}
.foot .f-blurb{font-size:14px;color:var(--ink-70);line-height:1.6;max-width:30ch;margin-top:14px;}
.foot h5{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-50);margin-bottom:14px;}
.foot a.f-lnk{display:block;color:var(--ink-2);font-size:14.5px;padding:5px 0;transition:color .2s,transform .2s var(--ease);}
.foot a.f-lnk:hover{color:var(--magenta);transform:translateX(4px);}
.foot-bottom{border-top:1px solid var(--line);}
.foot-bottom-inner{max-width:var(--maxw);margin:0 auto;padding:22px clamp(20px,4vw,28px);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-50);}
.foot-legal{display:flex;gap:18px;}
.foot-legal a{color:var(--ink-50);transition:color .2s;}
.foot-legal a:hover{color:var(--magenta);}

/* ---------- social icons ---------- */
.social{display:flex;gap:10px;margin-top:16px;}
.social a{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:#fff;border:1px solid var(--line);color:var(--magenta);transition:transform .22s var(--ease),background .25s,color .2s,border-color .2s,box-shadow .25s;}
.social a:hover{color:#fff;border-color:var(--magenta);background:var(--magenta);transform:translateY(-3px);box-shadow:0 10px 20px -8px rgba(232,65,138,.5);}
.social svg{width:17px;height:17px;}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--cream-2);overflow:hidden;}
.marquee-track{display:flex;width:max-content;padding:15px 0;animation:sw-marquee 34s linear infinite;font-family:var(--mono);font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-50);}
.marquee-track span{display:inline-flex;align-items:center;gap:34px;padding-right:34px;}

/* ---------- reveal: motion never drops content below readable opacity ---------- */
.reveal{opacity:1;transform:none;}
html.is-anim .reveal{opacity:.4;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
html.is-anim .reveal.in{opacity:1;transform:none;}
.lotus-float{animation:sw-breathe 7s ease-in-out infinite;transform-origin:center;}
@media(prefers-reduced-motion:reduce){
  html.is-anim .reveal,html.is-anim .reveal.in{opacity:1;transform:none;transition:none;}
  .spectrum,.lotus-float,.marquee-track,.kicker .dot,.fshape{animation:none;}
}

/* ---------- misc ---------- */
.divider{height:1px;background:var(--line);border:0;}
.stat b{font-family:var(--display);font-weight:700;font-size:28px;display:block;line-height:1;letter-spacing:-.02em;}
.stat span{font-size:13.5px;color:var(--ink-70);margin-top:4px;display:block;}

/* ---------- colorway lotus mark (per-product) ---------- */
.lmark{display:block;width:96px;height:96px;filter:drop-shadow(0 8px 14px rgba(120,60,90,.18));}
/* ---------- product logo badge (uploaded app-icon marks) ---------- */
.plogo{display:flex;align-items:center;justify-content:center;border-radius:24%;position:relative;box-shadow:0 4px 10px -3px rgba(20,14,30,.32);}
.plogo img{display:block;width:100%;height:100%;object-fit:contain;border-radius:inherit;}
.plogo em{font-family:var(--mono);font-style:normal;font-weight:700;color:#fff;letter-spacing:-.02em;line-height:1;}

/* ---------- back link ---------- */
.back{display:inline-flex;align-items:center;gap:7px;font-family:var(--sans);font-weight:600;font-size:14px;color:var(--ink-70);transition:color .2s,transform .2s var(--ease);}
.back:hover{color:var(--magenta);transform:translateX(-3px);}

/* ---------- blog ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr;}}
.post{padding:0;overflow:hidden;cursor:pointer;display:flex;flex-direction:column;}
.post .phead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 18px;border-bottom:1px solid var(--line-2);}
.post .ptag{font-family:var(--mono);font-size:10.5px;letter-spacing:.05em;text-transform:uppercase;font-weight:500;padding:5px 11px;border-radius:999px;white-space:nowrap;}
.post .pdate{font-family:var(--mono);font-size:11px;letter-spacing:.03em;text-transform:uppercase;color:var(--ink-50);white-space:nowrap;}
.post .pin{padding:20px;display:flex;flex-direction:column;flex:1;}
.post h3{font-size:20px;line-height:1.2;letter-spacing:-.02em;margin:0;}
.post p{font-size:14.5px;color:var(--ink-70);line-height:1.55;margin:10px 0 0;}
.post .more{margin-top:auto;padding-top:18px;font-weight:700;font-size:14px;color:var(--magenta);display:inline-flex;align-items:center;gap:6px;}
.post .more .arr{transition:transform .25s var(--ease);}
.post:hover .more .arr{transform:translateX(4px);}
.feature-post{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden;cursor:pointer;}
@media(max-width:760px){.feature-post{grid-template-columns:1fr;}}
.feature-post .fhero{min-height:300px;position:relative;display:grid;place-items:center;}
.feature-post .fbody{padding:clamp(28px,4vw,44px);display:flex;flex-direction:column;justify-content:center;}
.feature-post .fbody h2{font-size:clamp(24px,3vw,34px);letter-spacing:-.025em;line-height:1.1;margin:12px 0 0;}
.feature-post .fbody p{font-size:16px;color:var(--ink-70);line-height:1.6;margin:14px 0 0;max-width:48ch;}

/* ---------- article / prose ---------- */
.article{max-width:760px;margin:0 auto;}
.article .ahero{height:280px;border-radius:20px;position:relative;display:grid;place-items:center;overflow:hidden;margin:22px 0 30px;}
.article h1{font-size:clamp(32px,4.4vw,46px);line-height:1.08;letter-spacing:-.03em;margin:12px 0 0;}
.prose p{font-size:17px;line-height:1.75;color:var(--ink-2);margin:0 0 20px;}
.prose .lead{font-size:20px;font-weight:600;color:var(--ink);line-height:1.5;margin-bottom:22px;}
.prose h2{font-size:26px;letter-spacing:-.02em;margin:34px 0 12px;}
.prose h3{font-size:20px;letter-spacing:-.02em;margin:26px 0 8px;}
.prose ul{margin:0 0 20px;padding-left:20px;}
.prose li{font-size:16.5px;line-height:1.7;color:var(--ink-2);margin-bottom:8px;}
.prose a{color:var(--magenta);font-weight:600;}
.author{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;margin:30px 0;}
.author .av{width:46px;height:46px;border-radius:999px;background:linear-gradient(135deg,var(--magenta),var(--violet));display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:18px;color:#fff;}
.author .nm{font-weight:700;font-size:14.5px;}
.author .ro{font-size:13px;color:var(--ink-70);}

/* legal page meta */
.legal-meta{font-family:var(--mono);font-size:12px;color:var(--ink-50);margin-top:14px;}
.legal-note{background:var(--soft-gold);border:1px solid #f2e4cf;border-radius:14px;padding:16px 18px;font-size:14px;color:var(--ink-2);margin:0 0 28px;}
.toc{background:var(--cream-2);border:1px solid var(--line);border-radius:16px;padding:20px 22px;margin-bottom:30px;}
.toc h4{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-50);margin-bottom:12px;}
.toc a{display:block;font-size:14.5px;color:var(--ink-2);padding:5px 0;}
.toc a:hover{color:var(--magenta);}
/* legal pages: fill the standard wrap so gutters match every other page; TOC becomes a right sidebar */
.legal .toc{float:right;width:252px;margin:0 0 22px 44px;position:sticky;top:104px;}
.legal .prose{max-width:74ch;}
@media(max-width:820px){.legal .toc{float:none;width:auto;margin:0 0 26px;position:static;}}

/* ---------- product detail ---------- */
.pd-hero{display:grid;grid-template-columns:1fr 380px;gap:clamp(28px,4vw,44px);align-items:center;}
@media(max-width:860px){.pd-hero{grid-template-columns:1fr;}.pd-art{order:-1;max-width:340px;}}
.pd-art .pd-card{background:#fff;border:1px solid var(--line);border-radius:26px;padding:30px;box-shadow:0 30px 60px -34px rgba(155,93,229,.45);}
.pd-art .pd-tile{height:260px;border-radius:18px;display:grid;place-items:center;position:relative;overflow:hidden;}
.pd-art .pd-tile .plogo{width:104px;height:104px;}
.pd-art .pd-tile .plogo em{font-size:44px;}
.pd-cols{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;align-items:start;}
@media(max-width:860px){.pd-cols{grid-template-columns:1fr;}}
.pd-feat{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--line-2);}
.pd-feat:last-child{border-bottom:0;}
.pd-feat .ck{width:22px;height:22px;border-radius:7px;flex:none;display:grid;place-items:center;background:var(--soft-violet);}
.pd-feat span{font-size:15.5px;color:var(--ink-2);}
.pd-side .sbox{padding:22px;margin-bottom:14px;}
.pd-side .row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:14px;}
.pd-side .row span:first-child{color:var(--ink-70);}
.pd-side .row span:last-child{font-weight:600;}
.works{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px;}
