/* panel — тёплая светлая тема (по макету из Claude Design) */
@import url('https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root {
    --bg:        #f1f1ec;   /* фон контента */
    --panel:     #fbfbf9;   /* сайдбар */
    --card:      #ffffff;   /* карточки/таблицы */
    --hover:     #faf9f6;

    --ink:       #1a1a18;   /* основной текст / тёмный pill */
    --ink-2:     #6b6b66;   /* вторичный */
    --ink-3:     #9a9a94;   /* приглушённый */

    --line:      #e3e3de;
    --line-2:    #ebebe6;

    --accent:    #2563eb;   /* основная кнопка */
    --accent-2:  #1d4ed8;

    --ok:        #16a34a;
    --warn:      #d97706;
    --crit:      #dc2626;

    --namecheap: #ea580c;
    --hetzner:   #dc2626;
    --do:        #2563eb;

    --radius:    11px;
    --radius-lg: 16px;
    --radius-sm: 8px;
    --shadow:    0 1px 2px rgba(20,20,16,.04), 0 1px 3px rgba(20,20,16,.04);
    --shadow-lg: 0 10px 30px rgba(20,20,16,.08);
}

* { box-sizing: border-box; }

body {
    margin: 0;
    background: var(--bg);
    color: var(--ink);
    font: 14px/1.5 'Hanken Grotesk', system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
    -webkit-font-smoothing: antialiased;
}

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

/* ───────────── app shell ───────────── */

.app { display: flex; min-height: 100vh; }

.sidebar {
    width: 264px;
    flex: 0 0 264px;
    background: var(--panel);
    border-right: 1px solid var(--line);
    display: flex;
    flex-direction: column;
    padding: 18px 14px;
    position: sticky;
    top: 0;
    height: 100vh;
}

.brand { display: flex; gap: 11px; align-items: center; padding: 6px 8px 20px; color: var(--ink); }
.brand:hover { text-decoration: none; }
.brand .logo {
    width: 40px; height: 40px;
    border-radius: var(--radius);
    background: var(--ink);
    color: #fff;
    display: grid; place-items: center;
    font-weight: 800; font-size: 18px;
    flex: 0 0 40px;
}
.brand .t { display: block; font-weight: 700; font-size: 15px; line-height: 1.2; }
.brand .s { display: block; font-size: 12px; color: var(--ink-3); margin-top: 1px; }

.nav { display: flex; flex-direction: column; gap: 3px; }
.nav a {
    display: flex; align-items: center; justify-content: space-between;
    padding: 9px 12px;
    border-radius: var(--radius);
    color: var(--ink-2);
    font-weight: 500; font-size: 14px;
}
.nav a:hover { background: var(--line-2); color: var(--ink); text-decoration: none; }
.nav a.cur { background: var(--ink); color: #fff; font-weight: 600; }
.nav a.cur:hover { background: #000; }

.sidebar .spacer { flex: 1; }
.sidebar .lead-note { color: var(--ink-3); font-size: 12.5px; line-height: 1.5; padding: 14px 12px; }
.sidebar .foot {
    border-top: 1px solid var(--line);
    padding: 12px 8px 4px;
    font-size: 12.5px; color: var(--ink-3);
    display: flex; justify-content: space-between; align-items: center;
}
.sidebar .foot a { color: var(--ink-3); }

.main { flex: 1; min-width: 0; padding: 30px 36px; max-width: 1280px; }

/* ───────────── headings ───────────── */

h1 { font-size: 30px; font-weight: 800; letter-spacing: -.01em; margin: 0 0 6px; line-height: 1.1; }
.lead { color: var(--ink-3); margin: 0 0 24px; font-size: 14px; max-width: 60ch; }
h2 {
    font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em;
    color: var(--ink-3); margin: 28px 0 12px;
}

.toolbar { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-bottom: 16px; }
.toolbar .spacer { flex: 1; }

/* ───────────── stat cards ───────────── */

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px, 1fr)); gap: 14px; margin-bottom: 26px; }
.card-stat {
    background: var(--card);
    border: 1px solid var(--line-2);
    border-radius: var(--radius-lg);
    padding: 18px 20px;
    box-shadow: var(--shadow);
    display: flex; flex-direction: column;
}
.card-stat .val { order: 1; font-size: 30px; font-weight: 800; line-height: 1; }
.card-stat .lbl { order: 2; font-size: 12.5px; color: var(--ink-3); margin-top: 10px; }
.card-stat .sub { order: 3; font-size: 12px; color: var(--ink-3); margin-top: 8px; }

