/* css/degen-roast-machine.css
   Styles for /tools/degen-roast-machine/
   Requires site.css (loaded first) for header/footer/reset/flex-layout.
   site.css section 8 already handles all .site-header / .sh-* classes.
   This file only covers the tool-specific dark aesthetic and content classes.
*/

/* =========================================
   DRM COLOR TOKENS
   Supplement site.css :root — unique names
   so there are no conflicts.
   ========================================= */
:root {
  --bg0: #080810;
  --bg1: #0d0d18;
  --bg2: #111120;
  --bg3: #161628;
  --bg4: #1c1c35;

  --tx-pri: #e2e2f0;
  --tx-sec: #7070a0;
  --tx-ter: #3a3a60;

  --br-dim: rgba(255, 255, 255, 0.06);
  --br-mid: rgba(255, 255, 255, 0.10);
  --br-lit: rgba(255, 255, 255, 0.16);

  --acc:        #00ff99;
  --acc-dim:    rgba(0, 255, 153, 0.10);
  --acc-border: rgba(0, 255, 153, 0.28);
  --acc-glow:   0 0 24px rgba(0, 255, 153, 0.22), 0 0 80px rgba(0, 255, 153, 0.07);

  --fire:        #ff3355;
  --fire-dim:    rgba(255, 51, 85, 0.10);
  --fire-border: rgba(255, 51, 85, 0.28);
  --fire-glow:   0 0 24px rgba(255, 51, 85, 0.22), 0 0 80px rgba(255, 51, 85, 0.07);

  --amber:        #ffaa00;
  --amber-dim:    rgba(255, 170, 0, 0.10);
  --amber-border: rgba(255, 170, 0, 0.25);

  --f-display: 'Bebas Neue', sans-serif;

  --r:          10px;
  --r-sm:       6px;
  --r-pill:     999px;
  --transition: 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}

/* =========================================
   BODY OVERRIDES
   site.css sets font-family, background, color
   via html,body {}. body.drm-page {} wins via
   higher specificity (0,1,1 vs 0,0,1).
   ========================================= */
body.drm-page {
  background:   var(--bg0);
  color:        var(--tx-pri);
  font-family:  var(--f-mono);
  overflow-x:   hidden;
}

/* Nudge the main content area — site.css padding overridden here */
body.drm-page main {
  padding: 0;
}

/* Atmospheric scanlines overlay (whole page, pointer-events:none) */
body.drm-page::after {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0, 0, 0, 0.03) 2px,
    rgba(0, 0, 0, 0.03) 4px
  );
  pointer-events: none;
  z-index: 9999;
}

/* Radial gradient + grid background (behind content) */
body.drm-page::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 50% at 50% -5%, rgba(0, 255, 153, 0.05) 0%, transparent 65%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='40' height='40'%3E%3Cpath d='M40 0v40M0 40h40' stroke='rgba(255,255,255,0.025)' stroke-width='0.5' fill='none'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* =========================================
   PAGE SHELL
   ========================================= */
.shell {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 0 1rem 5rem;
  max-width: 680px;
  margin: 0 auto;
  width: 100%;
}

/* Safe area bottom padding on notched devices */
@supports (padding: max(0px)) {
  .shell { padding-bottom: max(5rem, env(safe-area-inset-bottom)); }
}

/* =========================================
   HERO
   ========================================= */
.drm-hero {
  width: 100%;
  text-align: center;
  padding: 2.8rem 0 1.8rem;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.6rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--tx-sec);
  margin-bottom: 1.1rem;
  border: 1px solid var(--br-dim);
  background: var(--bg2);
  padding: 0.3rem 0.85rem;
  border-radius: var(--r-pill);
}

.hero-eyebrow-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--acc);
  animation: blink 1.4s ease-in-out infinite;
}

.hero-eyebrow-brand {
  color: var(--acc);
  font-weight: 700;
}

.hero-title {
  font-family: var(--f-display);
  font-size: clamp(3rem, 13vw, 5.5rem);
  line-height: 0.92;
  letter-spacing: 0.02em;
  color: var(--tx-pri);
  margin-bottom: 0.6rem;
}

.hero-title .flame {
  color: var(--fire);
  text-shadow: var(--fire-glow);
  display: inline-block;
  animation: flicker 3s ease-in-out infinite;
}

.hero-sub {
  font-size: 0.8rem;
  color: var(--tx-sec);
  line-height: 1.7;
  max-width: 360px;
  margin: 0 auto;
}

/* =========================================
   ENGINE STRIP
   ========================================= */
.engine-strip {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  margin: 1.1rem 0 1.4rem;
  padding: 0.6rem 1rem;
  background: var(--bg2);
  border: 1px solid var(--br-dim);
  border-radius: var(--r);
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--tx-ter);
}

