/* ============================================================
   THE FLOWER ROOM — theflowerroom.co.za
   Khula Information Systems cc · Night Garden design system
   ============================================================ */
:root{
  --soil:#0A0F0D;
  --soil-2:#0E1512;
  --moss:#16211C;
  --petal:#E77FB3;
  --pollen:#E5C078;
  --leaf:#6ECF97;
  --mist:#E9EFE9;
  --mist-dim:#9AABA0;
  --line:rgba(110,207,151,.14);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--soil);color:var(--mist);font-family:'Sora',sans-serif;font-weight:300;line-height:1.6;overflow-x:hidden}
::selection{background:var(--petal);color:var(--soil)}
a{color:inherit;text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--leaf);outline-offset:3px;border-radius:2px}
img{max-width:100%;display:block}
.mono{font-family:'JetBrains Mono',monospace}

/* ---------- nav ---------- */
nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:20px 5vw;background:linear-gradient(180deg,rgba(10,15,13,.88),rgba(10,15,13,0));backdrop-filter:blur(6px)}
.logo{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-size:1.15rem;letter-spacing:.02em}
.logo svg{width:26px;height:26px}
.nav-links{display:flex;gap:32px;font-family:'JetBrains Mono',monospace;font-size:.75rem;letter-spacing:.08em;color:var(--mist-dim)}
.nav-links a{transition:color .25s;padding:4px 0}
.nav-links a:hover,.nav-links a[aria-current="page"]{color:var(--leaf)}
.nav-cta{font-family:'JetBrains Mono',monospace;font-size:.75rem;letter-spacing:.08em;color:var(--soil);
  background:var(--leaf);padding:9px 18px;border-radius:999px;transition:background .25s}
.nav-cta:hover{background:var(--pollen)}
.nav-burger{display:none;background:none;border:1px solid var(--line);color:var(--mist);border-radius:6px;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.1em;padding:9px 14px;cursor:pointer}
@media(max-width:820px){
  .nav-links{display:none}
  .nav-burger{display:block}
  .nav-links.open{display:flex;position:fixed;inset:64px 0 auto 0;flex-direction:column;gap:0;background:var(--soil-2);
    border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 5vw;z-index:49}
  .nav-links.open a{padding:14px 0;border-bottom:1px solid var(--line);font-size:.85rem}
  .nav-links.open a:last-child{border-bottom:none}
}

/* ---------- hero (home) ---------- */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;padding:120px 5vw 80px}
#bloom-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.hero-inner{position:relative;z-index:1;max-width:960px}
.seedline{font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--leaf);margin-bottom:28px;min-height:1.2em}
.seedline .cursor{display:inline-block;width:8px;height:1em;background:var(--leaf);vertical-align:text-bottom;animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
h1{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(2.8rem,7.5vw,6.2rem);line-height:1.04;letter-spacing:-.01em}
h1 em{font-style:italic;font-weight:400;color:var(--petal)}
.hero-sub{margin-top:28px;max-width:520px;color:var(--mist-dim);font-size:1.05rem}
.hero-ctas{margin-top:44px;display:flex;gap:16px;flex-wrap:wrap}
.btn{display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.8rem;letter-spacing:.08em;padding:14px 28px;border-radius:999px;transition:all .25s;border:none;cursor:pointer}
.btn-fill{background:var(--petal);color:var(--soil)}
.btn-fill:hover{background:var(--pollen);transform:translateY(-2px)}
.btn-line{border:1px solid var(--line);color:var(--mist);background:transparent}
.btn-line:hover{border-color:var(--leaf);color:var(--leaf)}
.hero-foot{position:absolute;bottom:28px;left:5vw;right:5vw;display:flex;justify-content:space-between;z-index:1;
  font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.1em;color:var(--mist-dim)}
@media(max-width:600px){.hero-foot span:nth-child(2){display:none}}

/* ---------- page header (inner pages) ---------- */
.page-head{padding:170px 5vw 70px;border-bottom:1px solid var(--line);position:relative}
.page-head h1{font-size:clamp(2.4rem,6vw,4.6rem)}
.page-head .hero-sub{max-width:600px}

/* ---------- sections ---------- */
section{padding:110px 5vw;position:relative}
.eyebrow{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.18em;color:var(--leaf);text-transform:uppercase;margin-bottom:18px}
.sec-title{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(1.9rem,4vw,3.2rem);line-height:1.12;max-width:700px}
.sec-title em{font-style:italic;color:var(--pollen)}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.bordered{border-top:1px solid var(--line)}

/* ---------- services ---------- */
.svc-grid{margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:900px){.svc-grid{grid-template-columns:1fr}}
.svc{background:var(--soil-2);padding:44px 36px 40px;position:relative;overflow:hidden;transition:background .35s}
.svc:hover{background:var(--moss)}
.svc .stem{position:absolute;left:36px;bottom:0;width:60px;height:110px;opacity:.5;transition:opacity .4s}
.svc:hover .stem{opacity:1}
.svc .stem path{stroke-dasharray:300;stroke-dashoffset:300;transition:stroke-dashoffset 1.1s ease}
.svc:hover .stem path{stroke-dashoffset:0}
.svc-num{font-family:'JetBrains Mono',monospace;font-size:.7rem;color:var(--mist-dim);letter-spacing:.15em}
.svc h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.55rem;margin:14px 0 12px}
.svc p{color:var(--mist-dim);font-size:.93rem;max-width:32ch;margin-bottom:110px}
.svc .tag{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--leaf);letter-spacing:.1em}