/* ───────────── table ───────────── */

.table {
    width: 100%;
    border-collapse: separate; border-spacing: 0;
    background: var(--card);
    border: 1px solid var(--line-2);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    overflow: hidden;
}
.table th {
    text-align: left;
    padding: 13px 16px;
    font-size: 11px; text-transform: uppercase; letter-spacing: .05em;
    color: var(--ink-3); font-weight: 700;
    border-bottom: 1px solid var(--line-2);
}
.table td { padding: 13px 16px; border-bottom: 1px solid var(--line-2); font-size: 14px; vertical-align: middle; }
.table tbody tr:hover td { background: var(--hover); }
.table tr:last-child td { border-bottom: 0; }
.table td.num, .num, .mono { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 12.5px; }
.table .row-actions { white-space: nowrap; text-align: right; }
.domain { font-family: 'JetBrains Mono', ui-monospace, monospace; font-weight: 600; font-size: 13.5px; }

/* ───────────── tags / badges / dots ───────────── */

.tag {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 600;
    padding: 3px 9px; border-radius: 999px;
    background: var(--line-2); color: var(--ink-2);
}
.tag.api    { background: #dcfce7; color: #15803d; }
.tag.manual { background: #fef3c7; color: #b45309; }
/* provider-colored chips (dot слева) */
.tag.namecheap, .tag.hetzner_cloud, .tag.digitalocean, .tag.inferno, .tag.hetzner, .tag.do {
    background: var(--card); border: 1px solid var(--line); color: var(--ink);
}
.tag.namecheap::before, .tag.hetzner_cloud::before, .tag.hetzner::before,
.tag.digitalocean::before, .tag.do::before, .tag.inferno::before {
    content: ''; width: 7px; height: 7px; border-radius: 50%; background: var(--ink-3);
}
.tag.namecheap::before     { background: var(--namecheap); }
.tag.hetzner_cloud::before,
.tag.hetzner::before        { background: var(--hetzner); }
.tag.digitalocean::before,
.tag.do::before             { background: var(--do); }

.dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--ink-3); margin-right: 6px; vertical-align: 1px; }
.dot.ok { background: var(--ok); } .dot.warn { background: var(--warn); } .dot.crit { background: var(--crit); }

/* ───────────── buttons ───────────── */

