/* ═══════════════════════════════════════════════════════════════════════════
   agenda.css — swp.ro · Agenda Iași v4
════════════════════════════════════════════════════════════════════════════ */

/* ── Themes ───────────────────────────────────────────────────────────────*/
[data-theme="night"] {
  --bg:#252A40; --bg2:#2E3452; --bg3:#363D5E;
  --card:#2E3452; --card-h:#363D5E;
  --brd:rgba(255,255,255,0.09); --brd2:rgba(255,255,255,0.2);
  --tx:#EDE9E0; --tx2:#a8a3b3; --tx3:#6b6480;
  --ac:#D4AF37; --ac2:rgba(212,175,55,0.15);
  --topbar:rgba(37,42,64,0.96);
  --hgrad:radial-gradient(ellipse 80% 50% at 50% 0%,rgba(212,175,55,0.09) 0%,transparent 70%);
  --sh:0 4px 20px rgba(0,0,0,.3); --sh-h:0 16px 40px rgba(0,0,0,.5);
}
[data-theme="viu"] {
  --bg:#FAFAF8; --bg2:#F5F2ED; --bg3:#EEEAE3;
  --card:#fff; --card-h:#f9f7f4;
  --brd:rgba(0,0,0,.07); --brd2:rgba(0,0,0,.18);
  --tx:#1A1A2E; --tx2:#444466; --tx3:#888;
  --ac:#7C3AED; --ac2:rgba(124,58,237,.08);
  --topbar:rgba(238,234,227,.97);
  --hgrad:linear-gradient(160deg,#F5F0FF 0%,#FFF5F0 50%,#F0FAF5 100%);
  --sh:0 4px 16px rgba(0,0,0,.07); --sh-h:0 16px 36px rgba(0,0,0,.15);
}
[data-theme="print"] {
  --bg:#F9F6F1; --bg2:#F2EEE8; --bg3:#E8E4DC;
  --card:#fff; --card-h:#fdf9f4;
  --brd:#D4CFC7; --brd2:#1A1A1A;
  --tx:#1A1A1A; --tx2:#555; --tx3:#888;
  --ac:#1A1A1A; --ac2:rgba(0,0,0,.05);
  --topbar:rgba(249,246,241,.98);
  --hgrad:linear-gradient(180deg,#F9F6F1,#F9F6F1);
  --sh:0 2px 8px rgba(0,0,0,.06); --sh-h:0 6px 20px rgba(0,0,0,.1);
}
:root {
  --c-op:#7C3AED; --c-fi:#DC2626; --c-te:#059669;
  --c-at:#0891B2; --c-sp:#CA8A04; --c-ev:#EA580C;
}

/* ── Reset ────────────────────────────────────────────────────────────────*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',system-ui,sans-serif;background:var(--bg);color:var(--tx);min-height:100vh;transition:background .3s,color .3s}

/* ── Topbar ───────────────────────────────────────────────────────────────*/
.tb {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--topbar);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--brd);
    padding: 0 16px;
}

/* Rândul 1: meteo + theme switcher */
.tb-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 36px;
}

/* Rândul 2: cursuri valutare — vizibil mereu */
.tb-rates {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 4px 0 6px;
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    color: var(--tx3);
    border-top: 1px solid var(--brd);
}

/* Pe desktop: mutăm rates în rândul 1 (o singura linie) */
@media (min-width: 540px) {
    .tb {
        height: 36px;
        padding: 0 20px;
        display: flex;
        align-items: center;
        flex-direction: row;
    }
    .tb-top {
        flex: 1;
        height: auto;
    }
    .tb-rates {
        border-top: none;
        padding: 0;
        margin-left: 12px;
        padding-left: 12px;
        border-left: 1px solid var(--brd);
    }
}

.tb-l, .tb-r {
    display: flex;
    align-items: center;
    gap: 10px;
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    color: var(--tx3);
}

.tb-sep { opacity: .35; }
.tb a { color: var(--tx3); text-decoration: none; }
.tb a:hover { color: var(--tx2); }
.eur { color: var(--c-op); font-weight: 500; }
.usd { color: var(--c-te); font-weight: 500; }

