:root{
  /* Monochrome / Black theme */
  --color-primary:#000000;
  --color-accent:#ffffff;
  --bg:#000000; /* black background */
  --text:#ffffff; /* white text */
  --muted:#bdbdbd;
  --card:rgba(255,255,255,0.04);
  --radius:12px;
  --shadow:0 8px 30px rgba(0,0,0,0.6);
  --container:1400px;
}

/* Base */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{height:100%;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial;color:var(--text);background:var(--bg)}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.small-muted{color:var(--muted);font-size:13px}

/* Header */
.site-header{border-bottom:1px solid rgba(255,255,255,0.04);background:#000;position:fixed;top:0;left:0;right:0;z-index:110}
.header-inner{display:flex;justify-content:space-between;align-items:center;height:72px;gap:20px;padding:0 20px}
.main-nav-horizontal ul{display:flex;list-style:none;margin:0;padding:0;gap:24px;align-items:center}
.main-nav-horizontal ul li{margin:0}
.main-nav-horizontal ul li a{color:var(--color-accent);text-decoration:none;font-weight:500;transition:opacity 0.2s}
.main-nav-horizontal ul li a:hover{opacity:0.7}
#mainNavRight{display:flex;justify-content:flex-end}
#mainNavRight ul{justify-content:flex-end}
.menu-btn{padding:8px;border-radius:8px;border:0;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));cursor:pointer;color:#fff}
.menu-btn svg rect{fill:#fff}

/* profile menu */
.profile-menu{position:absolute;right:18px;top:64px;background:#0b0b0b;border-radius:8px;box-shadow:0 8px 30px rgba(2,6,23,0.6);padding:8px;display:flex;flex-direction:column;gap:6px;z-index:120;color:var(--color-accent)}
.profile-menu a{padding:8px 10px;border-radius:8px;color:var(--color-accent);text-decoration:none}
.profile-menu a:hover{background:rgba(255,255,255,0.04);color:#ffffff}
.profile-menu.hidden{display:none}
.menu-dropdown{position:absolute;left:20px;top:72px;background:#0b0b0b;border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,0.8);padding:12px;width:220px;z-index:80;color:var(--color-accent)}
.menu-dropdown{position:absolute;right:20px;top:72px;background:#0b0b0b;border-radius:10px;box-shadow:0 10px 40px rgba(0,0,0,0.8);padding:12px;width:220px;z-index:80;color:var(--color-accent)}
.menu-dropdown.hidden{display:none}
.hidden{display:none !important}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:10px;background:#00CED1;color:#fff;font-weight:700;font-size:18px}
.icon-btn{background:transparent;border:0;padding:8px;cursor:pointer;color:#fff}
.icon-btn.btn-primary{background:linear-gradient(90deg,var(--color-primary),var(--color-accent));border-radius:10px;color:#fff}
.btn{padding:8px 12px;border-radius:10px;border:1px solid rgba(255,255,255,0.08);background:transparent;cursor:pointer;font-weight:600;color:var(--color-accent);transition:all 160ms ease}
.btn-primary{background:#00CED1;color:#ffffff;border-color:transparent;box-shadow:0 2px 4px rgba(0,206,209,0.2);font-weight:600}
.btn-primary:hover{transform:translateY(-1px);background:#00B4B8;box-shadow:0 4px 8px rgba(0,206,209,0.3)}
.btn-outline{border:1px solid #e0e0e0;color:#000;background:#fff;font-weight:600}
.btn-outline:hover{background:#f5f5f5;border-color:#ccc}
.btn-ghost{background:#f8f9fa;border:1px solid #e0e0e0;color:#666;font-weight:500}
.btn-ghost:hover{background:#e9ecef;color:#333}

/* Кнопки в админке должны быть контрастными */
.admin-main .btn-primary{background:#00CED1;color:#fff;border:none}
.admin-main .btn-outline{border:1px solid #00CED1;color:#00CED1;background:#fff}
.admin-main .btn-outline:hover{background:#e0f7f8;border-color:#00B4B8}
.admin-main .btn-ghost{background:#fff;border:1px solid #ddd;color:#666}
.admin-main .btn-ghost:hover{background:#f5f5f5;color:#333}

/* Кнопки в ЛК */
#accountOverlay .btn-primary{background:#00CED1;color:#fff;border:none}
#accountOverlay .btn-outline{border:1px solid #00CED1;color:#00CED1;background:#fff}
#accountOverlay .btn-outline:hover{background:#e0f7f8}
#accountOverlay .btn-ghost{background:#fff;border:1px solid #ddd;color:#666}
#accountOverlay .btn-ghost:hover{background:#f5f5f5}

/* Center logout button styling */
#logoutCenter{padding:8px 14px;border-radius:10px;border:0;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));color:#fff;cursor:pointer;margin:0 auto}

/* Make account sidebar use admin panel palette */
#accountSidebar{background:linear-gradient(180deg,var(--color-primary),var(--color-accent));color:#fff}

/* Ensure account overlay main area readable (use light panel like admin) */
#accountOverlay .admin-main{background:#ffffff;color:#000}
#accountOverlay .admin-main .admin-content, #accountOverlay .admin-main *{color:#000}
#accountOverlay .admin-content{background:#ffffff;color:#000}

/* make card images in account overlay a bit more compact to match LK */
#accountOverlay .vac-card-image{height:160px}

/* Hero */
.hero{position:relative;margin:0;border-radius:0;overflow:hidden;box-shadow:none}
.hero, .section { width:100vw; position:relative; left:50%; right:50%; margin-left:-50vw; margin-right:-50vw; }
.hero-media{min-height:calc(100vh - 72px);overflow:hidden;position:relative}
.hero-media img{width:100%;height:100%;object-fit:cover;object-position:left center;display:block}
.hero-slogan{font-size:48px;margin:0;font-weight:800;line-height:1.1}
/* hero buttons — larger CTAs */
.btn-hero{padding:12px 18px;font-size:15px;border-radius:12px}
/* unread dot used for nav indicators */
.unread-dot{display:inline-block;width:8px;height:8px;background:#ff4444;border-radius:50%;margin-left:8px;vertical-align:middle}

/* Sections: full viewport stacked blocks */
.section{padding:20px 0;border-bottom:none;min-height:calc(100vh - 72px);display:flex;flex-direction:column;justify-content:flex-start;align-items:stretch}
.section > h2 { margin: 12px 20px 6px; font-size:36px;font-weight:700; }
.section .muted, .section p.muted { margin: 0 20px 12px; font-size:16px; }

/* Section header with buttons (flex layout) */
.section-header-with-buttons{display:flex;justify-content:space-between;align-items:center;margin:12px 20px 6px;flex-wrap:wrap;gap:12px}
.section-header-with-buttons h2{margin:0}

/* Students, Companies, Startups buttons - white with black text (like btn-overlay) */
#students .btn-primary, #companies .btn-primary, #startups .btn-primary{
  background:#ffffff;
  color:#000000;
  border:0;
  box-shadow:0 2px 4px rgba(255,255,255,0.2);
  font-weight:600;
}
#students .btn-primary:hover, #companies .btn-primary:hover, #startups .btn-primary:hover{
  transform:translateY(-2px);
  background:#f5f5f5;
  box-shadow:0 4px 12px rgba(255,255,255,0.3);
}

/* Students buttons consistent */
#students .btn{min-width:170px;display:inline-flex;align-items:center;justify-content:center}
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;align-items:start;margin-top:48px}
.cards-grid img{width:100%;height:auto;display:block;border-radius:8px}
.card{background:transparent;padding:0;border-radius:10px;box-shadow:none}

/* Card with overlay button */
.card-with-overlay{position:relative}
.card-image-wrapper{position:relative;overflow:hidden;border-radius:12px}
.card-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent);padding:20px;display:flex;justify-content:center;align-items:flex-end;opacity:0;transition:opacity 0.3s ease}
.card-with-overlay:hover .card-overlay{opacity:1}
.content-card:hover .card-overlay{opacity:1}
.btn-overlay{padding:10px 24px;background:#ffffff;color:#000000;border-radius:8px;text-decoration:none;font-weight:600;transition:all 0.2s ease;border:0;cursor:pointer}
.btn-overlay:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(255,255,255,0.2)}

/* Overlay title for cards (centered) */
.card-overlay-title{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:22px;font-weight:700;text-align:center;z-index:2;text-shadow:0 2px 12px rgba(0,0,0,0.9);width:85%;line-height:1.3;pointer-events:none}

/* Content cards grid */
.cards-grid-content{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:1200px;margin:48px auto 20px;padding:0 20px}
.content-card{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);border-radius:12px;padding:0;overflow:hidden;transition:transform 0.2s ease;position:relative}
.content-card:hover{transform:translateY(-4px)}
.content-card h3{padding:0 20px;margin:0 0 12px;font-size:18px;font-weight:700}
.content-card p{padding:0 20px 20px;margin:0}
.content-card .card-image-wrapper{position:relative;overflow:hidden;border-radius:12px 12px 0 0}
.content-card .card-detail-text{display:none}

/* News grid */
.news-grid{display:flex;gap:20px;max-width:1400px;margin:48px auto 20px;padding:0 20px;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scroll-snap-type:x mandatory}
.news-grid::-webkit-scrollbar{height:8px}
.news-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}
.news-grid::-webkit-scrollbar-thumb{background:#00CED1;border-radius:10px}
.news-grid::-webkit-scrollbar-thumb:hover{background:#00B4B8}
.news-card{background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.04);border-radius:12px;overflow:hidden;transition:all 0.3s ease;cursor:pointer;display:flex;flex-direction:column;min-width:400px;max-width:400px;flex-shrink:0;scroll-snap-align:start}
.news-card:hover{transform:translateY(-4px);border-color:rgba(255,255,255,0.12)}
.news-cover{width:100%;height:240px;object-fit:cover;display:block}
.news-content{padding:20px;flex:1;display:flex;flex-direction:column}
.news-date{color:var(--muted);font-size:13px;margin-bottom:8px}
.news-title{font-size:20px;font-weight:700;margin:0 0 12px;line-height:1.3}
.news-excerpt{color:var(--muted);font-size:14px;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.news-read-more{margin-top:auto;padding-top:12px;color:var(--color-accent);font-weight:600;font-size:14px}

/* News modal (article view) */
.news-modal-content{max-width:800px;margin:0 auto}
.news-modal-cover{width:100%;max-height:400px;object-fit:cover;border-radius:12px;margin-bottom:24px}
.news-modal-title{font-size:32px;font-weight:700;margin:0 0 12px;line-height:1.2}
.news-modal-date{color:var(--muted);font-size:14px;margin-bottom:24px}
.news-modal-text{font-size:16px;line-height:1.7;color:var(--color-accent);white-space:pre-wrap;margin-bottom:24px}
.news-modal-images{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:24px}
.news-modal-images img{width:100%;height:200px;object-fit:cover;border-radius:8px}

/* News fullscreen overlay (полноэкранный просмотр статьи) */
.news-fullscreen-overlay{position:fixed;inset:0;background:#ffffff;z-index:300;display:flex;flex-direction:column;overflow:hidden}
.news-fullscreen-overlay.hidden{display:none}

.news-fullscreen-container{width:100%;height:100%;display:flex;flex-direction:column;overflow-y:auto}

/* Header с кнопками навигации и шаринга */
.news-fullscreen-header{position:sticky;top:0;left:0;right:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,0.06);padding:12px 24px;display:flex;justify-content:space-between;align-items:center;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,0.04)}

.news-back-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:transparent;border:1px solid rgba(0,0,0,0.1);border-radius:24px;color:#000;font-weight:600;font-size:15px;cursor:pointer;transition:all 0.2s ease}
.news-back-btn:hover{background:#f5f5f5;border-color:rgba(0,0,0,0.2);transform:translateX(-2px)}
.news-back-btn svg{width:20px;height:20px}

.news-share-buttons{display:flex;align-items:center;gap:12px}

.news-share-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f5f5f5;border:1px solid rgba(0,0,0,0.06);border-radius:20px;color:#000;font-weight:500;font-size:14px;cursor:pointer;transition:all 0.2s ease}
.news-share-btn:hover{background:#e8e8e8;border-color:rgba(0,0,0,0.12);transform:translateY(-1px)}
.news-share-btn svg{width:18px;height:18px}

.news-close-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid rgba(0,0,0,0.08);border-radius:50%;color:#000;cursor:pointer;transition:all 0.2s ease;padding:0}
.news-close-btn:hover{background:#f5f5f5;border-color:rgba(0,0,0,0.15)}
.news-close-btn svg{width:20px;height:20px}

/* Контент статьи */
.news-fullscreen-article{flex:1;width:100%;background:#ffffff;color:#000;overflow-y:auto}

.news-fullscreen-content{max-width:900px;margin:0 auto;padding:0;width:100%}

/* Обложка статьи */
.news-cover-container{width:100%;max-height:600px;overflow:hidden;background:#f5f5f5;margin-bottom:40px}
.news-fullscreen-cover{width:100%;height:100%;object-fit:cover;display:block;cursor:pointer;transition:transform 0.3s ease}
.news-fullscreen-cover:hover{transform:scale(1.02)}

/* Тело статьи */
.news-article-body{padding:0 48px 60px;max-width:800px;margin:0 auto}

.news-article-title{font-size:42px;font-weight:800;line-height:1.2;color:#000;margin:0 0 20px;letter-spacing:-0.02em}

.news-article-meta{display:flex;align-items:center;gap:16px;margin-bottom:32px;padding-bottom:20px;border-bottom:1px solid rgba(0,0,0,0.08)}

.news-article-date{color:#666;font-size:15px;font-weight:500}

.news-article-text{font-size:18px;line-height:1.8;color:#1a1a1a;white-space:pre-wrap;margin-bottom:48px;letter-spacing:0.01em}

/* Галерея дополнительных изображений */
.news-fullscreen-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:48px}

.news-gallery-image{width:100%;height:320px;object-fit:cover;border-radius:12px;cursor:pointer;transition:all 0.3s ease;box-shadow:0 4px 12px rgba(0,0,0,0.08)}
.news-gallery-image:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.15)}

/* Responsive */
@media (max-width:768px){
  .news-grid{padding:0 10px;gap:12px}
  .news-card{min-width:280px;max-width:280px}
  .news-fullscreen-header{padding:10px 16px}
  .news-back-btn span{display:none}
  .news-back-btn{padding:10px}
  .news-share-btn span{display:none}
  .news-share-btn{padding:10px;border-radius:50%;width:40px;height:40px;justify-content:center}
  .news-article-body{padding:0 24px 40px}
  .news-article-title{font-size:32px;margin-bottom:16px}
  .news-article-text{font-size:16px;line-height:1.7}
  .news-fullscreen-gallery{grid-template-columns:1fr;gap:16px}
  .news-gallery-image{height:240px}
}

.vacancies-list{display:grid;grid-template-columns:repeat(4, 1fr);gap:18px;width:100%;max-width:1400px}
/* Make vacancies and community tasks responsive and span rows of photos */
#vacancies .vacancies-list, #communityTasksListWrap{display:grid;grid-template-columns:repeat(4, 1fr);gap:18px;max-width:1400px}
.vacancy-card{background:var(--card);border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.04);box-shadow:0 6px 18px rgba(0,0,0,0.35);display:flex;flex-direction:column;min-height:320px;height:100%}
.vac-card-image{height:160px;overflow:hidden;position:relative;background:rgba(255,255,255,0.02)}
.vac-card-image img{width:100%;height:100%;object-fit:cover;display:block}
.vac-card-badge{position:absolute;left:12px;top:12px;background:rgba(0,0,0,0.7);color:#fff;padding:6px 10px;border-radius:6px}
.vac-content{padding:16px;flex:1;display:flex;flex-direction:column;justify-content:space-between}
.vac-title{font-weight:700}
.vac-short{color:var(--muted);margin-top:8px}
.card-actions{display:flex;gap:8px;margin-top:12px}

/* Task */
.task-card{background:var(--card);border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,0.04);box-shadow:0 6px 18px rgba(0,0,0,0.35);display:flex;flex-direction:column;min-height:320px;height:100%}
.task-img{width:100%;height:160px;object-fit:cover;display:block;background:transparent;flex-shrink:0}
.task-content{padding:16px;flex:1;display:flex;flex-direction:column;justify-content:space-between}

/* Modal */
.modal{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(2,6,23,0.45);z-index:220}
.modal.hidden{display:none}
.modal-inner{background:#0b0b0b;border-radius:12px;padding:20px;max-width:920px;width:95%;max-height:85vh;overflow-y:auto;position:relative;color:var(--color-accent)}
.modal-close{position:absolute;right:12px;top:12px;border:0;background:transparent;font-size:18px;cursor:pointer;color:#fff}
.modal-form .form-row{margin-bottom:10px;display:flex;flex-direction:column}
.modal-form label{font-weight:600;margin-bottom:6px}
.modal-form input, .modal-form textarea, .modal-form select{padding:8px;border-radius:8px;border:1px solid #eef2ff}

/* Toast */
.toast{position:fixed;right:20px;bottom:20px;background:#111;color:#fff;padding:10px 14px;border-radius:8px;box-shadow:var(--shadow)}
.toast.hidden{display:none}

/* Footer */
.site-footer{background:rgba(255,255,255,0.02);border-top:1px solid rgba(255,255,255,0.04);padding:64px 0 40px;margin-top:80px}
.footer-content{max-width:1200px;margin:0 auto;padding:0 20px}
.footer-columns{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-bottom:48px}
.footer-column h3{font-size:16px;font-weight:700;margin:0 0 16px;color:var(--text)}
.footer-column p{margin:8px 0;color:var(--muted);font-size:14px;line-height:1.6}
.footer-column ul{list-style:none;margin:0;padding:0}
.footer-column ul li{margin:8px 0}
.footer-column ul li a{color:var(--muted);text-decoration:none;font-size:14px;transition:color 0.2s ease}
.footer-column ul li a:hover{color:var(--text)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:24px;color:var(--muted);font-size:14px;text-align:center}

/* FAQ Accordion */
#faq{background:#ffffff;color:#000;padding:80px 20px}
#faq h2{color:#000}
#faq p.muted{color:#666}
.faq-container{max-width:800px;margin:0 auto;padding:24px 0;color:#000}
.faq-item{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:12px;margin-bottom:16px;overflow:hidden;transition:all 0.3s ease}
.faq-item:hover{background:#ffffff;border-color:#00CED1;box-shadow:0 4px 12px rgba(0,206,209,0.1)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;cursor:pointer;user-select:none}
.faq-question h3{margin:0;font-size:18px;font-weight:600;color:#000;flex:1;padding-right:16px}
.faq-toggle{background:transparent;border:none;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all 0.3s ease;flex-shrink:0}
.faq-toggle:hover{background:rgba(0,206,209,0.1)}
.faq-icon{width:24px;height:24px;transition:transform 0.3s ease;stroke:#00CED1;stroke-width:2}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease}
.faq-item.open .faq-answer{max-height:1000px;padding:0 24px 20px 24px}
.faq-answer p{margin:0;color:#333;line-height:1.7;font-size:15px}

/* Admin overlay (fullscreen like news) */
.admin-overlay{position:fixed;inset:0;background:#ffffff;z-index:300;display:flex;flex-direction:column;overflow:hidden}
.admin-overlay.hidden{display:none}

/* Admin fullscreen container */
.admin-fullscreen-container{width:100%;height:100%;display:flex;flex-direction:column;overflow-y:auto}

/* Admin fullscreen header */
.admin-fullscreen-header{position:sticky;top:0;left:0;right:0;background:rgba(255,255,255,0.98);backdrop-filter:blur(10px);border-bottom:1px solid rgba(0,0,0,0.06);padding:12px 24px;display:flex;justify-content:space-between;align-items:center;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,0.04)}

.admin-back-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;background:transparent;border:1px solid rgba(0,0,0,0.1);border-radius:24px;color:#000;font-weight:600;font-size:15px;cursor:pointer;transition:all 0.2s ease}
.admin-back-btn:hover{background:#f5f5f5;border-color:rgba(0,0,0,0.2);transform:translateX(-2px)}
.admin-back-btn svg{width:20px;height:20px}

.admin-sidebar{width:260px;background:#0b0b0b;color:#fff;padding:20px;display:flex;flex-direction:column;gap:20px;border-right:1px solid rgba(0,0,0,0.08)}
.admin-logo{width:52px;height:52px;border-radius:10px;background:#fff;color:#000;display:flex;align-items:center;justify-content:center;font-weight:800}
.admin-nav{display:flex;flex-direction:column;gap:8px}
.admin-nav-item{display:flex;align-items:center;gap:10px;background:transparent;border:0;color:#ddd;padding:10px;border-radius:8px;text-align:left;cursor:pointer}
.admin-nav-item svg{width:18px;height:18px;opacity:0.7}
.admin-nav-item:hover{background:rgba(255,255,255,0.04);color:#fff}
.admin-nav-item.active{background:linear-gradient(90deg,var(--color-primary),var(--color-accent));color:#fff}

/* admin main */
.admin-main{flex:1;background:#ffffff;color:#000;padding:24px;display:flex;flex-direction:column;overflow:auto}
.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.search-input{padding:8px;border-radius:8px;border:1px solid #e6eef8;width:260px}
.admin-content{background:#ffffff;border-radius:12px;padding:24px;min-height:360px;overflow:auto;color:#000;max-width:1400px;margin:0 auto;width:100%}

/* Admin body wrapper */
.admin-body-wrapper{display:flex;flex:1;overflow:hidden;background:#f8f9fa}

/* Ensure admin/account main area text/icons contrast with white background */
.admin-main { color: #000; }
.admin-main h2, .admin-main h3, .admin-main h4 { color: #000; }
.admin-main p, .admin-main div, .admin-main span, .admin-main td, .admin-main th, .admin-main li { color: #000; }
#accountOverlay .admin-main { color: #000; }
#accountOverlay .admin-main p, #accountOverlay .admin-main div, #accountOverlay .admin-main span { color: #000; }
.admin-content { color: #000; }
.admin-content h3, .admin-content h4 { color: #000; }
.admin-content p, .admin-content div:not(.btn):not(.btn-primary):not(.btn-outline):not(.btn-ghost), .admin-content span { color: #000; }
.admin-content strong { color: #000; font-weight: 700; }
.admin-content label { color: #000; font-weight: 600; }

/* Make message text readable (darker) */
.admin-content .card { background: #f5f5f5; border: 1px solid #e0e0e0; }
.admin-content .card strong { color: #000; }
.admin-content .card p, .admin-content .card div:not(.btn) { color: #333; }
.admin-content .small-muted { color: #666; }

/* Admin sidebar should keep light-on-dark contrast */
.admin-sidebar, .admin-sidebar * { color: #fff; }
.admin-nav-item svg path, .admin-nav-item svg rect, .admin-nav-item svg circle { fill: currentColor; stroke: currentColor; }

/* Ensure buttons, inputs, and labels are readable */
.admin-main input, .admin-main textarea, .admin-main select { color: #000; background: #fff; border: 1px solid #e0e0e0; }
.admin-main label { color: #000; font-weight: 600; }
#accountOverlay input, #accountOverlay textarea, #accountOverlay select { color: #000; background: #fff; border: 1px solid #e0e0e0; }
#accountOverlay label { color: #000; font-weight: 600; }

/* Make community task images match vacancies sizing (prevents stretching) */
.task-img{width:100%;height:160px;object-fit:cover;border-radius:8px;background:transparent;flex-shrink:0}

/* Image upload drop zone styles */
.image-drop-zone{border:2px dashed #d0d0d0;border-radius:8px;padding:24px;text-align:center;margin-bottom:8px;background:#fafafa;cursor:pointer;transition:all 0.2s ease}
.image-drop-zone:hover{border-color:#00CED1;background:#f0f9fa}
.image-drop-zone svg{margin:0 auto 12px;display:block;opacity:0.4;color:#666}
.image-drop-zone p{margin:0;color:#666;font-size:14px;line-height:1.5}
.image-drop-zone small{color:#999;font-size:12px}

/* tables */
.users-table{width:100%;border-collapse:collapse}
.users-table thead th{padding:12px;text-align:left;border-bottom:1px solid #eef2ff;color:#6b7280;font-weight:600;font-size:13px}
.users-table tbody td{padding:12px;border-bottom:1px solid #f4f6f9;vertical-align:middle}
.form-input{padding:8px;border-radius:8px;border:1px solid #eef2ff}

/* Footer (dark) */
.site-footer-dark{background:#0b0b0b;color:#e6eef8;padding:48px 0 20px;border-top:1px solid rgba(255,255,255,0.04);margin-top:40px}
.footer-dark-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;align-items:start}
.footer-col{max-width:360px}
.footer-title{color:#ffffff;font-weight:700;letter-spacing:1px;text-transform:uppercase;margin:0 0 12px;font-size:15px}
.footer-desc{color:rgba(230,238,248,0.85);line-height:1.6;margin:0 0 8px;font-size:15px}
.footer-links{list-style:none;padding:0;margin:0;display:block}
.footer-links li{margin:8px 0}
.footer-contacts{list-style:none;padding:0;margin:0}
.footer-divider{height:1px;background:rgba(255,255,255,0.03);margin:18px 0}
.footer-bottom{padding:10px 0 28px;text-align:center}
.footer-bottom .muted{color:rgba(230,238,248,0.6);font-size:13px}

/* responsive */
/* Мобильные устройства (до 600px) */
@media (max-width:600px){
  /* Header */
  .site-header{height:60px}
  .header-inner{height:60px;padding:0 12px;gap:12px}
  body{padding-top:60px}
  .brand-mark{width:40px;height:40px;font-size:14px}
  .main-nav-horizontal ul{gap:12px;font-size:14px}
  
  /* Hero */
  .hero-slogan{font-size:28px;line-height:1.2}
  .btn-hero{padding:10px 16px;font-size:14px}
  .hero-media{min-height:calc(100vh - 60px)}
  
  /* Section spacing */
  .section{padding:16px 0;min-height:auto}
  .section > h2{font-size:24px;margin:12px 16px 6px}
  .section .muted, .section p.muted{margin:0 16px 12px;font-size:14px}
  .section-header-with-buttons{margin:12px 16px 6px;gap:8px}
  .section-header-with-buttons h2{font-size:24px}
  
  /* Cards */
  .cards-grid{grid-template-columns:1fr;gap:12px;margin-top:24px;padding:0 16px}
  .cards-grid-content{grid-template-columns:1fr;gap:12px;padding:0 16px;margin:24px auto 16px}
  #vacancies .vacancies-list, #communityTasksListWrap{grid-template-columns:1fr;gap:12px;padding:0 16px}
  .vacancy-card{min-height:auto}
  .task-card{min-height:auto}
  .vac-card-image{height:180px}
  .task-img{height:180px}
  .card-overlay{opacity:1}
  .card-overlay-title{font-size:18px;width:90%}
  .card-actions{flex-direction:column;gap:8px}
  .card-actions .btn{width:100%;justify-content:center}
  
  /* News */
  .news-grid{padding:0 16px;gap:12px;display:flex}
  .news-card{min-width:280px;max-width:100%;width:100%}
  .news-cover{height:200px}
  
  /* FAQ */
  #faq{padding:40px 16px}
  .faq-container{padding:16px 0}
  .faq-question{padding:16px 20px}
  .faq-question h3{font-size:16px}
  .faq-answer p{font-size:14px}
  
  /* Footer */
  .site-footer{padding:40px 0 24px;margin-top:40px}
  .footer-columns{grid-template-columns:1fr;gap:24px}
  .footer-dark-grid{grid-template-columns:1fr;gap:24px}
  
  /* Modal */
  .modal-inner{width:calc(100% - 24px);padding:16px;max-height:90vh}
  .modal-close{right:8px;top:8px;font-size:24px}
  
  /* Buttons */
  .btn{padding:10px 14px;font-size:14px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
  .btn-hero{font-size:14px}
  
  /* Forms */
  .modal-form input, .modal-form textarea, .modal-form select{font-size:16px;padding:10px;min-height:44px}
  
  /* Admin panel */
  .admin-sidebar{width:60px;padding:8px}
  .admin-sidebar .admin-title, .admin-sidebar .small-muted, .admin-nav-item span{display:none}
  .admin-nav-item{justify-content:center;padding:10px}
  .admin-logo{width:44px;height:44px;font-size:16px}
  .admin-overlay{padding:0}
  .admin-main{padding:12px}
  .admin-content{padding:16px}
  .admin-fullscreen-header{padding:8px 12px}
  .admin-back-btn span{display:none}
  .admin-back-btn{padding:8px}
  
  /* Account overlay */
  #accountOverlay .admin-sidebar{width:60px;padding:8px}
  #accountOverlay .admin-main{padding:12px}
  
  /* Chat */
  .chat-container{height:calc(100vh - 180px)}
  .chat-message{max-width:85%;font-size:13px}
  .chat-input-area{padding:8px 12px}
  .chat-input{font-size:16px;padding:10px 14px}
  .chat-send-btn{width:44px;height:44px}
  
  /* News fullscreen */
  .news-article-title{font-size:28px}
  .news-article-body{padding:0 20px 40px}
  .news-article-text{font-size:16px}
  
  /* Tables */
  .users-table{font-size:13px;display:block;overflow-x:auto}
  .users-table thead th, .users-table tbody td{padding:8px;font-size:12px}
}

/* Планшеты (601px - 900px) */
@media (min-width:601px) and (max-width:900px){
  /* Header */
  .header-inner{padding:0 16px}
  
  /* Hero */
  .hero-slogan{font-size:36px}
  
  /* Section */
  .section > h2{font-size:32px}
  .section-header-with-buttons h2{font-size:32px}
  
  /* Cards */
  .cards-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .cards-grid-content{grid-template-columns:repeat(2,1fr);gap:16px}
  #vacancies .vacancies-list, #communityTasksListWrap{grid-template-columns:repeat(2, 1fr);gap:16px}
  .vac-card-image{height:160px}
  .task-img{height:160px}
  
  /* News */
  .news-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  
  /* Footer */
  .footer-columns{grid-template-columns:repeat(2,1fr)}
  .footer-dark-grid{grid-template-columns:repeat(2,1fr)}
  
  /* Admin */
  .admin-sidebar{width:70px;padding:12px}
  .admin-sidebar .admin-title, .admin-sidebar .small-muted, .admin-nav-item span{display:none}
  .admin-nav-item{justify-content:center;padding:12px}
  .admin-main{padding:16px}
  .card-overlay{opacity:1}
}

/* Средние экраны (901px - 1200px) */
@media (min-width:901px) and (max-width:1200px){
  #vacancies .vacancies-list, #communityTasksListWrap{grid-template-columns:repeat(3, 1fr);}
  .cards-grid-content{grid-template-columns:repeat(2,1fr)}
  .news-grid{grid-template-columns:repeat(2,1fr)}
  .cards-grid{grid-template-columns:repeat(3,1fr)}
}

/* Большие экраны (от 901px) */
@media (min-width:901px){
  .section{min-height:calc(100vh - 72px)}
}

/* Очень маленькие экраны (до 400px) */
@media (max-width:400px){
  .hero-slogan{font-size:24px}
  .section > h2, .section-header-with-buttons h2{font-size:20px}
  .news-card{min-width:100%}
  .btn{font-size:13px;padding:6px 10px}
  .modal-inner{padding:12px}
  .faq-question{padding:12px 16px}
  .faq-question h3{font-size:15px}
}

/* main nav inline styles */
.main-nav ul{display:flex;gap:14px;align-items:center;list-style:none;padding:0;margin:0}
.main-nav ul li a{display:inline-block;padding:8px 6px;color:var(--color-accent);text-decoration:none;border-radius:8px}
.main-nav ul li a:hover{background:rgba(255,255,255,0.04)}

/* adjust page content so header does not overlap */
main#main{padding-top:20px}
body{padding-top:72px}

/* Скрываем навигацию на мобильных только если нужно */
@media (max-width:768px){
  .main-nav-horizontal ul{gap:8px;font-size:13px}
  .main-nav-horizontal ul li a{padding:6px 4px}
}

/* Telegram-style chat */
.chat-container{display:flex;flex-direction:column;height:calc(100vh - 240px);background:#ffffff;border-radius:12px;overflow:hidden}
.chat-header{background:#00CED1;color:#fff;padding:16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(0,0,0,0.05)}
.chat-header h3{margin:0;font-size:16px;font-weight:600}
.chat-messages{flex:1;overflow-y:auto;padding:16px;background:#f5f7fa;display:flex;flex-direction:column;gap:12px}
.chat-message{max-width:70%;padding:10px 14px;border-radius:12px;position:relative;word-wrap:break-word;font-size:14px;line-height:1.4}
.chat-message.outgoing{background:#00CED1;color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.chat-message.incoming{background:#ffffff;color:#000;align-self:flex-start;border-bottom-left-radius:4px;box-shadow:0 1px 2px rgba(0,0,0,0.08)}
.chat-message-time{font-size:11px;margin-top:4px;opacity:0.7}
.chat-message-subject{font-weight:600;margin-bottom:4px;font-size:13px}
.chat-message-body{white-space:pre-wrap;word-break:break-word}
.chat-input-area{padding:12px 16px;background:#ffffff;border-top:1px solid #e8ebee;display:flex;gap:8px;align-items:flex-end}
.chat-input{flex:1;border:1px solid #dfe1e5;border-radius:20px;padding:10px 16px;font-family:inherit;font-size:14px;resize:none;max-height:120px;min-height:40px}
.chat-input:focus{outline:none;border-color:#00CED1}
.chat-send-btn{background:#00CED1;color:#fff;border:none;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background 0.2s}
.chat-send-btn:hover{background:#00B4B8}
.chat-send-btn:disabled{background:#ccc;cursor:not-allowed}
.chat-delete-btn{position:absolute;top:6px;right:6px;background:rgba(0,0,0,0.6);color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:none;line-height:1}
.chat-message:hover .chat-delete-btn{display:flex;align-items:center;justify-content:center}
.chat-users-list{display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 240px);overflow-y:auto}
.chat-user-item{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;padding:12px;cursor:pointer;transition:all 0.2s;display:flex;justify-content:space-between;align-items:center}
.chat-user-item:hover{background:#e0f7f8;border-color:#00CED1}
.chat-user-item.active{background:#00CED1;color:#fff;border-color:#00CED1}
.chat-user-info{flex:1}
.chat-user-name{font-weight:600;font-size:14px;margin-bottom:4px}
.chat-user-email{font-size:12px;color:#666}
.chat-user-item.active .chat-user-email{color:rgba(255,255,255,0.8)}
.chat-unread-badge{background:#ff3b30;color:#fff;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600;min-width:20px;text-align:center}