button, .btn {
    font-family: inherit; font-weight: 600; font-size: 13px;
    border: 1px solid transparent; border-radius: 10px;
    padding: 10px 16px; cursor: pointer;
    background: var(--accent); color: #fff;
    display: inline-flex; align-items: center; gap: 7px;
    transition: background .12s, border-color .12s;
}
button:hover, .btn:hover { background: var(--accent-2); text-decoration: none; }
.btn.secondary, button.secondary {
    background: var(--card); color: var(--ink); border-color: var(--line);
}
.btn.secondary:hover, button.secondary:hover { background: var(--hover); border-color: var(--ink-3); }
.btn.danger {
    background: transparent; color: var(--crit); border-color: #f0c6c6; padding: 6px 12px; font-size: 12.5px;
}
.btn.danger:hover { background: #fdecec; }
.btn.small, button.small { padding: 6px 12px; font-size: 12.5px; border-radius: 9px; }
button:disabled, .btn[disabled] { opacity: .5; cursor: not-allowed; }
.inline-form { display: inline; }

/* segmented control / chips (для будущих фильтров) */
.segmented { display: inline-flex; background: var(--line-2); border-radius: 10px; padding: 3px; gap: 2px; }
.segmented a { padding: 5px 14px; border-radius: 8px; color: var(--ink-2); font-weight: 600; font-size: 13px; }
.segmented a.cur { background: var(--card); color: var(--ink); box-shadow: var(--shadow); }
.chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip { padding: 5px 12px; border-radius: 999px; background: var(--line-2); color: var(--ink-2); font-size: 12.5px; font-weight: 600; }
.chip.cur { background: var(--ink); color: #fff; }

/* ───────────── forms ───────────── */

.form-card {
    background: var(--card);
    border: 1px solid var(--line-2);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow);
    padding: 22px;
    margin-bottom: 24px;
    max-width: 760px;
}
.form-card h2 { margin-top: 0; }
.form-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 14px; }
.form-grid .full { grid-column: 1 / -1; }
label.field { display: block; }
label.field > span { display: block; font-size: 12.5px; color: var(--ink-2); margin-bottom: 5px; font-weight: 500; }
.hint { font-size: 11.5px; color: var(--ink-3); margin-top: 3px; }

input[type=text], input[type=password], input[type=number], input[type=date], select, textarea {
    width: 100%;
    background: #fff;
    color: var(--ink);
    border: 1px solid var(--line);
    border-radius: 10px;
    padding: 9px 12px;
    font: inherit; font-size: 14px;
}
input:focus, select:focus, textarea:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(37,99,235,.12); }
textarea { resize: vertical; min-height: 64px; }
label.check { display: flex; align-items: center; gap: 8px; font-size: 13.5px; }
label.check input { width: auto; }
.form-actions { margin-top: 18px; display: flex; gap: 10px; align-items: center; }

/* ───────────── status text / misc ───────────── */

.ok      { color: var(--ok); }
.warn    { color: var(--warn); }
.crit    { color: var(--crit); font-weight: 600; }
.unknown { color: var(--ink-3); }
.dim     { color: var(--ink-3); font-weight: normal; }

.empty {
    color: var(--ink-3);
    padding: 28px; text-align: center;
    background: var(--card);
    border: 1px dashed var(--line);
    border-radius: var(--radius-lg);
}

.flash { border-radius: var(--radius); padding: 11px 15px; margin-bottom: 16px; font-size: 13.5px; border: 1px solid; }
.flash.ok   { color: #166534; background: #f0fdf4; border-color: #bbf7d0; }
.flash.err  { color: #b91c1c; background: #fef2f2; border-color: #fecaca; }
.flash.warn { color: #b45309; background: #fffbeb; border-color: #fde68a; }
.warn-banner {
    color: #b45309; background: #fffbeb; border: 1px solid #fde68a;
    border-radius: var(--radius); padding: 11px 15px; margin-bottom: 16px; font-size: 13.5px;
}
.warn-banner code, code { font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: .92em; background: var(--line-2); padding: 1px 5px; border-radius: 5px; }

/* ───────────── login ───────────── */

body.login { display: flex; align-items: center; justify-content: center; min-height: 100vh; background: var(--bg); }
body.login .card {
    background: var(--card);
    border: 1px solid var(--line-2);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    padding: 28px;
    min-width: 340px;
}
body.login h1 { margin: 0 0 18px; font-size: 22px; }
body.login label { display: block; margin-bottom: 14px; }
body.login label span { display: block; font-size: 12.5px; color: var(--ink-2); margin-bottom: 5px; }
body.login button { width: 100%; margin-top: 6px; padding: 11px; font-size: 14px; justify-content: center; }
body.login .err { color: #b91c1c; background: #fef2f2; border: 1px solid #fecaca; border-radius: 10px; padding: 9px 12px; margin-bottom: 14px; font-size: 13px; }