.engine-strip-icon {
  width: 18px;
  height: 18px;
  border-radius: 4px;
  background: linear-gradient(135deg, var(--acc) 0%, #00c974 100%);
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: 0 0 8px rgba(0, 255, 153, 0.25);
}
.engine-strip-icon svg { display: block; }

.engine-strip strong {
  color: var(--acc);
  font-weight: 700;
  letter-spacing: 0.16em;
}

.engine-strip .sep { color: var(--br-lit); }

/* =========================================
   SEARCH
   ========================================= */
.search-wrap { width: 100%; margin-bottom: 0.6rem; }

.search-box {
  display: flex;
  gap: 0.5rem;
  background: var(--bg2);
  border: 1px solid var(--br-lit);
  border-radius: var(--r);
  padding: 0.65rem;
  transition: border-color var(--transition), box-shadow var(--transition);
}
.search-box:focus-within {
  border-color: var(--acc-border);
  box-shadow: var(--acc-glow);
}

.search-inner { position: relative; flex: 1; }

.search-icon {
  position: absolute;
  left: 0.75rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--tx-ter);
  pointer-events: none;
  transition: color var(--transition);
}
.search-box:focus-within .search-icon { color: var(--acc); }

#q {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--br-dim);
  border-radius: var(--r-sm);
  color: var(--tx-pri);
  font-family: var(--f-mono);
  font-size: 0.85rem;
  padding: 0.8rem 0.9rem 0.8rem 2.4rem;
  outline: none;
  -webkit-appearance: none;
  transition: border-color var(--transition);
  caret-color: var(--acc);
  min-height: 48px;
}
#q::placeholder { color: var(--tx-ter); }
#q:focus        { border-color: var(--acc-border); }

.btn-roast {
  background: var(--acc);
  color: var(--bg0);
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--f-display);
  font-size: 1rem;
  letter-spacing: 0.06em;
  padding: 0 1.25rem;
  cursor: pointer;
  white-space: nowrap;
  min-height: 48px;
  transition: opacity var(--transition), transform var(--transition), box-shadow var(--transition);
  touch-action: manipulation;
}
.btn-roast:hover   { box-shadow: var(--acc-glow); }
.btn-roast:active  { transform: scale(0.95); opacity: 0.85; }
.btn-roast:disabled { opacity: 0.35; cursor: not-allowed; transform: none; box-shadow: none; }

/* =========================================
   DROPDOWN
   ========================================= */
.dd-shell { position: relative; width: 100%; }

#dd {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  background: var(--bg3);
  border: 1px solid var(--br-lit);
  border-radius: var(--r);
  z-index: 200;
  display: none;
  max-height: 320px;
  overflow-y: auto;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.7);
}
#dd.open { display: block; }

.dd-head {
  font-size: 0.6rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--tx-sec);
  padding: 0.7rem 1rem 0.45rem;
  border-bottom: 1px solid var(--br-dim);
}

.dd-wallet-ctx {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 1rem;
  background: var(--acc-dim);
  border-bottom: 1px solid var(--acc-border);
  font-size: 0.6rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--acc);
}
.dd-wallet-ctx svg { flex-shrink: 0; }

.dd-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.7rem 1rem;
  cursor: pointer;
  border-bottom: 1px solid var(--br-dim);
  transition: background var(--transition);
}
.dd-row:last-child { border-bottom: none; }
.dd-row:hover  { background: var(--bg4); }
.dd-row:active { background: var(--acc-dim); }

