/* =========================================================================
   ClickMarketWise Guide  -  "Ledger Terminal" design language
   Shared component layer (Tailwind CDN handles the utility layer).
   Palette: oat paper + slate ink + emerald signal. Warning amber used
   only inside genuine risk/danger blocks. One brand accent: emerald.
   ========================================================================= */

:root {
  --paper:        #f4f3ee;
  --paper-2:      #ecebe3;
  --card:         #fbfaf6;
  --ink:          #13161a;
  --ink-soft:     #4a4f57;
  --accent:       #0a7c5a;   /* emerald, brand accent (on light)        */
  --accent-bright:#16a974;   /* emerald (on dark)                       */
  --warn:         #b23b2e;   /* clay, risk/danger semantics only        */
  --line:         rgba(19, 22, 26, 0.12);
  --line-soft:    rgba(19, 22, 26, 0.07);
}

/* ------------------------------------------------------------------ base */
html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

::selection { background: var(--accent); color: #fff; }

/* Keyboard focus: visible, branded, consistent everywhere */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: 3px;
}
:focus:not(:focus-visible) { outline: none; }

/* ---------------------------------------------------------- typography */
.font-display { font-family: "Bricolage Grotesque", system-ui, sans-serif; }
.font-mono    { font-family: "JetBrains Mono", ui-monospace, monospace; }

/* Mono eyebrow label - used sparingly (max ~1 per 3 sections) */
.kicker {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: 0.72rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--accent);
  font-weight: 600;
}
.kicker-muted { color: var(--ink-soft); }
.on-ink .kicker { color: var(--accent-bright); }

/* -------------------------------------------------------------- motifs */
/* Graph-paper grid: a ledger/charting texture, used as a subtle backdrop */
.ledger-grid {
  background-image:
    linear-gradient(to right,  var(--line-soft) 1px, transparent 1px),
    linear-gradient(to bottom, var(--line-soft) 1px, transparent 1px);
  background-size: 34px 34px;
}
.ledger-grid-ink {
  background-image:
    linear-gradient(to right,  rgba(255,255,255,0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 34px 34px;
}

/* Signature depth cue: a hard "stamp" shadow (the opposite of soft glass) */
.stamp        { box-shadow: 5px 5px 0 var(--ink); }
.stamp-accent { box-shadow: 5px 5px 0 var(--accent); }
.stamp-sm     { box-shadow: 3px 3px 0 var(--ink); }

/* ------------------------------------------------------------- panels */
.panel {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 0.75rem;          /* 12px - the single card radius      */
}
.panel-flat {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 0.75rem;
  transition: transform .25s cubic-bezier(.16,1,.3,1), box-shadow .25s, border-color .25s;
}
.panel-flat:hover {
  border-color: rgba(10,124,90,0.45);
  transform: translateY(-3px);
  box-shadow: 0 14px 34px -18px rgba(19,22,26,0.35);
}

/* A small "terminal window" header bar for key data panels */
.panel-head {
  display: flex; align-items: center; gap: .5rem;
  padding: .55rem .9rem;
  border-bottom: 1px solid var(--line);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: .66rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-soft);
}
.panel-head .dot { width: 7px; height: 7px; border-radius: 9999px; background: var(--accent); }

/* ------------------------------------------------------------ buttons */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .8rem 1.4rem;
  border-radius: 0.5rem;           /* 8px - the single control radius     */
  font-weight: 600; font-size: .95rem; line-height: 1;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s cubic-bezier(.16,1,.3,1), box-shadow .2s, background-color .2s, color .2s, border-color .2s;
  text-align: center;
}
.btn:active { transform: translateY(1px); }

.btn-primary { background: var(--ink); color: var(--paper); }
.btn-primary:hover { box-shadow: 4px 4px 0 var(--accent); transform: translate(-1px,-1px); }

.btn-accent { background: var(--accent); color: #fff; }
.btn-accent:hover { box-shadow: 4px 4px 0 var(--ink); transform: translate(-1px,-1px); }

.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); background: rgba(19,22,26,0.04); }

.on-ink .btn-ghost { color: var(--paper); border-color: rgba(255,255,255,0.22); }
.on-ink .btn-ghost:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.55); }

.btn-block { width: 100%; }

/* Inline text link with animated underline */
.link-u {
  color: var(--accent); font-weight: 600;
  background-image: linear-gradient(var(--accent), var(--accent));
  background-size: 0% 1.5px; background-repeat: no-repeat; background-position: 0 100%;
  transition: background-size .3s ease;
  padding-bottom: 1px;
}
.link-u:hover { background-size: 100% 1.5px; }

