/* /home/users/oppqnrnc/www/par.testbase.hu/assets/css/app.css */

:root {
  --bg: #f9fbf7;            /* Törtefehér oldalháttér */
  --surface: #ffffff;       /* Hófehér kártyák/panelek a háttér felett */
  --surface-light: #f1f4f0; /* Világos szürke-zöldes átmeneti háttér */
  --primary: #026634;       /* Fő szín (Sötétzöld) */
  --primary-dark: #014c26;  /* Fő szín sötétebb árnyalata (hover) */
  --success: #3da435;       /* Másodlagos szín (Élénkzöld) */
  --danger: #ef4444;
  --warning: #f59e0b;
  --text: #0f172a;          /* Sötét szöveg a tökéletes olvashatóságért */
  --text-muted: #64748b;    /* Halványabb másodlagos szöveg */
  --border: #dcdfdc;        /* Világos szegélyek */
}

body { font-family: 'Segoe UI', system-ui, -apple-system, sans-serif; background: var(--bg); color: var(--text); min-height: 100vh; line-height: 1.6; margin: 0; }
.login-screen { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: linear-gradient(135deg, var(--primary) 0%, var(--success) 100%); }
.login-box { background: var(--surface); padding: 40px; border-radius: 20px; width: 100%; max-width: 420px; box-shadow: 0 20px 40px rgba(0,0,0,0.06); border: 1px solid var(--border); }
.login-box h1 { text-align: center; margin-bottom: 8px; font-size: 1.8rem; color: var(--primary); }
.login-box .subtitle { text-align: center; color: var(--text-muted); margin-bottom: 30px; font-size: .9rem; }
.app-container { display: none; }
.app-container.active { display: flex; flex-direction: column; min-height: 100vh; }
.top-nav { background: var(--surface); border-bottom: 1px solid var(--border); padding: 0 30px; display: flex; align-items: center; justify-content: space-between; height: 64px; position: sticky; top: 0; z-index: 100; }
.nav-brand { font-size: 1.3rem; font-weight: 700; color: var(--primary); }
.nav-links { display: flex; gap: 5px; }
.nav-link { padding: 8px 16px; border-radius: 8px; cursor: pointer; border: none; background: transparent; color: var(--text-muted); font-size: .9rem; font-weight: 600; transition: all .2s; display: flex; align-items: center; gap: 6px; }
.nav-link:hover { background: var(--surface-light); color: var(--text); }
.nav-link.active { background: rgba(2,102,52,0.08); color: var(--primary); }
.nav-user { display: flex; align-items: center; gap: 12px; }
.user-badge { padding: 4px 12px; border-radius: 20px; font-size: .75rem; font-weight: 700; text-transform: uppercase; }
.badge-admin { background: rgba(245,158,11,0.12); color: var(--warning); border: 1px solid rgba(245,158,11,0.25); }
.badge-user { background: rgba(61,164,53,0.12); color: var(--success); border: 1px solid rgba(61,164,53,0.25); }
.btn-logout { padding: 6px 14px; border-radius: 8px; border: 1px solid var(--border); background: transparent; color: var(--text-muted); cursor: pointer; font-size: .85rem; transition: all .2s; }
.btn-logout:hover { border-color: var(--danger); color: var(--danger); background: rgba(239,68,68,0.05); }
.main-content { flex: 1; padding: 30px; max-width: 1200px; width: 100%; margin: 0 auto; }
.page { display: none; }
.page.active { display: block; animation: fadeIn .3s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
h2 { font-size: 1.5rem; margin-bottom: 20px; color: var(--text); }
h3 { font-size: 1.1rem; margin: 25px 0 15px; color: var(--text); }
.card { background: var(--surface); border-radius: 16px; padding: 24px; border: 1px solid var(--border); margin-bottom: 20px; box-shadow: 0 4px 6px -1px rgba(0,0,0,0.02); }
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.card-title { font-size: 1.1rem; font-weight: 700; }
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; margin-bottom: 24px; }
.stat-card { background: var(--surface); border-radius: 14px; padding: 20px; border: 1px solid var(--border); text-align: center; }
.stat-value { font-size: 2rem; font-weight: 800; color: var(--primary); line-height: 1; }
.stat-label { font-size: .8rem; color: var(--text-muted); margin-top: 8px; text-transform: uppercase; letter-spacing: .5px; }
.form-group { margin-bottom: 18px; }
label { display: block; margin-bottom: 6px; font-size: .85rem; font-weight: 600; color: var(--text-muted); text-transform: uppercase; letter-spacing: .3px; }
input, select, textarea { width: 100%; padding: 12px 14px; border-radius: 10px; border: 1px solid var(--border); background: var(--surface); color: var(--text); font-size: .95rem; transition: all .2s; font-family: inherit; box-sizing: border-box; }
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(2,102,52,0.12); }
select option { background: var(--surface); color: var(--text); }
textarea { resize: vertical; min-height: 80px; }
.form-row { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 16px; }
.btn { padding: 12px 20px; border-radius: 10px; border: none; font-size: .9rem; font-weight: 700; cursor: pointer; transition: all .2s; display: inline-flex; align-items: center; justify-content: center; gap: 8px; }
.btn-primary { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); color: #fff; box-shadow: 0 4px 12px rgba(2,102,52,0.18); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(2,102,52,0.25); }
.btn-success { background: linear-gradient(135deg, var(--success), #2d8227); color: #fff; }
.btn-success:hover { transform: translateY(-1px); }
.btn-danger { background: linear-gradient(135deg, var(--danger), #dc2626); color: #fff; }
.btn-danger:hover { transform: translateY(-1px); }
.btn-secondary { background: var(--surface-light); color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover { background: var(--border); }
.btn-sm { padding: 8px 14px; font-size: .8rem; }
.btn-block { width: 100%; }
.btn:disabled { opacity: .5; cursor: not-allowed; transform: none!important; }
.days-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.day-chip { padding: 12px 4px; text-align: center; border-radius: 10px; border: 1px solid var(--border); cursor: pointer; transition: all .2s; font-weight: 600; font-size: .85rem; background: var(--surface); color: var(--text); user-select: none; }
.day-chip:hover { border-color: var(--primary); background: var(--surface-light); }
.day-chip.selected { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); border-color: var(--primary); color: #fff; }
.data-table { width: 100%; border-collapse: collapse; font-size: .9rem; }
.data-table th { text-align: left; padding: 12px 16px; color: var(--text-muted); font-weight: 600; text-transform: uppercase; font-size: .75rem; letter-spacing: .5px; border-bottom: 1px solid var(--border); }
.data-table td { padding: 14px 16px; border-bottom: 1px solid var(--border); color: var(--text); }
.data-table tr:hover td { background: rgba(2,102,52,0.03); }
.data-table tr:last-child td { border-bottom: none; }
.spot-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 16px; }
.spot-card { background: var(--surface); border-radius: 14px; padding: 20px; border: 1px solid var(--border); transition: all .2s; position: relative; overflow: hidden; box-shadow: 0 2px 4px rgba(0,0,0,0.01); }
.spot-card:hover { transform: translateY(-2px); border-color: rgba(2,102,52,0.3); box-shadow: 0 8px 16px rgba(0,0,0,0.04); }
.spot-card::before { content: ''; position: absolute; top: 0; left: 0; width: 3px; height: 100%; background: linear-gradient(to bottom, var(--primary), var(--primary-dark)); }
.spot-card.booked-by-me { border-color: var(--warning); }
.spot-card.booked-by-me::before { background: var(--warning); }
.spot-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.spot-title { font-weight: 700; font-size: 1.1rem; }
.spot-badge { padding: 3px 10px; border-radius: 20px; font-size: .7rem; font-weight: 700; text-transform: uppercase; }
.badge-a { background: rgba(239,68,68,0.08); color: #dc2626; border: 1px solid rgba(239,68,68,0.2); }
.badge-b { background: rgba(37,99,235,0.08); color: #2563eb; border: 1px solid rgba(37,99,235,0.2); }
.spot-info { color: var(--text-muted); font-size: .9rem; margin-bottom: 4px; }
.spot-info strong { color: var(--text); }
.days-tags { display: flex; flex-wrap: wrap; gap: 5px; margin: 10px 0; }
.day-tag { padding: 3px 8px; border-radius: 6px; font-size: .75rem; background: rgba(2,102,52,0.06); color: var(--primary); border: 1px solid rgba(2,102,52,0.15); }
.day-tag.booked { background: rgba(61,164,53,0.08); color: var(--success); border-color: rgba(61,164,53,0.18); }
.status-badge { padding: 2px 8px; border-radius: 6px; font-size: .7rem; font-weight: 700; }
.status-available { background: rgba(61,164,53,0.12); color: var(--success); }
.status-my-booking { background: rgba(245,158,11,0.12); color: var(--warning); }
.empty-state { text-align: center; padding: 50px 20px; color: var(--text-muted); }
.empty-state-icon { font-size: 3rem; margin-bottom: 16px; opacity: .5; }
.toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 1000; display: flex; flex-direction: column; gap: 8px; }
.toast { padding: 14px 22px; border-radius: 12px; color: #fff; font-weight: 600; font-size: .9rem; box-shadow: 0 8px 24px rgba(0,0,0,0.12); transform: translateX(400px); transition: transform .4s cubic-bezier(0.175,0.885,0.32,1.275); max-width: 360px; }
.toast.show { transform: translateX(0); }
.toast-success { background: linear-gradient(135deg, var(--success), #2d8227); }
.toast-error { background: linear-gradient(135deg, var(--danger), #dc2626); }
.toast-info { background: linear-gradient(135deg, var(--primary), var(--primary-dark)); }
.modal-overlay { position: fixed; inset: 0; background: rgba(15,23,42,0.3); backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; z-index: 200; padding: 20px; }
.modal-overlay.active { display: flex; }
.modal-box { background: var(--surface); border-radius: 20px; padding: 30px; width: 100%; max-width: 500px; max-height: 90vh; overflow-y: auto; border: 1px solid var(--border); box-shadow: 0 25px 50px -12px rgba(0,0,0,0.08); }
.modal-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.modal-title { font-size: 1.2rem; font-weight: 700; }
.modal-close { background: none; border: none; color: var(--text-muted); font-size: 1.5rem; cursor: pointer; line-height: 1; }
.modal-close:hover { color: var(--text); }
.csv-preview { background: var(--surface-light); border-radius: 10px; padding: 16px; font-family: 'Consolas', monospace; font-size: .8rem; overflow-x: auto; white-space: pre; color: var(--text); border: 1px dashed var(--border); max-height: 200px; overflow-y: auto; }
.file-input-wrapper { position: relative; overflow: hidden; display: inline-block; width: 100%; }
.file-input-wrapper input[type=file] { position: absolute; left: 0; top: 0; opacity: 0; width: 100%; height: 100%; cursor: pointer; }
.info-box { background: rgba(2,102,52,0.04); border: 1px solid rgba(2,102,52,0.12); border-radius: 10px; padding: 14px 18px; margin-bottom: 20px; font-size: .9rem; color: var(--text-muted); }
.info-box strong { color: var(--primary); }
.booking-info { background: rgba(61,164,53,0.05); border: 1px solid rgba(61,164,53,0.15); border-radius: 10px; padding: 14px 18px; margin: 12px 0; font-size: .9rem; }
.booking-info strong { color: var(--success); }
.profile-header { display: flex; align-items: center; gap: 20px; margin-bottom: 24px; }
.avatar { width: 72px; height: 72px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--primary-dark)); display: flex; align-items: center; justify-content: center; font-size: 1.8rem; font-weight: 700; color: #fff; flex-shrink: 0; }
.profile-name { font-size: 1.3rem; font-weight: 700; }
.profile-email { color: var(--text-muted); font-size: .9rem; }

@media(max-width: 768px) {
  .top-nav { padding: 0 15px; flex-wrap: wrap; height: auto; min-height: 64px; }
  .nav-links { gap: 2px; }
  .nav-link { padding: 6px 10px; font-size: .8rem; }
  .main-content { padding: 20px 15px; }
  .days-grid { grid-template-columns: repeat(4, 1fr); }
  .form-row { grid-template-columns: 1fr; }
  .spot-grid { grid-template-columns: 1fr; }
}

/* ÚJ DAY-TAG DIZÁJN IDŐJÁRÁSSAL */
.day-tag-wrapper { 
    display: inline-flex; 
    flex-direction: column; 
    align-items: center; 
    justify-content: center; 
    padding: 8px 12px; 
    border-radius: 10px; 
    line-height: 1.3; 
    border: 1px solid var(--border); 
    background: var(--surface); 
    font-family: inherit;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1); 
}
.day-tag-wrapper .day-date { 
    font-weight: 700; 
    font-size: 0.8rem;
}
.day-tag-wrapper .weather-info { 
    font-size: 0.95rem; 
    margin-top: 4px; 
    display: flex;
    align-items: center;
    gap: 4px;
}
.day-tag-wrapper .weather-info .temp {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
}

/* Állapotok formázása */
.day-tag-wrapper.bookable { 
    cursor: pointer; 
    background: rgba(2,102,52,0.03); 
    color: var(--primary); 
    border-color: rgba(2,102,52,0.15); 
}
.day-tag-wrapper.bookable:hover { 
    background: linear-gradient(135deg, var(--primary), var(--primary-dark)); 
    color: #fff; 
    transform: translateY(-2px); 
    box-shadow: 0 4px 12px rgba(2,102,52,0.2); 
    border-color: transparent;
}
.day-tag-wrapper.bookable:hover .temp { color: rgba(255,255,255,0.8); }

.day-tag-wrapper.booked { 
    background: rgba(61,164,53,0.08); 
    color: var(--success); 
    border-color: rgba(61,164,53,0.18); 
    cursor: default; 
}
.day-tag-wrapper.disabled { 
    opacity: 0.55; 
    cursor: not-allowed; 
    background: var(--surface-light); 
}
.day-tag-wrapper.disabled .day-date {
    text-decoration: line-through; 
}
.day-tag-wrapper.my-offer { 
    background: var(--surface-light); 
    color: var(--text-muted); 
    cursor: default; 
}

/* FULLCALENDAR TESTRESZABÁS */
.fc { font-family: inherit; }
.fc-toolbar-title { font-size: 1.25rem !important; color: var(--text); font-weight: 800; text-transform: capitalize; }
.fc-button-primary { background-color: var(--surface-light) !important; color: var(--text) !important; border-color: var(--border) !important; text-transform: capitalize; font-weight: 600 !important; }
.fc-button-primary:hover { background-color: var(--border) !important; color: var(--text) !important; }
.fc-button-primary:not(:disabled):active, .fc-button-primary:not(:disabled).fc-button-active { background-color: var(--primary) !important; color: #fff !important; border-color: var(--primary) !important; }
.fc-event { border-radius: 6px; padding: 3px 6px; border: none; font-size: 0.75rem; font-weight: 600; box-shadow: 0 1px 3px rgba(0,0,0,0.1); cursor: default; transition: transform 0.2s; margin-bottom: 3px;}
.fc-event:hover { transform: scale(1.02); }
.fc-day-today { background: rgba(2, 102, 52, 0.03) !important; }
.fc-daygrid-day-number { font-weight: 600; color: var(--text-muted); }