.tsw { display: flex; gap: 2px; background: var(--bg3); border-radius: 6px; padding: 2px; }
.tsw button {
    border: none;
    background: transparent;
    color: var(--tx3);
    font-family: 'DM Mono', monospace;
    font-size: 9px;
    letter-spacing: .05em;
    padding: 3px 8px;
    border-radius: 4px;
    cursor: pointer;
    transition: all .2s;
    text-transform: uppercase;
}
.tsw button.on { background: var(--ac); color: #000; font-weight: 700; }
[data-theme="print"] .tsw button.on { background: #1A1A1A; color: #fff; }

/* ── Header ───────────────────────────────────────────────────────────────*/
.hd { background: var(--hgrad); padding: 48px 20px 0; text-align: center; }
[data-theme="print"] .hd { border-bottom: 3px solid #1A1A1A; padding: 28px 20px 0; }

.hd-eye {
    font-family: 'DM Mono', monospace;
    font-size: 12px;
    letter-spacing: .3em;
    text-transform: uppercase;
    color: var(--ac);
    font-weight: 500;
    margin-bottom: 14px;
}
[data-theme="print"] .hd-eye { color: var(--tx2); }

.hd-eye strong {
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .15em;
    font-family: 'Playfair Display', serif;
    font-style: italic;
}

.hd-title {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: clamp(32px, 5vw, 56px);
    font-weight: 900;
    line-height: 1.05;
    color: var(--tx);
    margin-bottom: 10px;
}
.hd-title em { font-style: italic; color: var(--ac); }
[data-theme="print"] .hd-title { letter-spacing: -.03em; font-size: clamp(38px, 7vw, 64px); }
[data-theme="print"] .hd-title em { color: inherit; font-style: normal; }
.hd-sub { font-size: 14px; color: var(--tx3); margin-bottom: 24px; }

/* ── View toggle ──────────────────────────────────────────────────────────*/
.view-toggle{display:inline-flex;gap:3px;background:var(--bg3);border-radius:8px;padding:3px;margin-bottom:24px}
.view-btn{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;padding:6px 14px;border-radius:6px;border:none;background:transparent;color:var(--tx3);cursor:pointer;transition:all .2s}
.view-btn.on{background:var(--card);color:var(--tx);box-shadow:var(--sh);font-weight:600}

/* ── Filter pills ─────────────────────────────────────────────────────────*/
.fbar-wrap {
    position: relative;
    overflow: hidden;
}
.fbar{display:flex;gap:6px;justify-content:center;flex-wrap:wrap;padding:0 20px 32px}

[data-theme="print"] .fbar {
    padding: 0 20px 32px;
    gap: 6px;
    flex-wrap: wrap;
    justify-content: center;
    scrollbar-width: none;
}
[data-theme="print"] .fbar::-webkit-scrollbar { display: none; }

@media (max-width: 700px) {
    [data-theme="print"] .fbar {
        flex-wrap: nowrap;
        overflow-x: auto;
        justify-content: flex-start;
        padding-left: 16px;
        padding-right: 16px;
        -webkit-overflow-scrolling: touch;
    }
}

.fpill{font-size:12px;font-weight:500;padding:7px 16px;border-radius:100px;border:1px solid var(--brd2);background:transparent;color:var(--tx2);cursor:pointer;transition:all .2s;white-space:nowrap;font-family:'DM Sans',sans-serif}
[data-theme="print"] .fpill{border-radius:0;border:none;border-right:1px solid #1A1A1A;font-size:9px;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:10px 14px}
.fpill:hover:not(.on){border-color:var(--ac);color:var(--ac)}
[data-theme="print"] .fpill:hover:not(.on){background:#f0ece4}
.fpill.on { background: var(--ac2); border-color: var(--ac); color: var(--ac); font-weight: 600; }
[data-theme="print"] .fpill.on { background: #1A1A1A; color: #fff; border-color: #1A1A1A; }

.pill-count {
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    opacity: .55;
    margin-left: 3px;
}

/* ── Main container ───────────────────────────────────────────────────────*/
.main{max-width:1100px;margin:0 auto;padding:32px 24px 72px}
[data-theme="print"] .main{padding:0 24px 72px}

/* ── Grid categorii: mereu 2 coloane pe desktop ──────────────────────────*/
.cats-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px 48px}
@media(max-width:860px){.cats-grid{grid-template-columns:1fr;gap:32px}}

.cats-grid.single-cat{grid-template-columns:1fr}
@media(min-width:860px){
  .cats-grid.single-cat .elist{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
    align-items:start;
  }
  .cats-grid.single-cat .ecard-wrap{animation:none}
}

/* ── View cronologic ──────────────────────────────────────────────────────*/
/* ── View cronologic ──────────────────────────────────────────────────────*/

/*
 * Grid 2 coloane, câte o zi per coloană.
 * align-items: stretch → grupurile din aceeași linie au aceeași înălțime.
 * Cardurile din interiorul unui grup cresc cu flex:1 → egalizate pe verticală.
 */
.cats-chrono {
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 24px;
    row-gap: 36px;
    align-items: start;   /* fiecare grup la înălțimea sa naturală */
}

.chrono-day-group {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Cardurile cresc să umple înălțimea grupului */
.chrono-day-group .ecard-wrap {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.chrono-day-group .ecard {
    flex: 1;
}

/* Zile cu 3+ carduri → full width, carduri pe sub-grid 2 col */
.chrono-day-group.many-cards {
    grid-column: 1 / -1;
}

.chrono-day-group.many-cards .chrono-cards-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
    align-items: stretch;
}

.chrono-day-group.many-cards .ecard-wrap {
    flex: none;
    display: flex;
    flex-direction: column;
}

.chrono-day-group.many-cards .ecard-wrap .ecard {
    flex: 1;
}

.chrono-day-header {
    font-family: 'Playfair Display', serif;
    font-size: 17px;
    font-weight: 700;
    color: var(--tx);
    padding: 0 0 10px;
    border-bottom: 2px solid var(--brd);
    margin-bottom: 4px;
    display: flex;
    align-items: baseline;
    gap: 10px;
    flex-shrink: 0;   /* headerul nu se comprimă */
}

.chrono-day-header .day-count {
    font-family: 'DM Mono', monospace;
    font-size: 11px;
    font-weight: 400;
    color: var(--tx3);
}


/* Mobile: 1 coloană */
@media (max-width: 860px) {
    .cats-chrono {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .chrono-day-group { flex: none; }
    .chrono-day-group.many-cards { grid-column: auto; }
    .chrono-day-group.many-cards .chrono-cards-inner {
        grid-template-columns: 1fr;
    }
}


/* ── Section header ───────────────────────────────────────────────────────*/
.csec{min-width:0}
.csec.hide{display:none}
.chdr{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:12px}
.chdr::after{content:'';flex-grow:1;height:1px;background:linear-gradient(90deg,var(--cc,var(--ac)),transparent)}
[data-theme="print"] .chdr{border-bottom:2px solid #1A1A1A;padding-bottom:10px}
[data-theme="print"] .chdr::after{display:none}
.cat-logo{width:34px;height:34px;border-radius:7px;object-fit:cover;box-shadow:0 2px 8px rgba(0,0,0,.15);flex-shrink:0}
.cicon{font-size:20px;line-height:1}
.ctitle{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;color:var(--cc,var(--tx))}
[data-theme="print"] .ctitle{font-size:18px;color:var(--tx)}
.cpill{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:3px;color:#fff}

/* Empty state */
.cempty{padding:24px 16px;text-align:center;color:var(--tx3);font-size:13px;border:1px dashed var(--brd);border-radius:8px;line-height:1.7}
[data-theme="print"] .cempty{border-radius:0;border-color:#D4CFC7}
.cempty-icon{display:block;font-size:22px;margin-bottom:6px;opacity:.35}

/* ══════════════════════════════════════════════════════════════════════════
   CARD EVENIMENT
══════════════════════════════════════════════════════════════════════════ */
.elist{display:flex;flex-direction:column;gap:16px}

@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ecard-wrap{animation:fadeUp .3s ease both}

.ecard{
  display:flex;flex-direction:column;
  background:var(--card);
  border-radius:12px;
  overflow:hidden;
  box-shadow:var(--sh);
  border-left:6px solid var(--cc,var(--ac));
  transition:transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s ease;
  text-decoration:none;color:inherit;
  will-change:transform;
}
.ecard:hover{
  transform:translateY(-5px) scale(1.01);
  box-shadow:var(--sh-h);
}
[data-theme="print"] .ecard{border-radius:0;box-shadow:none;border-bottom:1px solid #D4CFC7}
[data-theme="print"] .ecard:hover{transform:none;box-shadow:none;background:#fdf9f4}

.ecard-date{
  display:flex;align-items:baseline;flex-wrap:wrap;gap:4px 6px;
  padding:14px 18px 0 18px;
  font-family:'DM Mono',monospace;
}
.ecard-weekday{font-size:12px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em}
.ecard-day{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--cc,var(--ac));line-height:1}
[data-theme="night"] .ecard-day{color:var(--ac)}
.ecard-month{font-size:13px;font-weight:600;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em}
.ecard-time{
  font-family:'Playfair Display',serif;
  font-size:18px;font-weight:700;
  color:var(--cc,var(--ac));
  margin-left:6px;line-height:1;
}
[data-theme="night"] .ecard-time{color:var(--ac)}
.ecard-time::before{content:'·';font-family:'DM Sans',sans-serif;font-weight:300;margin-right:6px;opacity:.4;font-size:14px}

.ecard-body{padding:10px 18px 14px;flex:1;display:flex;flex-direction:column;gap:6px}

.ecard-title{
  font-family:'Playfair Display',serif;
  font-size:18px;font-weight:700;line-height:1.3;color:var(--tx);
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

.ecard-type{
  display:inline-flex;font-size:11px;font-weight:700;
  letter-spacing:.07em;text-transform:uppercase;
  padding:2px 9px;border-radius:4px;
  background:var(--cpill,rgba(0,0,0,.07));
  color:var(--cc,var(--tx2));width:fit-content;
}
.ecard-venue{font-size:12px;color:var(--tx3);display:flex;align-items:center;gap:4px}
.ecard-duration{font-family:'DM Mono',monospace;font-size:11px;color:var(--tx3)}

.ecard-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 18px 14px;
  border-top:1px solid var(--brd);
  gap:12px;flex-wrap:wrap;
}
.ecard-ticket-info{display:flex;flex-direction:column;gap:4px}
.badge{font-size:12px;font-weight:600;padding:4px 12px;border-radius:20px;display:inline-block}
.badge-ok { background: rgba(5,150,105,.1); color: #059669; }
.badge-ok .badge-total { opacity: .5; font-weight: 400; }
.badge-so { background: rgba(220,38,38,.1); color: #DC2626; }
.badge-fr { background: rgba(8,145,178,.1); color: #0891B2; }
.ecard-price{font-size:13px;font-weight:600;color:var(--tx2);display:flex;align-items:center;gap:4px}
.btn-t{
  display:inline-flex;align-items:center;gap:4px;
  font-size:12px;font-weight:600;padding:6px 14px;
  border-radius:6px;text-decoration:none;white-space:nowrap;
  transition:all .2s;
  background:var(--cc,var(--ac));color:#fff;
  border:none;cursor:pointer;
  opacity:.85;flex-shrink:0;
}
[data-theme="night"] .btn-t{background:linear-gradient(135deg,var(--ac),#b8941e);color:#000}
[data-theme="print"] .btn-t{border-radius:3px;font-size:10px;letter-spacing:.06em;text-transform:uppercase;padding:5px 10px}
.btn-t:hover{opacity:1;filter:brightness(1.08);transform:translateY(-1px)}

/* filterCat JS foloseste data-cat pe .ecard (acum div) */
.ecard[data-cat] { display: flex; }
.ecard-past {
    opacity: .45;
    filter: grayscale(60%);
}
.ecard-past:hover {
    transform: translateY(-2px);
    box-shadow: var(--sh);
    opacity: .6;
    filter: grayscale(40%);
}

.badge-past {
    font-family: 'DM Mono', monospace;
    font-size: 10px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--tx3);
    background: var(--bg3);
    padding: 2px 7px;
    border-radius: 3px;
    margin-left: 6px;
    vertical-align: middle;
}
.smore{
  width:100%;margin-top:8px;padding:12px;
  background:transparent;
  border:1px solid color-mix(in srgb,var(--cc,var(--ac)) 30%,transparent);
  color:var(--cc,var(--ac));font-family:'DM Sans',sans-serif;
  font-size:13px;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s;opacity:.7;
}
[data-theme="print"] .smore{border-radius:0;font-size:9px;letter-spacing:.1em;text-transform:uppercase}
.smore:hover{opacity:1;background:var(--ac2)}

/* ── Footer pagina ────────────────────────────────────────────────────────*/
.ft{border-top:1px solid var(--brd);padding:20px;text-align:center;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;color:var(--tx3);text-transform:uppercase}
.ft a{color:var(--tx3);text-decoration:none}.ft a:hover{color:var(--tx2)}

/* ── Responsive ───────────────────────────────────────────────────────────*/
@media(max-width:600px){
  .hd-title{font-size:28px}
  .hd-sub{font-size:12px}
  .fbar {
    flex-wrap: nowrap;
    overflow-x: auto;
    justify-content: flex-start;
    padding-left: 16px;
    padding-right: 56px;
    padding-bottom: 32px;
    scroll-padding-left: 16px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .fbar::-webkit-scrollbar { display: none; }
  .fbar-wrap::after{content:'';position:absolute;top:0;right:0;bottom:0;width:48px;background:linear-gradient(to right,transparent,var(--bg));pointer-events:none;z-index:2}
  .fpill{font-size:11px;padding:6px 12px}
  .cats-grid{grid-template-columns:1fr;gap:24px}
  .cats-grid.single-cat .elist{display:flex;flex-direction:column}
  .ecard-date{padding:10px 14px 0}
  .ecard-day{font-size:24px}
  .ecard-time{font-size:13px}
  .ecard-body{padding:8px 14px 10px;gap:4px}
  .ecard-title{font-size:15px}
  .ecard-type{font-size:10px;padding:2px 7px}
  .ecard-venue{font-size:11px}
  .ecard-footer{padding:8px 14px 10px;gap:8px}
  .badge{font-size:11px;padding:3px 10px}
  .ecard-footer{flex-direction:row;align-items:center;justify-content:space-between;flex-wrap:nowrap}
  .btn-t{width:auto;padding:7px 14px;font-size:12px;box-shadow:none}
  .view-toggle { font-size: 11px; }
  .view-btn { padding: 5px 10px; font-size: 11px; }
}