.dd-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--bg4);
  border: 1px solid var(--br-mid);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
  color: var(--tx-sec);
}
.dd-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.dd-info   { flex: 1; min-width: 0; }
.dd-name   { font-size: 0.82rem; font-weight: 700; color: var(--tx-pri); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dd-addr   { font-size: 0.65rem; color: var(--tx-sec); margin-top: 1px; }
.dd-bal    { font-size: 0.65rem; color: var(--acc); margin-top: 1px; font-style: italic; }

.badge-strict {
  font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
  color: var(--acc); background: var(--acc-dim); border: 1px solid var(--acc-border);
  padding: 0.18rem 0.5rem; border-radius: var(--r-pill); white-space: nowrap; flex-shrink: 0;
}
.badge-community {
  font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
  color: var(--amber); background: var(--amber-dim); border: 1px solid var(--amber-border);
  padding: 0.18rem 0.5rem; border-radius: var(--r-pill); white-space: nowrap; flex-shrink: 0;
}
.badge-wallet {
  font-size: 0.58rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
  color: var(--tx-sec); background: var(--bg4); border: 1px solid var(--br-mid);
  padding: 0.18rem 0.5rem; border-radius: var(--r-pill); white-space: nowrap; flex-shrink: 0;
}

.dd-loading {
  padding: 0.9rem 1rem;
  font-size: 0.7rem;
  color: var(--tx-sec);
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.dd-spin { display: inline-block; animation: tspin 0.7s linear infinite; }

/* =========================================
   LOADER
   ========================================= */
#loader { display: none; width: 100%; padding: 2rem 0; text-align: center; }
#loader.on { display: block; }

.term {
  display: inline-block;
  background: var(--bg2);
  border: 1px solid var(--br-lit);
  border-radius: var(--r);
  padding: 1.25rem 1.5rem;
  text-align: left;
  min-width: 270px;
}

.tline {
  font-size: 0.75rem;
  color: var(--tx-sec);
  margin-bottom: 0.35rem;
  opacity: 0;
  transition: opacity 0.35s ease;
  white-space: nowrap;
}
.tline:last-child { margin-bottom: 0; }
.tline.show       { opacity: 1; }
.tline .p         { color: var(--acc); }
.tline .spin      { display: inline-block; animation: tspin 0.7s linear infinite; }

/* =========================================
   ERROR
   ========================================= */
#err {
  display: none;
  width: 100%;
  background: var(--bg2);
  border: 1px solid var(--fire-border);
  border-radius: var(--r);
  padding: 0.9rem 1.1rem;
  font-size: 0.78rem;
  color: var(--fire);
  animation: pop 0.25s ease;
}
#err.on { display: block; }

/* =========================================
   RESULT CARD
   ========================================= */
#card {
  display: none;
  width: 100%;
  border-radius: var(--r);
  overflow: hidden;
  border: 1px solid var(--br-lit);
  animation: pop 0.38s cubic-bezier(0.34, 1.56, 0.64, 1);
}
#card.on     { display: block; }
#card.c-roast  { border-color: var(--fire-border); box-shadow: var(--fire-glow); }
#card.c-praise { border-color: var(--acc-border);  box-shadow: var(--acc-glow); }

/* Card header */
.c-head {
  background: var(--bg2);
  display: flex;
  align-items: center;
  gap: 0.9rem;
  padding: 1rem 1.1rem;
  border-bottom: 1px solid var(--br-dim);
}

.c-avatar {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  background: var(--bg4);
  border: 2px solid var(--br-mid);
  flex-shrink: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--tx-sec);
}
.c-avatar img { width: 100%; height: 100%; object-fit: cover; }

.c-title-wrap { flex: 1; min-width: 0; }
.c-name   { font-family: var(--f-display); font-size: 1.2rem; letter-spacing: 0.04em; color: var(--tx-pri); line-height: 1; }
.c-ticker { font-size: 0.7rem; color: var(--tx-sec); margin-top: 3px; }

.c-mint-row { display: flex; align-items: center; gap: 0.4rem; margin-top: 3px; }
.c-mint     { font-size: 0.62rem; color: var(--tx-ter); font-style: italic; }

.c-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  color: var(--tx-ter);
  transition: color var(--transition);
  flex-shrink: 0;
  line-height: 1;
}
.c-copy:hover  { color: var(--acc); }
.c-copy svg    { display: block; width: 11px; height: 11px; }
.c-copy.copied { color: var(--acc); }

.c-price-wrap { text-align: right; flex-shrink: 0; }
.c-price      { font-size: 1.05rem; font-weight: 700; color: var(--tx-pri); }
.c-change     { font-size: 0.72rem; margin-top: 3px; }
.c-change.up  { color: var(--acc); }
.c-change.dn  { color: var(--fire); }

/* Stats row */
.c-stats {
  background: var(--bg2);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: 1px solid var(--br-dim);
}
.stat               { padding: 0.75rem 0.9rem; border-right: 1px solid var(--br-dim); }
.stat:last-child    { border-right: none; }
.stat-lbl           { font-size: 0.58rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--tx-ter); margin-bottom: 0.3rem; }
.stat-val           { font-size: 0.88rem; font-weight: 700; color: var(--tx-pri); }
.stat-val.acc       { color: var(--acc); }
.stat-val.fire      { color: var(--fire); }
.stat-val.amber     { color: var(--amber); }

/* Organic score */
.score-wrap   { background: var(--bg2); padding: 0.85rem 1.1rem; border-bottom: 1px solid var(--br-dim); }
.score-row    { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.55rem; }
.score-lbl    { font-size: 0.6rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--tx-sec); }
.score-num    { font-size: 1rem; font-weight: 700; }
.track        { height: 4px; background: var(--bg4); border-radius: var(--r-pill); overflow: hidden; }
.fill         { height: 100%; border-radius: var(--r-pill); width: 0%; transition: width 1.1s cubic-bezier(0.34, 1.1, 0.64, 1); }
.score-engine {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.55rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--tx-ter);
  margin-top: 0.55rem;
}
.score-engine strong { color: var(--acc); opacity: 0.7; }

