/* =====================================================================
   Стили публичной части сайта общежития №1 ОшМУ.
   КЛЮЧЕВОЙ АКЦЕНТ ТЕМЫ: вёрстка построена средствами CSS GRID.
   Почти все блоки используют display:grid (каркас страницы, меню,
   карточки статистики, сетка комнат, новости, форма, подвал).
   Разработчик: Нурматова Сезим Тилековна.
   ===================================================================== */

:root {
    --c-primary:   #0d4a8f;   /* фирменный синий */
    --c-primary-d: #093866;
    --c-accent:    #f0a500;   /* золотой акцент */
    --c-teal:      #0e8f8f;
    --c-bg:        #f4f6fb;
    --c-card:      #ffffff;
    --c-text:      #1f2733;
    --c-muted:     #6b7280;
    --c-border:    #e2e6ee;
    --c-free:      #2e9e5b;
    --c-partial:   #e0a912;
    --c-full:      #cf4040;
    --radius:      14px;
    --shadow:      0 6px 20px rgba(13, 74, 143, .08);
    --maxw:        1180px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
    font-family: "Segoe UI", Tahoma, system-ui, sans-serif;
    color: var(--c-text);
    background: var(--c-bg);
    line-height: 1.6;

    /* --- CSS GRID: каркас всей страницы (шапка / контент / подвал) --- */
    min-height: 100vh;
    display: grid;
    grid-template-rows: auto 1fr auto;
    grid-template-areas:
        "header"
        "main"
        "footer";
}

a { color: var(--c-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
img { max-width: 100%; display: block; }

.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }

/* ---------- Шапка: CSS GRID (логотип | меню | язык) ---------- */
.site-header {
    grid-area: header;
    background: linear-gradient(120deg, var(--c-primary), var(--c-primary-d));
    color: #fff;
    box-shadow: var(--shadow);
}
.header-grid {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 18px;
    padding: 14px 20px;
    max-width: var(--maxw);
    margin: 0 auto;
}
.brand { display: grid; grid-template-columns: 46px auto; gap: 12px; align-items: center; color:#fff; }
.brand:hover { text-decoration: none; }
.brand .logo {
    width: 46px; height: 46px; border-radius: 50%;
    background: var(--c-accent); color: var(--c-primary-d);
    display: grid; place-items: center; font-weight: 800; font-size: 18px;
}
.brand b { font-size: 17px; display: block; }
.brand span { font-size: 12px; opacity: .85; }

.main-nav ul {
    list-style: none;
    display: grid;
    grid-auto-flow: column;
    gap: 6px;
    justify-content: center;
}
.main-nav a {
    color: #fff; padding: 9px 14px; border-radius: 9px;
    font-size: 14.5px; display: block; white-space: nowrap;
}
.main-nav a:hover, .main-nav a.active { background: rgba(255,255,255,.16); text-decoration: none; }

.lang-switch { display: grid; grid-auto-flow: column; gap: 6px; }
.lang-switch a {
    color:#fff; border: 1px solid rgba(255,255,255,.5);
    padding: 5px 10px; border-radius: 8px; font-size: 13px;
}
.lang-switch a.active { background: var(--c-accent); color: var(--c-primary-d); border-color: var(--c-accent); font-weight: 700; }

/* ---------- Контент ---------- */
main { grid-area: main; padding: 28px 0 48px; }
.page-title { font-size: 28px; color: var(--c-primary-d); margin-bottom: 6px; }
.page-sub { color: var(--c-muted); margin-bottom: 22px; }
section { margin-bottom: 34px; }
h2.block-title {
    font-size: 22px; color: var(--c-primary-d);
    margin-bottom: 16px; padding-bottom: 8px;
    border-bottom: 3px solid var(--c-accent); display: inline-block;
}

.card {
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: var(--radius); padding: 22px; box-shadow: var(--shadow);
}
.prose p { margin-bottom: 12px; }

/* ---------- Hero (главная): CSS GRID ---------- */
.hero {
    display: grid;
    grid-template-columns: 1.3fr 1fr;
    gap: 26px;
    align-items: center;
    background: linear-gradient(120deg, var(--c-primary), var(--c-teal));
    color: #fff; border-radius: var(--radius);
    padding: 40px; box-shadow: var(--shadow); margin-bottom: 30px;
}
.hero h1 { font-size: 34px; margin-bottom: 12px; }
.hero p  { font-size: 17px; opacity: .92; margin-bottom: 20px; }
.hero-art {
    display: grid; place-items: center;
    font-size: 90px;
    background: rgba(255,255,255,.12); border-radius: var(--radius); padding: 30px;
}
.btn {
    display: inline-block; background: var(--c-accent); color: var(--c-primary-d);
    font-weight: 700; padding: 12px 22px; border-radius: 10px;
    border: none; cursor: pointer; font-size: 15px;
}
.btn:hover { filter: brightness(1.06); text-decoration: none; }
.btn-outline { background: transparent; color:#fff; border: 2px solid #fff; }

/* ---------- Сетка карточек статистики: CSS GRID ---------- */
.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
    gap: 16px;
}
.stat {
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: var(--radius); padding: 20px; text-align: center;
    box-shadow: var(--shadow);
    display: grid; gap: 4px;
}
.stat .num { font-size: 32px; font-weight: 800; color: var(--c-primary); }
.stat .lbl { color: var(--c-muted); font-size: 14px; }

/* ---------- Двухколоночная раскладка контента: CSS GRID ---------- */
.split {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: 24px;
    align-items: start;
}

/* ---------- Сетка комнат по этажам: CSS GRID ---------- */
.floor-block { margin-bottom: 26px; }
.floor-head {
    display: grid; grid-template-columns: auto 1fr; align-items: center; gap: 12px;
    margin-bottom: 12px;
}
.floor-head h3 { color: var(--c-primary-d); font-size: 19px; }
.floor-head .bar { height: 3px; background: var(--c-border); border-radius: 3px; }

.room-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 14px;
}
.room {
    border-radius: 12px; padding: 14px; color: #fff;
    display: grid; gap: 6px; box-shadow: var(--shadow);
}
.room.free    { background: var(--c-free); }
.room.partial { background: var(--c-partial); }
.room.full    { background: var(--c-full); }
.room .rno { font-size: 18px; font-weight: 800; }
.room .meta { font-size: 13px; opacity: .95; }
.room .occ {
    display: grid; grid-auto-flow: column; gap: 4px; justify-content: start; margin-top: 4px;
}
.room .bed { width: 14px; height: 14px; border-radius: 3px; background: rgba(255,255,255,.4); }
.room .bed.taken { background: #fff; }

.legend {
    display: grid; grid-auto-flow: column; gap: 18px;
    justify-content: start; align-items: center; margin: 10px 0 20px;
    font-size: 14px; flex-wrap: wrap;
}
.legend span { display: grid; grid-auto-flow: column; gap: 7px; align-items: center; }
.dot { width: 16px; height: 16px; border-radius: 4px; display: inline-block; }
.dot.free { background: var(--c-free); }
.dot.partial { background: var(--c-partial); }
.dot.full { background: var(--c-full); }

/* ---------- Список условий: CSS GRID ---------- */
.cond-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 14px;
}
.cond-grid .item {
    display: grid; grid-template-columns: 40px 1fr; gap: 12px; align-items: start;
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: 12px; padding: 16px;
}
.cond-grid .ic {
    width: 40px; height: 40px; border-radius: 10px;
    background: #e8f0fb; color: var(--c-primary);
    display: grid; place-items: center; font-size: 18px; font-weight: 800;
}

/* ---------- Новости: CSS GRID ---------- */
.news-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 18px;
}
.news-card {
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow);
    display: grid; grid-template-rows: 6px auto 1fr auto;
}
.news-card .strip { background: var(--c-accent); }
.news-card .body { padding: 18px; display: grid; gap: 8px; }
.news-card h3 { font-size: 18px; color: var(--c-primary-d); }
.news-card .date { color: var(--c-muted); font-size: 13px; }
.news-card .more { padding: 0 18px 16px; }