/* ---------------------------------------------------------- rating bar */
.rating { display: inline-flex; align-items: center; gap: .5rem; }
.rating .num {
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-weight: 700; font-size: .95rem; color: var(--ink);
}
.on-ink .rating .num { color: #fff; }
.rating .track { width: 56px; height: 6px; border-radius: 9999px; background: rgba(19,22,26,0.12); overflow: hidden; }
.on-ink .rating .track { background: rgba(255,255,255,0.16); }
.rating .fill { height: 100%; background: var(--accent); border-radius: 9999px; }
.on-ink .rating .fill { background: var(--accent-bright); }

/* --------------------------------------------------------------- chips */
.chip {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: .64rem; letter-spacing: .14em; text-transform: uppercase;
  padding: .3rem .6rem; border-radius: 0.4rem;
  border: 1px solid var(--line); color: var(--ink-soft);
}
.chip-accent { color: var(--accent); border-color: rgba(10,124,90,0.35); background: rgba(10,124,90,0.06); }
.chip-warn   { color: var(--warn);   border-color: rgba(178,59,46,0.35); background: rgba(178,59,46,0.06); }

/* ------------------------------------------------------- prose (articles/legal) */
.prose-ledger { color: var(--ink-soft); font-size: 1.06rem; line-height: 1.75; }
.prose-ledger > p { margin: 0 0 1.4rem; }
.prose-ledger h2 {
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  color: var(--ink); font-weight: 700; font-size: 1.7rem; line-height: 1.15;
  margin: 2.6rem 0 1rem; letter-spacing: -0.01em;
}
.prose-ledger h3 {
  font-family: "Bricolage Grotesque", system-ui, sans-serif;
  color: var(--ink); font-weight: 700; font-size: 1.32rem; line-height: 1.2;
  margin: 2.2rem 0 .8rem;
  padding-left: .9rem; border-left: 3px solid var(--accent);
}
.prose-ledger h4 { color: var(--ink); font-weight: 700; font-size: 1.05rem; margin: 1.6rem 0 .6rem; }
.prose-ledger a { color: var(--accent); font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }
.prose-ledger strong { color: var(--ink); font-weight: 700; }
.prose-ledger ul { margin: 0 0 1.4rem; padding-left: 0; list-style: none; }
.prose-ledger ul > li {
  position: relative; padding-left: 1.6rem; margin-bottom: .65rem;
}
.prose-ledger ul > li::before {
  content: ""; position: absolute; left: .2rem; top: .65rem;
  width: 7px; height: 7px; background: var(--accent); border-radius: 2px;
}
.prose-ledger ol { margin: 0 0 1.4rem 1.2rem; }
.prose-ledger ol > li { margin-bottom: .55rem; padding-left: .3rem; }
.prose-ledger blockquote {
  margin: 1.8rem 0; padding: 1.1rem 1.4rem;
  background: rgba(10,124,90,0.05); border-left: 4px solid var(--accent);
  border-radius: 0 .5rem .5rem 0; color: var(--ink); font-style: italic;
}

/* ------------------------------------------------------------- flags */
.flag {
  filter: grayscale(0.7) contrast(1.05);
  transition: filter .45s cubic-bezier(.4,0,.2,1), transform .45s cubic-bezier(.4,0,.2,1);
}
.group:hover .flag, .flag:hover { filter: grayscale(0) contrast(1); transform: translateY(-2px) scale(1.06); }

/* --------------------------------------------------------------- forms */
.label {
  display: block; font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: .64rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-soft); margin-bottom: .5rem; font-weight: 600;
}
.input, .textarea, select.input {
  width: 100%; background: #fff; border: 1px solid var(--line);
  border-radius: 0.5rem; padding: .8rem 1rem; color: var(--ink);
  font-family: inherit; font-size: .95rem; transition: border-color .2s, box-shadow .2s;
}
.input::placeholder, .textarea::placeholder { color: rgba(19,22,26,0.4); }
.input:focus, .textarea:focus, select.input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(10,124,90,0.14);
}
.field-error { border-color: var(--warn) !important; box-shadow: 0 0 0 3px rgba(178,59,46,0.12) !important; }

/* --------------------------------------------------- scroll reveal */
.reveal { opacity: 0; transform: translateY(18px); }
.reveal.is-in {
  opacity: 1; transform: none;
  transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1);
}
/* hero load stagger */
.rise { opacity: 0; animation: rise .8s cubic-bezier(.16,1,.3,1) forwards; }
.rise-1 { animation-delay: .05s; }
.rise-2 { animation-delay: .15s; }
.rise-3 { animation-delay: .25s; }
.rise-4 { animation-delay: .35s; }
@keyframes rise { to { opacity: 1; transform: none; } }
.rise { transform: translateY(20px); }

/* live pulse dot for a "market open" indicator (real semantic state) */
.pulse-dot { position: relative; }
.pulse-dot::after {
  content: ""; position: absolute; inset: 0; border-radius: 9999px;
  background: var(--accent-bright); opacity: .65;
  animation: pulse 2s cubic-bezier(.4,0,.6,1) infinite;
}
@keyframes pulse { 0% { transform: scale(1); opacity:.6 } 70%,100% { transform: scale(2.4); opacity:0 } }

/* marquee ticker (used once, on the homepage market strip) */
.ticker-track { display: inline-flex; white-space: nowrap; animation: ticker 38s linear infinite; }
@keyframes ticker { from { transform: translateX(0) } to { transform: translateX(-50%) } }
.ticker-wrap:hover .ticker-track { animation-play-state: paused; }

/* custom scrollbar */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: var(--paper-2); }
::-webkit-scrollbar-thumb { background: rgba(19,22,26,0.22); border-radius: 9999px; border: 2px solid var(--paper-2); }
::-webkit-scrollbar-thumb:hover { background: rgba(19,22,26,0.38); }

/* ------------------------------------------------ reduced motion */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
  .rise { opacity: 1 !important; transform: none !important; animation: none !important; }
  .ticker-track { animation: none !important; }
  .pulse-dot::after { animation: none !important; }
  * { scroll-behavior: auto !important; }
}
