/* =========================================================
   CannaCal – Frontend (an den Weederkennen-Styleguide angelehnt)
   Nutzt die --nw-*-Tokens mit Fallbacks: mit aktivem Weederkennen werden
   dessen Marke + Themes (Hell/Dunkel/Kontrast) automatisch übernommen;
   standalone greifen die Fallback-Werte. Flach, kein Glassmorphism.
   ========================================================= */

.cannacal-widget {
  font: inherit;
  background: #fff;
  color: var(--nw-ink, #1d2421);
  border: 1px solid var(--nw-line, #cfe0c2);
  border-top: 5px solid var(--nw-green-brand, #2e7d32);
  border-radius: var(--nw-radius-card, 14px);
  box-shadow: 0 1px 2px rgba(0, 0, 0, .04);
  padding: clamp(1.2rem, 4vw, 2rem);
  max-width: 680px;
  margin: 1.5rem auto;
}

/* ─── Header ─── */
.cannacal-header { text-align: center; margin-bottom: 1.4rem; }
.cannacal-logo { font-size: 2.4rem; display: block; margin-bottom: .3rem; }
.cannacal-title {
  font-size: clamp(1.3rem, 1.1rem + 1vw, 1.6rem); font-weight: 700; margin: 0 0 .2rem;
  color: var(--nw-ink, #1d2421); text-wrap: balance;
}
.cannacal-subtitle { color: var(--nw-muted, #6b786b); font-size: .8rem; margin: 0; letter-spacing: .06em; text-transform: uppercase; }
.cannacal-strain-context { display: inline-block; margin: .5rem 0 0; padding: .25rem .7rem; font-size: .85rem; font-weight: 600; color: var(--nw-green-strong, #2f6b16); background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); border-radius: 999px; }

/* ─── Form ─── */
.cannacal-form-section { margin-bottom: 1.2rem; }
.cannacal-label { display: block; font-weight: 600; font-size: .92rem; color: var(--nw-ink, #1d2421); margin-bottom: .5rem; }
.cannacal-date-row { display: flex; gap: 10px; align-items: center; }
.cannacal-date-input {
  flex: 1; background: #fff; border: 1px solid var(--nw-line, #cfe0c2);
  border-radius: var(--nw-radius, 10px); color: var(--nw-ink, #1d2421);
  font: inherit; font-size: 1rem; padding: .6rem .7rem; outline: none;
}
.cannacal-date-input:focus { border-color: var(--nw-green, #4f8a2e); box-shadow: 0 0 0 3px rgba(79, 138, 46, .18); }

/* ─── Buttons (an .navweed-btn angelehnt) ─── */
.cannacal-btn {
  font: inherit; font-size: .95rem; font-weight: 600; border: 0;
  border-radius: var(--nw-radius, 10px); cursor: pointer; padding: .6rem 1.1rem;
  text-decoration: none; display: inline-flex; align-items: center; gap: 6px; white-space: nowrap;
}
.cannacal-btn-primary { background: var(--nw-green, #4f8a2e); color: #fff; }
.cannacal-btn-primary:hover { background: var(--nw-green-dark, #1d4d12); }
.cannacal-btn-secondary { background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); color: var(--nw-green-strong, #2f6b16); }
.cannacal-btn-secondary:hover { background: #e7efe0; }
.cannacal-btn-platform { background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); color: var(--nw-green-strong, #2f6b16); margin-top: 10px; }
.cannacal-btn-platform:hover { border-color: var(--nw-green, #4f8a2e); }
.cannacal-btn-secondary.copied { background: #e7efe0; border-color: var(--nw-green, #4f8a2e); color: var(--nw-green-strong, #2f6b16); }

/* ─── Result ─── */
.cannacal-result { border-top: 1px solid var(--nw-line, #cfe0c2); padding-top: 1.2rem; margin-top: .3rem; }
.cannacal-result-info { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; margin-bottom: 1.2rem; }
.cannacal-info-card { background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); border-radius: var(--nw-radius, 10px); padding: .8rem .9rem; display: flex; align-items: center; gap: 12px; }
.cannacal-info-icon { font-size: 1.5rem; flex-shrink: 0; }
.cannacal-info-label { font-size: .72rem; color: var(--nw-muted, #6b786b); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 2px; }
.cannacal-info-value { font-size: .92rem; font-weight: 600; color: var(--nw-ink, #1d2421); }

/* ─── Link box ─── */
.cannacal-link-section { margin-bottom: 1.2rem; }
.cannacal-link-box { display: flex; gap: 8px; margin-top: 8px; }
.cannacal-url-input {
  flex: 1; background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2);
  border-radius: var(--nw-radius, 10px); color: var(--nw-green-strong, #2f6b16);
  font-family: ui-monospace, Menlo, Consolas, monospace; font-size: .82rem; padding: .55rem .7rem;
  outline: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cannacal-expiry-note { font-size: .8rem; color: var(--nw-muted, #6b786b); margin: 8px 0 0; }

/* ─── Instructions ─── */
.cannacal-instructions { background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); border-radius: var(--nw-radius, 10px); padding: 1rem 1.1rem; margin-bottom: 1.1rem; }
.cannacal-instructions h3 { margin: 0 0 .8rem; font-size: 1rem; color: var(--nw-ink, #1d2421); }
.cannacal-platform-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: .9rem; }
.cannacal-platform-tab {
  background: #fff; border: 1px solid var(--nw-line, #cfe0c2); border-radius: 999px;
  color: var(--nw-muted, #6b786b); cursor: pointer; font: inherit; font-size: .85rem;
  padding: .35rem .8rem; display: flex; align-items: center; gap: 4px;
}
.cannacal-platform-tab:hover, .cannacal-platform-tab.active { border-color: var(--nw-green, #4f8a2e); color: var(--nw-green-strong, #2f6b16); background: var(--nw-surface-soft, #f3f7ef); }
.cannacal-platform-content { display: none; }
.cannacal-platform-content.active { display: block; }
.cannacal-platform-content ol { color: var(--nw-muted, #6b786b); font-size: .9rem; line-height: 1.7; margin: 0 0 0 1.2em; padding: 0; }
.cannacal-platform-content ol li { margin-bottom: 4px; }
.cannacal-platform-content strong { color: var(--nw-ink, #1d2421); }
.cannacal-note { font-size: .82rem; color: var(--nw-muted, #6b786b); margin: 10px 0 0; padding: 8px 12px; background: #fff; border-left: 3px solid var(--nw-star, #e3a008); }

/* ─── Legal ─── */
.cannacal-legal { border-top: 1px solid var(--nw-line, #cfe0c2); padding-top: 1rem; margin-top: .5rem; text-align: center; }
.cannacal-legal p { font-size: .78rem; color: var(--nw-muted, #6b786b); margin: 0; }
.cannacal-legal a { color: var(--nw-green-strong, #2f6b16); text-decoration: none; }
.cannacal-legal a:hover { text-decoration: underline; }

/* ─── Changelog ([cannacal_changelog]) ─── */
.cannacal-changelog h2 { font-size: 1.5rem; margin: 1.6rem 0 .5rem; color: var(--nw-ink, #1d2421); }
.cannacal-changelog h3 { font-size: 1.15rem; margin: 1.4rem 0 .4rem; color: var(--nw-green-strong, #2f6b16); }
.cannacal-changelog h4 { font-size: 1rem; margin: .9rem 0 .3rem; color: var(--nw-ink, #1d2421); }
.cannacal-changelog ul { margin: .3rem 0 .9rem 1.2rem; }
.cannacal-changelog li { margin-bottom: .25rem; }
.cannacal-changelog code { background: var(--nw-surface-soft, #f3f7ef); border: 1px solid var(--nw-line, #cfe0c2); border-radius: 4px; padding: .04em .35em; font-size: .9em; font-family: ui-monospace, Menlo, Consolas, monospace; }
html[data-nw-theme="dark"] .cannacal-changelog h2,
html[data-nw-theme="dark"] .cannacal-changelog h4 { color: var(--nw-d-ink, #e8ece8); }
html[data-nw-theme="dark"] .cannacal-changelog code { background: var(--nw-d-panel, #232b32); border-color: var(--nw-d-border, #3a4751); color: var(--nw-d-ink, #e8ece8); }

/* ─── Dark-Mode (greift nur mit aktivem Weederkennen-Theme) ─── */
html[data-nw-theme="dark"] .cannacal-widget { background: var(--nw-d-surface, #1e2329); border-color: var(--nw-d-border, #3a4751); color: var(--nw-d-ink, #e8ece8); }
html[data-nw-theme="dark"] .cannacal-title,
html[data-nw-theme="dark"] .cannacal-info-value,
html[data-nw-theme="dark"] .cannacal-instructions h3,
html[data-nw-theme="dark"] .cannacal-label,
html[data-nw-theme="dark"] .cannacal-platform-content strong { color: var(--nw-d-ink, #e8ece8); }
html[data-nw-theme="dark"] .cannacal-subtitle,
html[data-nw-theme="dark"] .cannacal-info-label,
html[data-nw-theme="dark"] .cannacal-expiry-note,
html[data-nw-theme="dark"] .cannacal-platform-content ol,
html[data-nw-theme="dark"] .cannacal-legal p,
html[data-nw-theme="dark"] .cannacal-note { color: var(--nw-d-muted, #9fb0a0); }
html[data-nw-theme="dark"] .cannacal-info-card,
html[data-nw-theme="dark"] .cannacal-instructions,
html[data-nw-theme="dark"] .cannacal-url-input,
html[data-nw-theme="dark"] .cannacal-note,
html[data-nw-theme="dark"] .cannacal-date-input,
html[data-nw-theme="dark"] .cannacal-strain-context,
html[data-nw-theme="dark"] .cannacal-platform-tab { background: var(--nw-d-panel, #232b32); border-color: var(--nw-d-border, #3a4751); }
html[data-nw-theme="dark"] .cannacal-date-input,
html[data-nw-theme="dark"] .cannacal-url-input { color: var(--nw-d-ink, #e8ece8); }
html[data-nw-theme="dark"] .cannacal-legal a,
html[data-nw-theme="dark"] .cannacal-strain-context,
html[data-nw-theme="dark"] .cannacal-btn-secondary,
html[data-nw-theme="dark"] .cannacal-btn-platform { color: var(--nw-d-green, #7bbf4e); }

/* ─── Glossar ─── */
.cannacal-glossar { max-width: 760px; }
.cannacal-glossar-tools { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem .9rem; margin-bottom: .5rem; }
.cannacal-glossar-search-label { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
.cannacal-glossar-search {
  flex: 1 1 16rem; background: #fff; border: 1px solid var(--nw-line, #cfe0c2);
  border-radius: var(--nw-radius, 10px); color: var(--nw-ink, #1d2421);
  font: inherit; font-size: 1rem; padding: .6rem .8rem; outline: none;
}
.cannacal-glossar-search:focus { border-color: var(--nw-green, #4f8a2e); box-shadow: 0 0 0 3px rgba(79, 138, 46, .18); }
.cannacal-glossar-count { margin: 0; color: var(--nw-muted, #6b786b); font-size: .9rem; }
.cannacal-glossar-empty { margin: .25rem 0; color: var(--nw-muted, #6b786b); font-style: italic; }

.cannacal-glossar-az { display: flex; flex-wrap: wrap; gap: .25rem; margin: .4rem 0 1rem; }
.cannacal-glossar-az a {
  display: inline-flex; min-width: 1.7rem; justify-content: center; padding: .15rem .35rem;
  border: 1px solid var(--nw-line, #cfe0c2); border-radius: 6px; text-decoration: none;
  color: var(--nw-green, #4f8a2e); font-weight: 600; font-size: .85rem;
}
.cannacal-glossar-az a:hover { background: var(--nw-surface-soft, #f3f7ef); }

.cannacal-glossar-list { margin: 0; text-align: left; }
.cannacal-glossar-letter {
  margin: 1.1rem 0 .4rem; padding-bottom: .2rem; font-size: 1.1rem; font-weight: 800;
  color: var(--nw-green-brand, #2e7d32); border-bottom: 2px solid var(--nw-line, #cfe0c2);
  scroll-margin-top: 1rem;
}
.cannacal-glossar-item {
  border: 1px solid var(--nw-line, #cfe0c2); border-radius: var(--nw-radius, 10px);
  margin: .5rem 0; padding: .75rem .95rem; background: var(--nw-surface-soft, #f3f7ef);
  scroll-margin-top: 1rem;
}
.cannacal-glossar-item:target { border-color: var(--nw-green, #4f8a2e); box-shadow: 0 0 0 2px var(--nw-green, #4f8a2e); }
.cannacal-glossar-term { margin: 0 0 .25rem; font-weight: 700; }
.cannacal-glossar-term .cannacal-glossar-anchor { color: var(--nw-ink, #1d2421); text-decoration: none; }
.cannacal-glossar-term .cannacal-glossar-anchor:hover { color: var(--nw-green, #4f8a2e); }
.cannacal-glossar-def { margin: 0; }
.cannacal-glossar-def p { margin: 0 0 .5rem; line-height: 1.55; color: var(--nw-ink, #1d2421); }
.cannacal-glossar-def p:last-child { margin-bottom: 0; }
.cannacal-glossar-item[hidden], .cannacal-glossar-letter[hidden] { display: none; }

/* Glossar – Dark Theme (übernimmt Weederkennen-Tokens) */
html[data-nw-theme="dark"] .cannacal-glossar-search { background: var(--nw-d-panel, #232b32); color: var(--nw-d-ink, #e8ece8); border-color: var(--nw-d-border, #3a4751); }
html[data-nw-theme="dark"] .cannacal-glossar-az a { border-color: var(--nw-d-border, #3a4751); color: var(--nw-d-green, #7bbf4e); }
html[data-nw-theme="dark"] .cannacal-glossar-az a:hover { background: var(--nw-d-surface, #1e2329); }
html[data-nw-theme="dark"] .cannacal-glossar-letter { color: var(--nw-d-green, #7bbf4e); border-bottom-color: var(--nw-d-border, #3a4751); }
html[data-nw-theme="dark"] .cannacal-glossar-item { background: var(--nw-d-panel, #232b32); border-color: var(--nw-d-border, #3a4751); }
html[data-nw-theme="dark"] .cannacal-glossar-term .cannacal-glossar-anchor { color: var(--nw-d-ink, #e8ece8); }
html[data-nw-theme="dark"] .cannacal-glossar-def p { color: var(--nw-d-ink, #e8ece8); }

/* ─── Responsive ─── */
@media (max-width: 600px) {
  .cannacal-date-row { flex-direction: column; align-items: stretch; }
  .cannacal-btn-primary { justify-content: center; }
  .cannacal-link-box { flex-direction: column; }
}