/* ---------- Список / таблицы ---------- */
.list { display: grid; gap: 10px; }
.list .row {
    display: grid; grid-template-columns: 30px 1fr; gap: 12px;
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: 10px; padding: 14px;
}
.list .n {
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--c-primary); color:#fff;
    display: grid; place-items: center; font-size: 14px; font-weight: 700;
}

/* ---------- Контакты + форма: CSS GRID ---------- */
.contact-grid {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 24px;
    align-items: start;
}
.info-list { display: grid; gap: 14px; }
.info-list .it {
    display: grid; grid-template-columns: 44px 1fr; gap: 14px; align-items: center;
    background: var(--c-card); border: 1px solid var(--c-border);
    border-radius: 12px; padding: 14px;
}
.info-list .it .ic {
    width: 44px; height: 44px; border-radius: 10px; background: #e8f0fb;
    color: var(--c-primary); display: grid; place-items: center; font-size: 18px;
}
.info-list .it small { color: var(--c-muted); display:block; }

form.grid-form { display: grid; gap: 14px; }
.form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
}
.field { display: grid; gap: 6px; }
.field label { font-size: 14px; font-weight: 600; }
.field .req { color: var(--c-full); }
.field input, .field select, .field textarea {
    border: 1px solid var(--c-border); border-radius: 9px;
    padding: 11px 12px; font-size: 15px; font-family: inherit; width: 100%;
    background: #fff;
}
.field textarea { min-height: 110px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus {
    outline: 2px solid var(--c-primary); border-color: transparent;
}

/* ---------- Уведомления ---------- */
.alert { border-radius: 10px; padding: 14px 16px; margin-bottom: 16px; font-size: 15px; }
.alert.success { background: #e6f6ec; color: #1c6b3c; border: 1px solid #b9e3c8; }
.alert.error   { background: #fdeaea; color: #9b2c2c; border: 1px solid #f3c4c4; }
.alert.info    { background: #e8f0fb; color: #1b4a86; border: 1px solid #c3d8f2; }

/* ---------- Подвал: CSS GRID ---------- */
.site-footer {
    grid-area: footer;
    background: var(--c-primary-d); color: #cdd9ea;
}
.footer-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 22px;
    max-width: var(--maxw); margin: 0 auto; padding: 30px 20px;
}
.site-footer h4 { color:#fff; margin-bottom: 10px; font-size: 16px; }
.site-footer a { color:#cdd9ea; }
.site-footer ul { list-style: none; display: grid; gap: 6px; }
.footer-bottom {
    border-top: 1px solid rgba(255,255,255,.12);
    padding: 14px 20px; text-align: center; font-size: 13px;
}

/* ---------- Адаптивность: CSS Grid перестраивается ---------- */
@media (max-width: 920px) {
    .header-grid { grid-template-columns: 1fr auto; }
    .main-nav { grid-column: 1 / -1; order: 3; }
    .main-nav ul { grid-auto-flow: row; grid-template-columns: repeat(2,1fr); }
    .hero { grid-template-columns: 1fr; }
    .hero-art { display: none; }
    .split, .contact-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
    .form-row { grid-template-columns: 1fr; }
    .page-title { font-size: 23px; }
    .hero { padding: 26px; }
}
