/* === BroGrowz app styles === */
:root{
  --leaf-1:#7ed957;
  --leaf-2:#3aa84a;
  --leaf-3:#caff7a;
  --bg-0:#000;
  --bg-1:#050c06;
  --bg-2:#0a160c;
  --line:rgba(126,217,87,.22);
  --line-strong:rgba(167,255,90,.45);
  --ink:#eaffe2;
  --ink-mute:#9ec792;
  --ink-dim:#6f9265;
  --danger:#ff7676;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100vh;background:var(--bg-0);color:var(--ink);overflow-x:hidden;max-width:100vw}
body{
  font-family:'Rajdhani','Segoe UI',system-ui,sans-serif;
  background:
    radial-gradient(900px 700px at 50% -10%,rgba(126,217,87,.14),transparent 65%),
    radial-gradient(1100px 800px at 15% 110%,rgba(58,168,74,.10),transparent 60%),
    linear-gradient(180deg,#000 0%,#050c06 100%);
  background-attachment:fixed;
  min-height:100vh;
  display:flex;flex-direction:column;
}
a{color:var(--leaf-3);text-decoration:none}
a:hover{color:#fff}

/* --- Topbar --- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  padding:.8rem 1rem;border-bottom:1px solid var(--line);
  background:rgba(0,0,0,.55);backdrop-filter:blur(8px);
  position:sticky;top:0;z-index:50;
  flex-wrap:wrap;row-gap:.5rem;width:100%;max-width:100vw;
}
.brand{display:flex;align-items:center;gap:.5rem;font-family:'Black Ops One',Impact,sans-serif;
  font-size:1.1rem;letter-spacing:.06em;color:#fff;flex-shrink:0;min-width:0}
.brand img{width:30px;height:30px;border-radius:8px;object-fit:cover;flex-shrink:0}
.brand .accent{color:var(--leaf-3)}
.topbar nav{display:flex;align-items:center;gap:.7rem;font-family:'Black Ops One',Impact,sans-serif;
  font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;flex-wrap:wrap;justify-content:flex-end;min-width:0}
.who{color:var(--ink-mute);font-family:'Rajdhani';font-size:.92rem;letter-spacing:.04em;text-transform:none;
  max-width:22ch;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
@media (max-width:560px){
  .topbar{padding:.6rem .7rem}
  .brand{font-size:.95rem}
  .brand img{width:26px;height:26px}
  .topbar nav{gap:.5rem;font-size:.66rem;letter-spacing:.12em}
  .who{display:none}
  .btn-mini{padding:.3rem .55rem;font-size:.62rem;letter-spacing:.1em}
}
.linklike{background:none;border:0;color:inherit;cursor:pointer;font:inherit;letter-spacing:inherit;text-transform:inherit;padding:0}
.linklike:hover{color:#fff}

/* --- Layout --- */
.container{max-width:1100px;margin:0 auto;padding:2rem 1.4rem 4rem;flex:1;width:100%;min-width:0}
@media (max-width:560px){.container{padding:1.2rem .9rem 3rem}}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.page-title{margin:0;font-family:'Black Ops One',Impact,sans-serif;font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:.04em;text-transform:uppercase;
  background:linear-gradient(180deg,#fff,#caff7a 60%,#3aa84a);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-sub{color:var(--ink-mute);margin:0 0 1rem;max-width:64ch}
.section-title{font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.06em;color:var(--leaf-3);text-transform:uppercase;font-size:1rem;margin:2.2rem 0 .8rem}

/* --- Cards --- */
.card{background:rgba(8,18,10,.7);border:1px solid var(--line);border-radius:14px;padding:1.4rem;
  box-shadow:0 10px 30px rgba(0,0,0,.4)}
.card.narrow{max-width:440px;margin:3rem auto 0}
.details-card{padding:1rem 1.4rem}
.details-card summary{cursor:pointer;font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.06em;color:var(--leaf-3);text-transform:uppercase;font-size:.85rem}

/* --- Forms --- */
form.stack{display:flex;flex-direction:column;gap:1rem}
form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:560px){form .row{grid-template-columns:1fr}}
label{display:flex;flex-direction:column;gap:.35rem;color:var(--ink-mute);font-size:.92rem;letter-spacing:.04em}
.hint{color:var(--ink-dim);font-size:.85rem;font-weight:400}
input[type=text],input[type=email],input[type=password],input[type=date],input[type=file],select,textarea{
  background:rgba(0,0,0,.5);border:1px solid var(--line);color:var(--ink);
  padding:.7rem .9rem;border-radius:10px;font:inherit;width:100%;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--line-strong);box-shadow:0 0 0 3px rgba(167,255,90,.15)}
textarea{resize:vertical}
.actions{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:.5rem}

/* --- Buttons --- */
.btn{display:inline-flex;align-items:center;gap:.5rem;
  padding:.7rem 1.2rem;border-radius:999px;border:1px solid transparent;cursor:pointer;
  font:inherit;font-family:'Black Ops One',Impact,sans-serif;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;
  text-decoration:none;transition:transform .15s ease,filter .15s ease}
.btn:hover{transform:translateY(-1px);filter:brightness(1.1)}
.btn.primary{background:linear-gradient(135deg,#caff7a,#7ed957 55%,#3aa84a);color:#0a1a05;
  box-shadow:0 8px 24px rgba(126,217,87,.3),0 0 30px rgba(167,255,90,.15)}
.btn.ghost{background:transparent;border-color:var(--line-strong);color:var(--leaf-3)}
.btn.ghost:hover{background:rgba(167,255,90,.08);color:#fff}
.btn-mini{padding:.4rem .8rem;border:1px solid var(--line-strong);border-radius:999px;color:var(--leaf-3);
  font-size:.7rem;letter-spacing:.14em}
.btn-mini:hover{background:rgba(167,255,90,.1)}

/* --- Tags / meta --- */
.meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.4rem}
.tag{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:99px;
  background:rgba(126,217,87,.12);border:1px solid var(--line);color:var(--leaf-3);
  font-size:.78rem;letter-spacing:.06em;text-transform:lowercase}
.tag.muted{color:var(--ink-mute);background:rgba(255,255,255,.04)}
.tag.stage{background:linear-gradient(135deg,rgba(202,255,122,.25),rgba(58,168,74,.15));color:#fff}
.muted{color:var(--ink-mute)}.center{text-align:center}

/* --- Flash --- */
.flash-wrap{max-width:1100px;margin:1rem auto 0;padding:0 1.4rem;display:flex;flex-direction:column;gap:.4rem;width:100%}
@media (max-width:560px){.flash-wrap{padding:0 .9rem}}
.flash{padding:.7rem 1rem;border-radius:10px;border:1px solid var(--line);background:rgba(0,0,0,.5)}
.flash-error{border-color:rgba(255,118,118,.5);color:#ffb8b8}

/* --- Empty state --- */
.empty{text-align:center;padding:3rem 1rem;border:1px dashed var(--line);border-radius:14px;color:var(--ink-mute)}
.empty p{margin:0 0 .6rem}

/* --- Plants grid --- */
.grid.plants{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.plant-card{display:flex;flex-direction:column;gap:.5rem;color:inherit}
.plant-card:hover{border-color:var(--line-strong);transform:translateY(-2px);box-shadow:0 14px 40px rgba(126,217,87,.18)}
.plant-name{margin:0;font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.04em;font-size:1.25rem;color:#fff;text-transform:uppercase}
.stats{display:flex;gap:1rem;color:var(--ink-dim);font-size:.85rem;margin-top:auto;letter-spacing:.04em}

/* --- Plant detail KV --- */
.kv{display:grid;grid-template-columns:auto 1fr;gap:.4rem 1.2rem;margin:.6rem 0 0}
.kv dt{color:var(--ink-mute);font-family:'Black Ops One',Impact,sans-serif;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.kv dd{margin:0;color:var(--ink)}

/* --- Timeline --- */
.timeline{display:flex;flex-direction:column;gap:1rem}
.entry-card{display:flex;gap:1rem;padding:.9rem;background:rgba(8,18,10,.7);border:1px solid var(--line);border-radius:14px;color:inherit}
.entry-card:hover{border-color:var(--line-strong);transform:translateY(-1px)}
.thumb{width:120px;height:120px;object-fit:cover;border-radius:10px;flex:0 0 120px}
.entry-body{display:flex;flex-direction:column;gap:.3rem;min-width:0}
.when{color:var(--ink-mute);font-size:.85rem;letter-spacing:.05em}
.status{font-family:'Black Ops One',Impact,sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase}
.status-pending{color:#ffd66a}.status-error{color:#ffb8b8}.status-done{color:var(--leaf-3)}
.note{font-style:italic;color:var(--ink-mute)}
.obs-preview{margin:.2rem 0 0;color:var(--ink);opacity:.85}

/* --- Entry detail --- */
.entry-grid{display:grid;grid-template-columns:minmax(300px,1fr) 1.4fr;gap:1.4rem;align-items:flex-start}
@media (max-width:780px){.entry-grid{grid-template-columns:1fr}}
.big-photo{width:100%;border-radius:14px;display:block;border:1px solid var(--line)}
.user-note{margin-top:1rem}
.user-note h3{margin:0 0 .3rem;font-family:'Black Ops One',Impact,sans-serif;font-size:.85rem;letter-spacing:.14em;color:var(--leaf-3);text-transform:uppercase}
.ai-card .ai-h, .comparison .ai-h{margin:0 0 .6rem;font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.04em;color:#fff;display:flex;align-items:center;gap:.5rem;text-transform:uppercase}
.ai-card .ai-h .rx{color:var(--leaf-3);font-family:serif;font-size:1.4em}
.ai-card h3,.comparison h3{margin:1.2rem 0 .4rem;font-family:'Black Ops One',Impact,sans-serif;font-size:.78rem;letter-spacing:.16em;color:var(--leaf-3);text-transform:uppercase}
.prose{line-height:1.55;color:var(--ink)}
.prose.advice{padding:.6rem .9rem;border-left:3px solid var(--leaf-2);background:rgba(58,168,74,.07);border-radius:0 8px 8px 0}
.error{color:#ffb8b8}
.pending{color:#ffd66a;display:flex;align-items:center;gap:.6rem}
.spinner{width:1rem;height:1rem;border:2px solid rgba(255,214,106,.3);border-top-color:#ffd66a;border-radius:50%;animation:spin .9s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}
#comparisons{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}

/* --- Calendar --- */
.cal-head{display:flex;align-items:center;gap:1rem;justify-content:center;margin-bottom:1rem}
.cal-head h2{margin:0;font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.06em;text-transform:uppercase}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.dn{font-family:'Black Ops One',Impact,sans-serif;font-size:.7rem;letter-spacing:.18em;color:var(--ink-mute);text-align:center;padding:.3rem 0;text-transform:uppercase}
.day{min-height:90px;padding:.4rem;border:1px solid var(--line);border-radius:10px;background:rgba(8,18,10,.55);position:relative}
.day.empty{background:transparent;border:1px dashed rgba(126,217,87,.1)}
.day-num{font-size:.85rem;color:var(--ink-mute)}
.day.has{border-color:var(--line-strong);box-shadow:inset 0 0 0 1px rgba(167,255,90,.1)}
.dots{display:flex;gap:3px;margin-top:.3rem;flex-wrap:wrap}
.dot-link img{width:28px;height:28px;border-radius:6px;object-fit:cover;display:block}
.more{align-self:center;color:var(--ink-mute);font-size:.75rem}

/* --- Footer --- */
.sitefoot{padding:1.6rem 1rem;text-align:center;border-top:1px solid var(--line);
  font-family:'Black Ops One',Impact,sans-serif;font-size:.7rem;letter-spacing:.24em;color:var(--ink-dim);text-transform:uppercase}
.sitefoot .credit{margin-top:.4rem;color:rgba(202,255,122,.4);letter-spacing:.32em}

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

/* ====================================================================
   Journal (cream notebook page-flip book) — used on plant view only
   ==================================================================== */
:root{
  --paper-1:#f5efdb;
  --paper-2:#ece2c3;
  --paper-shade:rgba(82,60,20,.10);
  --ink-deep:#1c2f1a;
  --ink-mid:#2d5a32;
  --ink-soft:#4d6b3f;
  --ink-faded:#7a8a6a;
  --rule:rgba(46,90,50,.10);
  --gold:#b88a3a;
}
.journal-head{margin-bottom:.4rem}
.journal-hint{
  color:var(--ink-mute);text-align:center;margin:.2rem 0 1rem;
  font-family:'Caveat',cursive;font-size:1.05rem;letter-spacing:.02em;
}
.book-frame{
  max-width:1180px;margin:0 auto;
  padding:1rem 0;
  perspective:2400px;
  width:100%;overflow:hidden;
}
#journal-book{
  margin:0 auto;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.45));
}
/* Page base — cream paper with faint horizontal ruled lines + leaf watermark */
.page{
  background:
    radial-gradient(800px 600px at 30% 0%,rgba(255,255,255,.55),transparent 60%),
    repeating-linear-gradient(to bottom,transparent 0,transparent 26px,var(--rule) 27px,var(--rule) 28px),
    linear-gradient(170deg,var(--paper-1) 0%,var(--paper-2) 100%);
  color:var(--ink-deep);
  font-family:'Lora',Georgia,serif;
  overflow:hidden;position:relative;
}
.page::before{
  /* page-edge speckle / age */
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(2px 2px at 10% 25%,rgba(82,60,20,.08),transparent 70%),
    radial-gradient(2px 2px at 78% 60%,rgba(82,60,20,.07),transparent 70%),
    radial-gradient(2px 2px at 35% 88%,rgba(82,60,20,.06),transparent 70%);
}
.page-content{
  position:relative;height:100%;padding:2.4rem 2.2rem 2rem;
  display:flex;flex-direction:column;gap:.85rem;
}
.page-num{
  position:absolute;bottom:.9rem;left:50%;transform:translateX(-50%);
  font-family:'Caveat',cursive;color:var(--ink-faded);font-size:1rem;letter-spacing:.04em;
}

/* Soft inner gutter shadow on inside edges (just visual depth) */
.page::after{
  content:"";position:absolute;top:0;bottom:0;width:24px;pointer-events:none;
  background:linear-gradient(to right,rgba(0,0,0,.18),transparent);
}
.--right.page::after{left:0}      /* page-flip applies these classes */
.--left.page::after{right:0;background:linear-gradient(to left,rgba(0,0,0,.18),transparent)}

/* --- Cover pages --- */
.page-cover{
  background:
    radial-gradient(900px 700px at 70% 30%,rgba(255,255,255,.18),transparent 60%),
    linear-gradient(160deg,#1f4a23 0%,#0c2410 100%);
  color:#f1ffd8;
  border-radius:0;
}
.page-cover::before, .page-cover::after{display:none}
.page-cover .cover-inner{
  height:100%;padding:3rem 2.4rem;text-align:center;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.8rem;
  position:relative;
}
.cover-watermark{
  position:absolute;inset:0;
  background:radial-gradient(closest-side,rgba(255,255,255,.06),transparent 70%);
  background-image:
    radial-gradient(closest-side,rgba(202,255,122,.07),transparent 70%),
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 64 64'><g fill='rgba(202,255,122,0.07)' stroke='rgba(202,255,122,0.10)' stroke-width='1'><path d='M32 60 C30 50 30 44 32 38 C34 44 34 50 32 60Z'/><path d='M32 38 C28 36 22 28 20 14 C26 18 30 26 32 36Z'/><path d='M32 38 C36 36 42 28 44 14 C38 18 34 26 32 36Z'/><path d='M32 36 C26 34 16 30 8 22 C14 30 22 36 30 38Z'/><path d='M32 36 C38 34 48 30 56 22 C50 30 42 36 34 38Z'/></g></svg>");
  background-size:auto, 80% 80%;
  background-repeat:no-repeat;background-position:center;
  opacity:.7;
}
.cover-stamp{
  font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.28em;text-transform:uppercase;
  color:var(--leaf-3);font-size:.72rem;
}
.cover-title{
  font-family:'Black Ops One',Impact,sans-serif;font-size:clamp(2rem,4.5vw,3.2rem);
  letter-spacing:.04em;margin:0;line-height:1.05;text-transform:uppercase;
  background:linear-gradient(180deg,#fff,#caff7a 60%,#3aa84a);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.cover-strain{font-family:'Caveat',cursive;font-size:2rem;color:#caff7a;margin-top:-.4rem}
.cover-divider{color:var(--leaf-3);font-size:1.4rem;opacity:.7;margin:.4rem 0}
.cover-meta{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;
  color:rgba(202,255,122,.6);font-family:'Black Ops One',Impact,sans-serif;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}

/* --- Section headings within pages --- */
.entry-h{
  margin:.4rem 0 .2rem;
  font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.12em;text-transform:uppercase;
  color:var(--ink-mid);font-size:.78rem;
  border-bottom:1px solid var(--rule);padding-bottom:.2rem;
}
.serif{font-family:'Lora',Georgia,serif;color:var(--ink-deep);line-height:1.55;font-size:.98rem}
.serif em{color:var(--ink-mid);font-style:italic}
.ink{color:var(--ink-mid);font-weight:600}
.hand{font-family:'Caveat',cursive;color:var(--ink-mid);font-size:1.25rem;line-height:1.35}

/* Plant details KV inside the journal */
.journal-kv{display:grid;grid-template-columns:auto 1fr;gap:.3rem 1rem;margin:0}
.journal-kv dt{
  font-family:'Black Ops One',Impact,sans-serif;font-size:.66rem;letter-spacing:.16em;
  color:var(--ink-soft);text-transform:uppercase;padding-top:.15rem;
}
.journal-kv dd{margin:0;color:var(--ink-deep);font-family:'Lora',serif}

/* --- Photo page (polaroid taped to the page) --- */
.page-photo .entry-date{
  font-family:'Caveat',cursive;font-size:2rem;color:var(--ink-mid);margin:0;line-height:1
}
.page-photo .entry-time{
  font-family:'Caveat',cursive;font-size:1.1rem;color:var(--ink-faded);margin:-.3rem 0 .6rem
}
.polaroid{
  align-self:center;
  background:#fff;padding:.7rem .7rem 1.2rem;
  box-shadow:0 6px 18px rgba(0,0,0,.18),0 2px 4px rgba(0,0,0,.12);
  transform:rotate(-1.2deg);
  position:relative;max-width:88%;
  margin:.4rem 0 .6rem;
}
.polaroid img{display:block;width:100%;height:auto;background:#222}
.tape{position:absolute;width:64px;height:18px;
  background:rgba(220,200,140,.55);box-shadow:0 1px 3px rgba(0,0,0,.15);
  border-left:1px dashed rgba(0,0,0,.05);border-right:1px dashed rgba(0,0,0,.05);
}
.tape-l{top:-9px;left:6px;transform:rotate(-8deg)}
.tape-r{top:-9px;right:6px;transform:rotate(7deg)}
.user-note-block{margin-top:.4rem}
.note-label{
  font-family:'Black Ops One',Impact,sans-serif;font-size:.66rem;letter-spacing:.18em;
  color:var(--ink-soft);text-transform:uppercase;margin-bottom:.15rem
}
.note-body{margin:0}

/* --- AI page (Dr. BroGrowz) --- */
.rx-head{display:flex;align-items:baseline;gap:.6rem;margin-bottom:.2rem}
.rx-mark{font-family:'Lora',serif;font-style:italic;font-size:1.8rem;color:var(--gold);line-height:1}
.rx-name{font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-deep);font-size:.85rem}
.serif.advice{
  background:rgba(58,168,74,.07);padding:.55rem .8rem;
  border-left:3px solid var(--ink-mid);border-radius:0 6px 6px 0;
}
.stage-stamp{
  margin-top:.6rem;align-self:flex-start;
  padding:.25rem .7rem;border:1px dashed var(--ink-soft);
  border-radius:4px;color:var(--ink-mid);font-family:'Caveat',cursive;font-size:1.05rem;
  transform:rotate(-1deg);
}
.pending{color:#9a7c00;display:flex;align-items:center;gap:.5rem}
.pending .spinner{
  width:1rem;height:1rem;border:2px solid rgba(154,124,0,.25);border-top-color:#9a7c00;
  border-radius:50%;animation:spin .9s linear infinite;display:inline-block;
}
.error{color:#a13a3a}

/* --- Comparison pages --- */
.page-compare{
  background:
    radial-gradient(800px 600px at 30% 0%,rgba(255,255,255,.55),transparent 60%),
    repeating-linear-gradient(to bottom,transparent 0,transparent 26px,var(--rule) 27px,var(--rule) 28px),
    linear-gradient(170deg,#eef5d8 0%,#dbe7ba 100%);
}
.compare-head{
  font-family:'Black Ops One',Impact,sans-serif;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-mid);font-size:.82rem;
  border-top:2px solid var(--ink-mid);border-bottom:2px solid var(--ink-mid);
  padding:.3rem 0;text-align:center;margin-bottom:.4rem;
}

.empty-prompt{margin-top:1rem;text-align:center}

/* --- Controls under the book --- */
.book-controls{
  display:flex;align-items:center;justify-content:center;gap:1.2rem;
  margin:1.4rem auto 0;flex-wrap:wrap;
}
.page-counter{
  color:var(--ink-mute);font-family:'Black Ops One',Impact,sans-serif;
  font-size:.78rem;letter-spacing:.2em;
}
#bk-cur,#bk-total{color:var(--leaf-3)}

/* On narrow viewports, the page-flip lib goes portrait/single-page automatically. */
@media (max-width:760px){
  .journal-hint{font-size:.95rem}
  .page-content{padding:1.6rem 1.4rem 1.4rem}
  .cover-title{font-size:2rem}
  .polaroid{max-width:96%}
}
