/* =====================================================================
   szinonimaszotar.com — „Modern lexikon" arculat
   Editorial / irodalmi: meleg ivory papír, Fraunces fejbetűk + Hanken törzs,
   mély pine akcentus, okker kiemelés. Mobil-first, gyors, akadálymentes.
   ===================================================================== */

:root {
  --paper:    #FAF6EC;
  --paper-2:  #F2ECDD;
  --card:     #FFFDF7;
  --ink:      #211C16;
  --ink-soft: #574D3F;   /* sötétebb mellékszöveg a jobb olvashatóságért */
  --line:     #E7DFCD;
  --accent:   #176B5E;   /* mély pine/teal — SZINONIMA világ */
  --accent-d: #0F5044;
  --gold:     #B07A1F;   /* okker kiemelés */
  --pos:      #3E7D55;
  --neg:      #A0504E;
  --ant:      #A23E3A;   /* rőt — ELLENTÉT világ */
  --ant-d:    #872F2C;
  --ant-bg:   #F6EBE6;
  --shadow:   0 1px 2px rgba(33,28,22,.04), 0 8px 24px rgba(33,28,22,.06);
  --radius:   12px;
  --maxw:     720px;
  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Hanken Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.68;
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    radial-gradient(1200px 480px at 50% -260px, #FFFDF7 0%, rgba(255,253,247,0) 70%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-d); text-decoration: underline; text-underline-offset: 2px; }

::selection { background: #FBE7BD; color: var(--ink); }

main { max-width: var(--maxw); margin: 0 auto; padding: 2rem 1.25rem 4rem; }

/* ---------- Fejléc + kereső ---------- */
.site-header {
  position: sticky; top: 0; z-index: 30;
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  max-width: var(--maxw); margin: 0 auto; padding: .85rem 1.25rem;
  background: rgba(250,246,236,.85);
  backdrop-filter: saturate(140%) blur(8px);
  border-bottom: 1px solid var(--line);
}
.brand {
  font-family: var(--serif); font-weight: 600; font-size: 1.35rem;
  letter-spacing: -.01em; color: var(--ink); white-space: nowrap;
}
.brand:hover { text-decoration: none; color: var(--accent); }
.brand::first-letter { color: var(--accent); }

.search { position: relative; flex: 1 1 260px; display: flex; gap: .5rem; }
.search input {
  flex: 1; min-width: 0;
  padding: .62rem .9rem; font-size: 1rem; font-family: var(--sans);
  color: var(--ink); background: var(--card);
  border: 1px solid var(--line); border-radius: 999px;
  box-shadow: inset 0 1px 2px rgba(33,28,22,.04);
  transition: border-color .15s, box-shadow .15s;
}
.search input::placeholder { color: #A89E8C; }
.search input:focus {
  outline: none; border-color: var(--accent);
  box-shadow: 0 0 0 4px rgba(23,107,94,.12);
}
.search button {
  padding: .62rem 1.1rem; font-family: var(--sans); font-weight: 600; font-size: .95rem;
  color: #fff; background: var(--accent); border: 0; border-radius: 999px; cursor: pointer;
  transition: background .15s, transform .05s;
}
.search button:hover { background: var(--accent-d); }
.search button:active { transform: translateY(1px); }

.suggest {
  position: absolute; top: calc(100% + .4rem); left: 0; right: 0;
  margin: 0; padding: .3rem; list-style: none;
  background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); z-index: 40; overflow: hidden;
}
.suggest li {
  padding: .5rem .7rem; border-radius: 8px; cursor: pointer; display: flex; align-items: baseline; gap: .5rem;
}
.suggest li[aria-selected="true"], .suggest li:hover { background: var(--paper-2); }
.suggest .pos { color: var(--ink-soft); font-size: .8em; }

/* ---------- Szóoldal ---------- */
.word { animation: rise .5s ease both; }
h1 {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(2rem, 6vw, 2.9rem); line-height: 1.08;
  letter-spacing: -.02em; margin: .4rem 0 .3rem;
}
h1 .hw-suffix { color: var(--ink-soft); font-weight: 400; font-size: .5em; font-family: var(--sans); letter-spacing: 0; }

.crumbs { font-size: .82rem; color: var(--ink-soft); margin: 0 0 .7rem; }
.crumbs a { color: var(--ink-soft); }
.crumbs a:hover { color: var(--accent); }
.crumbs .sep { color: #C9BFA8; margin: 0 .15rem; }
.crumbs .cur { color: var(--ink); }

.pos-tag {
  display: inline-block; margin: 0 0 1rem; font-size: .72rem; font-weight: 600;
  letter-spacing: .06em; text-transform: uppercase; color: var(--ink-soft);
  background: var(--paper-2); border: 1px solid var(--line); padding: .12rem .55rem; border-radius: 6px;
}
.lead {
  font-size: 1.15rem; color: var(--ink); margin: .4rem 0 1.6rem;
  padding-left: .9rem; border-left: 3px solid var(--gold);
}

.synfilter { margin: -.6rem 0 1.4rem; font-size: .88rem; color: var(--ink-soft); }
.synfilter label { display: inline-flex; align-items: center; gap: .45rem; cursor: pointer; user-select: none; }
.synfilter input { accent-color: var(--accent); }

.sense { margin: 0 0 1.8rem; animation: rise .5s ease both; }
.sense:nth-child(2) { animation-delay: .04s; }
.sense:nth-child(3) { animation-delay: .08s; }
.sense:nth-child(4) { animation-delay: .12s; }
.sense:nth-child(5) { animation-delay: .16s; }
.sense:nth-child(n+6) { animation-delay: .2s; }

h2 {
  font-family: var(--serif); font-weight: 500; font-size: 1.05rem;
  color: var(--ink-soft); margin: 0 0 .6rem; display: flex; align-items: baseline; gap: .5rem;
}
.sense-no {
  font-family: var(--serif); font-weight: 600; font-size: 1.5rem; line-height: 1;
  color: var(--accent);
}
.def { color: var(--ink-soft); font-style: italic; margin: .1rem 0 .7rem; }

/* chipek — minden szólistára (szinonima, ellentét, böngészés, kezdőlap) */
ul.rel { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: .5rem; }
ul.rel li {
  display: inline-flex; align-items: center; gap: .4rem;
  background: var(--card); border: 1px solid var(--line);
  border-radius: 999px; padding: .34rem .85rem;
  box-shadow: 0 1px 1px rgba(33,28,22,.03);
  transition: transform .12s ease, border-color .12s, box-shadow .12s;
}
ul.rel li:hover { transform: translateY(-2px); border-color: var(--accent); box-shadow: var(--shadow); }
ul.rel li a { color: var(--ink); font-weight: 500; }
ul.rel li a:hover { text-decoration: none; color: var(--accent); }
ul.rel li.syn.tone-pos { box-shadow: inset 3px 0 0 var(--pos); }
ul.rel li.syn.tone-neg { box-shadow: inset 3px 0 0 var(--neg); }
.styles {
  font-size: .64rem; letter-spacing: .06em; text-transform: uppercase;
  color: var(--gold); background: rgba(176,122,31,.1);
  padding: .12rem .4rem; border-radius: 6px; font-weight: 600;
}

.empty { color: var(--ink-soft); font-style: italic; }

/* a lista „fajtája": ≈ zöld = rokon értelmű, ↔ rőt = ellentét */
.rel-kind { font-size: .8rem; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; margin: 0 0 .6rem; }
.rel-kind--syn { color: var(--accent); font-size: .92rem; }   /* a fő funkció hangsúlyosabb fejléce */
.rel-kind--ant { color: var(--ant); }
.rel-count { font-weight: 600; color: var(--ink-soft); }

/* a fő szinonima-lista kicsit nagyobb, hangsúlyosabb chipekkel (a .related/.cross/ellentét érintetlen) */
ul.rel--syn { gap: .55rem; }
ul.rel--syn li.syn { padding: .44rem .95rem; font-size: 1.02rem; }
ul.rel--syn li.syn a { font-weight: 600; }

/* ellentét-chipek külön, rőt világban */
ul.rel--ant li.syn { background: var(--ant-bg); border-color: #EAD3CC; }
ul.rel--ant li.syn:hover { border-color: var(--ant); box-shadow: var(--shadow); }
ul.rel--ant li.syn a { color: var(--ant-d); }
ul.rel--ant li.syn a:hover { color: var(--ant); }

/* kereszt-link blokk (a másik reláció) — élesen elkülönítve, színkódolva */
.cross { margin-top: 1.1rem; padding: .6rem .85rem; border-radius: 10px; font-size: .96rem; line-height: 1.7; }
.cross--ant { background: var(--ant-bg); }
.cross--syn { background: #EAF2F0; }
.cross-label { display: inline-block; font-weight: 700; font-size: .68rem; letter-spacing: .06em; text-transform: uppercase; margin-right: .35rem; }
.cross--ant .cross-label { color: var(--ant); }
.cross--syn .cross-label { color: var(--accent); }
.cross--ant a { color: var(--ant-d); }
.cross--syn a { color: var(--accent-d); }

/* példák */
.examples { margin-top: 2rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.examples h2 {
  font-family: var(--serif); font-weight: 600; font-size: .8rem;
  text-transform: uppercase; letter-spacing: .12em; color: var(--gold); display: block;
}
.examples ul { list-style: none; padding: 0; margin: .4rem 0 0; }
.examples li {
  position: relative; padding-left: 1.2rem; margin: .5rem 0;
  font-family: var(--serif); font-style: italic; font-size: 1.05rem; color: var(--ink);
}
.examples li::before { content: "“"; position: absolute; left: 0; top: -.1em; color: var(--gold); font-family: var(--serif); font-size: 1.4em; }
.examples mark { background: #FBE7BD; color: var(--ink); padding: 0 .12rem; border-radius: 3px; }

.related { margin-top: 2rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.related h2 {
  font-family: var(--serif); font-weight: 600; font-size: .8rem;
  text-transform: uppercase; letter-spacing: .12em; color: var(--gold); margin: 0 0 .7rem;
}

.switch { margin-top: 1.8rem; }
.switch a {
  display: inline-flex; align-items: center; gap: .35rem;
  font-weight: 600; padding: .5rem .9rem; border: 1px solid var(--line);
  border-radius: 999px; background: var(--card);
}
.switch a:hover { text-decoration: none; border-color: var(--accent); background: var(--paper-2); }

/* ---------- Kezdőlap (hero) ---------- */
.hero { padding: 1rem 0 2.2rem; margin-bottom: 1.6rem; border-bottom: 1px solid var(--line); }
.hero-title {
  font-family: var(--serif); font-weight: 600;
  font-size: clamp(2.3rem, 7.5vw, 3.6rem); line-height: 1.04; letter-spacing: -.025em;
  margin: 0 0 .7rem;
}
.hero-title em { font-style: italic; color: var(--accent); }
.hero-sub { font-size: 1.18rem; color: var(--ink-soft); max-width: 38rem; margin: 0 0 1.3rem; }
.hero-try { display: flex; flex-wrap: wrap; align-items: center; gap: .5rem; font-size: .95rem; }
.hero-try > span { font-weight: 700; color: var(--ink-soft); }
.hero-try a {
  display: inline-flex; padding: .28rem .8rem; border-radius: 999px;
  background: var(--card); border: 1px solid var(--line); color: var(--ink); font-weight: 500;
  transition: transform .12s, border-color .12s;
}
.hero-try a:hover { transform: translateY(-2px); border-color: var(--accent); color: var(--accent); text-decoration: none; }

.daily, .recent { margin: 0 0 2rem; }
.recent h2, .daily h2 {
  font-family: var(--serif); font-weight: 600; font-size: .76rem;
  text-transform: uppercase; letter-spacing: .12em; color: var(--gold); margin: 0 0 .6rem;
}
.daily-word a { font-family: var(--serif); font-size: 1.6rem; color: var(--accent); }
.daily-word a:hover { color: var(--accent-d); }

/* böngészés */
.alpha { margin: 0 0 1.4rem; line-height: 2.2; display: flex; flex-wrap: wrap; gap: .25rem; }
.alpha a { display: inline-block; padding: .15rem .5rem; border-radius: 7px; color: var(--ink-soft); font-weight: 500; }
.alpha a.cur, .alpha a:hover { background: var(--accent); color: #fff; text-decoration: none; }

.hero-rand { color: var(--ink-soft); font-weight: 600; }
.hero-rand:hover { color: var(--accent); text-decoration: none; }

/* ---------- Fázis 4: másolás, kedvencek, toast ---------- */
.copy-btn {
  border: 0; background: none; cursor: pointer; color: var(--ink-soft);
  font-size: .85rem; line-height: 1; padding: .1rem .15rem; border-radius: 5px;
  opacity: 0; transition: opacity .12s, color .12s, background .12s;
}
ul.rel li:hover .copy-btn, .copy-btn:focus-visible { opacity: .7; }
.copy-btn:hover { color: var(--accent); background: var(--paper-2); opacity: 1; }
@media (hover: none) { .copy-btn { opacity: .55; } }

.fav-btn {
  display: inline-flex; align-items: center; gap: .35rem; margin: 0 0 1rem;
  font-family: var(--sans); font-size: .85rem; font-weight: 600; cursor: pointer;
  color: var(--ink-soft); background: var(--card); border: 1px solid var(--line);
  padding: .32rem .8rem; border-radius: 999px; transition: border-color .12s, color .12s;
}
.fav-btn:hover { border-color: var(--gold); color: var(--gold); }
.fav-btn.on { color: var(--gold); border-color: var(--gold); background: rgba(176,122,31,.08); }

#favorites { margin: 0 0 2rem; }
#favorites h2 {
  font-family: var(--serif); font-weight: 600; font-size: .76rem;
  text-transform: uppercase; letter-spacing: .12em; color: var(--gold); margin: 0 0 .6rem;
}

.toast {
  position: fixed; left: 50%; bottom: 1.5rem; transform: translateX(-50%) translateY(1rem);
  background: var(--ink); color: var(--paper); padding: .6rem 1rem; border-radius: 10px;
  font-size: .92rem; box-shadow: var(--shadow); opacity: 0; pointer-events: none;
  transition: opacity .18s, transform .18s; z-index: 60;
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ---------- Tartalmi oldal (Impresszum, 404) ---------- */
.page h1 { font-family: var(--serif); font-weight: 600; font-size: clamp(1.8rem, 5vw, 2.4rem); margin: .2rem 0 1rem; letter-spacing: -.02em; }
.page h2 { font-family: var(--serif); font-weight: 600; font-size: 1.15rem; color: var(--ink); margin: 1.7rem 0 .5rem; }
.page p { margin: .6rem 0; }
.dym-intro { color: var(--ink-soft); margin: 0 0 .7rem; }

.gen-form { margin-top: 1.6rem; padding: 1rem 1.2rem; background: var(--paper-2); border: 1px solid var(--line); border-radius: 12px; }
.gen-form p { margin: 0; }
.gen-form button { font-family: var(--sans); font-weight: 600; color: #fff; background: var(--accent); border: 0; border-radius: 999px; padding: .4rem 1.05rem; cursor: pointer; }
.gen-form button:hover { background: var(--accent-d); }
.gen-note { display: block; margin-top: .45rem; font-size: .82rem; color: var(--ink-soft); }

/* Frissen, on-demand generált szócikk jelzése a szó-blokk tetején */
.fresh-note {
  margin: 0 0 1.1rem; padding: .6rem .85rem; font-size: .88rem; line-height: 1.45;
  color: var(--ink-soft); background: var(--paper-2);
  border: 1px solid var(--line); border-left: 3px solid var(--accent); border-radius: 8px;
}

/* Látogatói szinonima-javaslat — diszkrét, lecsukott */
.suggest { margin-top: 1.6rem; font-size: .92rem; }
.suggest > summary {
  cursor: pointer; display: inline-block; color: var(--accent); font-weight: 600;
  padding: .35rem .2rem; list-style: none;
}
.suggest > summary::-webkit-details-marker { display: none; }
.suggest > summary:hover { color: var(--accent-d); }
.suggest[open] > summary { margin-bottom: .6rem; }
.suggest-form { display: flex; flex-wrap: wrap; gap: .5rem; }
.suggest-form input[type=text] {
  flex: 1 1 12rem; font-family: var(--sans); font-size: 1rem;
  padding: .45rem .7rem; border: 1px solid var(--line); border-radius: 10px;
  background: var(--card); color: var(--ink);
}
.suggest-form input[type=text]:focus { outline: 0; border-color: var(--accent); }
.suggest-form button {
  font-family: var(--sans); font-weight: 600; color: #fff; background: var(--accent);
  border: 0; border-radius: 999px; padding: .45rem 1.1rem; cursor: pointer;
}
.suggest-form button:hover { background: var(--accent-d); }
.suggest-note { margin: .5rem 0 0; font-size: .82rem; color: var(--ink-soft); }

/* Lapozó (böngésző / népszerű) + kezdőlap-böngésző linkek */
.pager { margin: 1.6rem 0 0; display: flex; align-items: center; gap: .9rem; font-weight: 600; }
.pager a { color: var(--accent); }
.pager-pos { color: var(--ink-soft); font-weight: 400; font-size: .9rem; }
.hero-browse { margin: 1rem 0 0; color: var(--ink-soft); }
.hero-browse a { color: var(--accent); font-weight: 600; }

/* Impresszum / adatkezelés — üzemeltetői adatlista */
.contact { display: grid; grid-template-columns: max-content 1fr; gap: .25rem 1rem; margin: .6rem 0 1.2rem; }
.contact dt { color: var(--ink-soft); font-size: .9rem; }
.contact dd { margin: 0; font-weight: 600; }

/* ---------- Lábléc ---------- */
.site-footer {
  max-width: var(--maxw); margin: 3rem auto 0; padding: 1.5rem 1.25rem 2.5rem;
  border-top: 1px solid var(--line); color: var(--ink-soft); font-size: .9rem;
}
.site-footer nav a { color: var(--ink-soft); }
.site-footer nav a:hover { color: var(--accent); }

@keyframes rise { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

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

@media (max-width: 540px) {
  body { font-size: 16px; }
  main { padding: 1.4rem 1rem 3rem; }
  .site-header { gap: .6rem; padding: .7rem 1rem; }
  .brand { font-size: 1.2rem; }
  .search { flex-basis: 100%; order: 3; }
}

/* ---------- Sötét téma ---------- */
@media (prefers-color-scheme: dark) {
  :root {
    --paper:    #1A1611;
    --paper-2:  #241E17;
    --card:     #221C15;
    --ink:      #ECE4D5;
    --ink-soft: #ABA08C;
    --line:     #39322A;
    --accent:   #5FBFA9;
    --accent-d: #7CD0BC;
    --gold:     #D6A24A;
    --pos:      #62B681;
    --neg:      #D38C8A;
    --ant:      #E2918B;
    --ant-d:    #EEA9A3;
    --ant-bg:   #2C211D;
    --shadow:   0 1px 2px rgba(0,0,0,.3), 0 8px 24px rgba(0,0,0,.4);
  }
  body {
    background-image: radial-gradient(1200px 480px at 50% -260px, #241E17 0%, rgba(36,30,23,0) 70%);
  }
  .site-header { background: rgba(26,22,17,.82); }
  .search input { box-shadow: inset 0 1px 2px rgba(0,0,0,.25); }
  ul.rel li.syn { box-shadow: none; }
  ul.rel--ant li.syn { border-color: #4A332E; }
  .cross--syn { background: #16241F; }
  .styles { background: rgba(214,162,74,.14); }
  .examples mark, ::selection { background: #5a4a1e; color: var(--ink); }
  .search button { color: #10130f; }
}