/* Verdict */
.verdict-wrap { background: var(--bg2); padding: 1.25rem 1.1rem 1rem; border-bottom: 1px solid var(--br-dim); }
.verdict-tag  {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.25rem 0.7rem;
  border-radius: var(--r-pill);
  margin-bottom: 0.85rem;
}
.verdict-tag.roast  { background: var(--fire-dim); border: 1px solid var(--fire-border); color: var(--fire); }
.verdict-tag.praise { background: var(--acc-dim);  border: 1px solid var(--acc-border);  color: var(--acc); }
.verdict-msg {
  font-family: var(--f-display);
  font-size: clamp(1.05rem, 4.5vw, 1.4rem);
  letter-spacing: 0.02em;
  line-height: 1.35;
  color: var(--tx-pri);
}

/* Risk flags */
.flags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  padding: 0.85rem 1.1rem;
  background: var(--bg2);
  border-bottom: 1px solid var(--br-dim);
  min-height: 1px;
}
.pill       { font-size: 0.6rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; padding: 0.26rem 0.7rem; border-radius: var(--r-pill); border: 1px solid; }
.pill-sus   { background: var(--fire-dim);  border-color: var(--fire-border);  color: var(--fire); }
.pill-ok    { background: var(--acc-dim);   border-color: var(--acc-border);   color: var(--acc); }
.pill-warn  { background: var(--amber-dim); border-color: var(--amber-border); color: var(--amber); }
.pill-info  { background: rgba(100, 100, 200, 0.08); border-color: rgba(100, 100, 200, 0.22); color: #8888cc; }

/* Card actions */
.c-actions {
  display: flex;
  gap: 0.5rem;
  padding: 0.9rem 1.1rem 1.1rem;
  background: var(--bg2);
}
.btn-share {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  background: var(--tx-pri);
  color: var(--bg0);
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--f-display);
  font-size: 1rem;
  letter-spacing: 0.05em;
  padding: 0.85rem;
  cursor: pointer;
  transition: opacity var(--transition), transform var(--transition);
  touch-action: manipulation;
  min-height: 48px;
}
.btn-share:active { transform: scale(0.95); opacity: 0.85; }

.btn-reset {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  background: transparent;
  color: var(--tx-sec);
  border: 1px solid var(--br-lit);
  border-radius: var(--r-sm);
  font-family: var(--f-mono);
  font-size: 0.75rem;
  padding: 0.85rem 1rem;
  cursor: pointer;
  transition: color var(--transition), border-color var(--transition);
  touch-action: manipulation;
  white-space: nowrap;
  min-height: 48px;
}
.btn-reset:hover  { color: var(--tx-pri); border-color: var(--br-lit); }
.btn-reset:active { transform: scale(0.95); }

.btn-capture {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  background: transparent;
  color: var(--tx-sec);
  border: 1px solid var(--br-lit);
  border-radius: var(--r-sm);
  font-family: var(--f-mono);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  padding: 0.85rem 1rem;
  cursor: pointer;
  transition: color var(--transition), border-color var(--transition), background var(--transition), transform var(--transition);
  touch-action: manipulation;
  white-space: nowrap;
  min-height: 48px;
}
.btn-capture:hover    { color: var(--acc); border-color: var(--acc-border); background: var(--acc-dim); }
.btn-capture:active   { transform: scale(0.95); }
.btn-capture:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

/* =========================================
   KEYFRAMES
   ========================================= */
@keyframes blink   { 0%, 100% { opacity: 1; } 50% { opacity: 0.2; } }

@keyframes flicker {
  0%, 100% { opacity: 1; text-shadow: var(--fire-glow); }
  92%       { opacity: 1; text-shadow: var(--fire-glow); }
  93%       { opacity: 0.7; text-shadow: none; }
  94%       { opacity: 1; text-shadow: var(--fire-glow); }
  97%       { opacity: 0.85; }
}

@keyframes pop {
  from { opacity: 0; transform: translateY(18px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes tspin { to { transform: rotate(360deg); } }

/* =========================================
   SCROLLBAR
   ========================================= */
body.drm-page ::-webkit-scrollbar       { width: 3px; }
body.drm-page ::-webkit-scrollbar-track { background: transparent; }
body.drm-page ::-webkit-scrollbar-thumb { background: var(--br-lit); border-radius: 2px; }