/* services page: deep sections */
.svc-deep{display:grid;grid-template-columns:1fr 1fr;gap:60px;padding:80px 0;border-bottom:1px solid var(--line);align-items:start}
.svc-deep:last-of-type{border-bottom:none}
@media(max-width:860px){.svc-deep{grid-template-columns:1fr;gap:28px}}
.svc-deep h3{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(1.7rem,3.4vw,2.6rem);line-height:1.15}
.svc-deep h3 em{font-style:italic;color:var(--petal)}
.svc-deep .lede{color:var(--mist-dim);margin-top:16px;max-width:46ch}
.svc-deep ul{list-style:none;margin-top:8px}
.svc-deep li{padding:16px 0;border-bottom:1px dashed var(--line);color:var(--mist-dim);font-size:.95rem}
.svc-deep li b{color:var(--mist);font-weight:500;display:block;margin-bottom:2px}
.svc-deep .stack{margin-top:22px;font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.1em;color:var(--leaf)}

/* ---------- process ---------- */
.stages{margin-top:70px;display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
@media(max-width:900px){.stages{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.stages{grid-template-columns:1fr}}
.stage{position:relative;padding-top:26px;border-top:1px solid var(--line)}
.stage::before{content:"";position:absolute;top:-4px;left:0;width:7px;height:7px;border-radius:50%;background:var(--petal)}
.stage:nth-child(2)::before{background:var(--pollen)}
.stage:nth-child(3)::before{background:var(--leaf)}
.stage:nth-child(4)::before{background:var(--mist)}
.stage .mono{font-size:.68rem;color:var(--mist-dim);letter-spacing:.15em}
.stage h4{font-family:'Fraunces',serif;font-weight:400;font-size:1.35rem;margin:10px 0 8px}
.stage p{color:var(--mist-dim);font-size:.9rem}

/* ---------- work ---------- */
.cases{margin-top:64px;display:grid;grid-template-columns:1fr 1fr;gap:28px}
@media(max-width:820px){.cases{grid-template-columns:1fr}}
.case{position:relative;border:1px solid var(--line);border-radius:6px;padding:38px 34px;min-height:250px;
  display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;transition:border-color .3s,transform .3s;background:var(--soil-2)}
.case:hover{border-color:var(--pollen);transform:translateY(-4px)}
.case::after{content:"→";position:absolute;top:26px;right:30px;font-size:1.3rem;color:var(--pollen);opacity:0;transition:opacity .3s}
.case:hover::after{opacity:1}
.case .mono{font-size:.68rem;color:var(--leaf);letter-spacing:.12em;margin-bottom:10px}
.case h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.5rem;margin-bottom:8px}
.case p{color:var(--mist-dim);font-size:.9rem;max-width:44ch}
.case .result{margin-top:16px;font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--pollen);letter-spacing:.1em}

/* ---------- khula band ---------- */
.khula{border-top:1px solid var(--line);background:var(--soil-2);text-align:center;padding:130px 5vw}
.khula .word{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(3rem,9vw,7rem);color:var(--leaf)}
.khula .def{font-family:'JetBrains Mono',monospace;font-size:.78rem;letter-spacing:.14em;color:var(--mist-dim);margin-top:18px}
.khula p{max-width:560px;margin:34px auto 0;color:var(--mist-dim)}

/* ---------- values (studio) ---------- */
.values{margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:860px){.values{grid-template-columns:1fr}}
.value{background:var(--soil-2);padding:40px 34px}
.value h4{font-family:'Fraunces',serif;font-weight:400;font-size:1.3rem;margin-bottom:10px}
.value h4::before{content:"✳ ";color:var(--petal)}
.value p{color:var(--mist-dim);font-size:.92rem}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:70px;margin-top:60px}
@media(max-width:860px){.contact-grid{grid-template-columns:1fr}}
.field{margin-bottom:26px}
.field label{display:block;font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.14em;color:var(--leaf);margin-bottom:10px;text-transform:uppercase}
.field input,.field select,.field textarea{width:100%;background:var(--soil-2);border:1px solid var(--line);border-radius:6px;
  color:var(--mist);font-family:'Sora',sans-serif;font-weight:300;font-size:.95rem;padding:14px 16px;transition:border-color .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--leaf)}
.field textarea{min-height:140px;resize:vertical}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.form-note{font-size:.8rem;color:var(--mist-dim);margin-top:14px}
.contact-aside .block{border:1px solid var(--line);border-radius:6px;padding:30px;margin-bottom:22px;background:var(--soil-2)}
.contact-aside .block h4{font-family:'Fraunces',serif;font-weight:400;font-size:1.2rem;margin-bottom:8px}
.contact-aside .block p,.contact-aside .block a{color:var(--mist-dim);font-size:.92rem}
.contact-aside .block a:hover{color:var(--leaf)}
.form-status{display:none;margin-top:18px;padding:14px 18px;border-radius:6px;font-size:.9rem}
.form-status.ok{display:block;border:1px solid var(--leaf);color:var(--leaf)}
.form-status.err{display:block;border:1px solid var(--petal);color:var(--petal)}

/* ---------- cta + footer ---------- */
.cta{text-align:center;padding:140px 5vw;border-top:1px solid var(--line)}
.cta h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(2.2rem,5.5vw,4.2rem);line-height:1.1}
.cta h2 em{font-style:italic;color:var(--petal)}
.cta .btn{margin-top:44px}
footer{border-top:1px solid var(--line);padding:44px 5vw;display:flex;justify-content:space-between;flex-wrap:wrap;gap:18px;
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.1em;color:var(--mist-dim)}

/* ---------- zen hero (home) ---------- */
.hero-zen{align-items:center;text-align:center}
.hero-zen .hero-inner{max-width:840px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.hero-zen .seed-glow{position:absolute;top:18%;left:50%;transform:translateX(-50%);width:420px;height:420px;
  background:radial-gradient(circle,rgba(229,192,120,.28) 0%,rgba(229,192,120,.08) 35%,transparent 70%);pointer-events:none;z-index:0}
.hero-zen h1{font-size:clamp(2.2rem,5vw,3.9rem);font-weight:200;margin-top:34vh}
.hero-zen .hero-sub{max-width:none;margin-top:20px}
.hero-zen .btn-petal{border:1px solid var(--petal);color:var(--petal);background:transparent}
.hero-zen .btn-petal:hover{background:var(--petal);color:var(--soil)}
.hero-zen .eyebrow{margin-bottom:0}

/* ---------- bento (home) ---------- */
.bento{margin-top:64px;display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media(max-width:900px){.bento{grid-template-columns:1fr}}
.b-cell{background:var(--soil-2);border:1px solid #182018;border-radius:14px;padding:40px 36px;position:relative;
  transition:border-color .3s,transform .3s;display:block}
a.b-cell:hover{border-color:var(--line);transform:translateY(-4px)}
.b-statement{grid-column:span 2;display:flex;flex-direction:column;justify-content:center}
@media(max-width:900px){.b-statement{grid-column:auto}}
.b-statement h2{font-family:'Fraunces',serif;font-weight:200;font-size:clamp(2rem,4.5vw,3.4rem);line-height:1.08}
.b-statement h2 em{font-style:italic;color:var(--petal)}
.b-statement p{color:var(--mist-dim);margin-top:16px;max-width:44ch}
.b-statement .btn{margin-top:30px;align-self:flex-start;background:var(--mist);color:var(--soil)}
.b-statement .btn:hover{background:var(--pollen)}
.b-accent{background:var(--petal);border-color:var(--petal);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px}
.b-accent svg{width:56%;max-width:220px}
.b-accent .mono{color:var(--soil);font-size:.72rem;letter-spacing:.2em}
.b-svc .svc-num{display:block;margin-bottom:16px}
.b-svc h3{font-family:'Fraunces',serif;font-weight:400;font-size:1.5rem;margin-bottom:10px}
.b-svc p{color:var(--mist-dim);font-size:.92rem;max-width:30ch}
.b-svc .arrow{display:inline-block;margin-top:24px;font-size:1.15rem;transition:transform .3s}
a.b-cell:hover .arrow{transform:translateX(6px)}
.b-strip{grid-column:1/-1;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding:28px 36px}
.b-strip p{color:var(--mist-dim)}
.b-strip a{font-family:'JetBrains Mono',monospace;font-size:.8rem;letter-spacing:.08em;color:var(--mist);transition:color .25s}
.b-strip a:hover{color:var(--leaf)}

/* ---------- motion safety ---------- */
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
