/* =====================================================================
   Din Skiklub  Holdtilmeld
   Recolor the whole app by editing the variables in :root below.
   These defaults aim at a clean, friendly, alpine-blue club look.
   To match the live Kubio theme exactly, copy its primary colour,
   font-family and button radius into the variables below.
   ===================================================================== */

:root {
    --ds-primary:        #0a5ca8;   /* main blue */
    --ds-primary-dark:   #074a87;
    --ds-primary-light:  #e7f1fb;
    --ds-accent:         #e8462b;   /* warm CTA / price highlight */
    --ds-bg:             #f4f7fa;
    --ds-surface:        #ffffff;
    --ds-text:           #1b2733;
    --ds-muted:          #5e6b78;
    --ds-border:         #d8e0e8;
    --ds-success:        #1c8b53;
    --ds-danger:         #c0392b;
    --ds-radius:         12px;
    --ds-radius-sm:      8px;
    --ds-shadow:         0 6px 24px rgba(10, 40, 80, .08);
    --ds-font:           "Inter", "Helvetica Neue", Arial, system-ui, sans-serif;
    --ds-maxw:           720px;
}

* { box-sizing: border-box; }

body {
    margin: 0;
    font-family: var(--ds-font);
    color: var(--ds-text);
    background: var(--ds-bg);
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
}

.ds-wrap   { max-width: var(--ds-maxw); margin: 0 auto; padding: 24px 16px 64px; }
.ds-wide   { max-width: 1040px; }

/* header */
.ds-header {
    display: flex; align-items: center; gap: 14px;
    padding: 18px 16px;
    background: var(--ds-surface);
    border-bottom: 1px solid var(--ds-border);
}
.ds-header .logo { font-weight: 800; color: var(--ds-primary); font-size: 20px; letter-spacing: -.3px; }
.ds-header .spacer { flex: 1; }
.ds-header a { color: var(--ds-muted); text-decoration: none; font-size: 14px; }
.ds-header a:hover { color: var(--ds-primary); }

/* cards */
.ds-card {
    background: var(--ds-surface);
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius);
    box-shadow: var(--ds-shadow);
    padding: 28px;
    margin-bottom: 22px;
}

h1 { font-size: 26px; margin: 0 0 6px; letter-spacing: -.5px; }
h2 { font-size: 20px; margin: 26px 0 12px; }
.ds-sub { color: var(--ds-muted); margin: 0 0 22px; }

/* form fields */
.ds-field { margin-bottom: 18px; }
.ds-field label { display: block; font-weight: 600; margin-bottom: 6px; font-size: 15px; }
.ds-field .hint { color: var(--ds-muted); font-size: 13px; margin-top: 4px; }

input[type=text], input[type=password], input[type=email],
input[type=number], select, textarea {
    width: 100%;
    padding: 11px 13px;
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-sm);
    font-size: 15px;
    font-family: inherit;
    background: #fff;
    color: var(--ds-text);
    transition: border-color .15s, box-shadow .15s;
}
input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: var(--ds-primary);
    box-shadow: 0 0 0 3px var(--ds-primary-light);
}
textarea { min-height: 90px; resize: vertical; }

/* radio / choice groups */
.ds-choices { display: flex; flex-direction: column; gap: 8px; }
.ds-choice {
    display: flex; align-items: center; gap: 10px;
    border: 1px solid var(--ds-border);
    border-radius: var(--ds-radius-sm);
    padding: 12px 14px;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.ds-choice:hover { border-color: var(--ds-primary); background: var(--ds-primary-light); }
.ds-choice input { width: auto; margin: 0; }
.ds-choice .price-tag { margin-left: auto; color: var(--ds-muted); font-size: 14px; }

/* buttons */
.ds-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 8px;
    background: var(--ds-primary);
    color: #fff;
    border: none;
    border-radius: var(--ds-radius-sm);
    padding: 13px 22px;
    font-size: 16px;
    font-weight: 700;
    font-family: inherit;
    cursor: pointer;
    text-decoration: none;
    transition: background .15s, transform .05s;
}
.ds-btn:hover  { background: var(--ds-primary-dark); }
.ds-btn:active { transform: translateY(1px); }
.ds-btn.accent { background: var(--ds-accent); }
.ds-btn.ghost  { background: transparent; color: var(--ds-primary); border: 1px solid var(--ds-border); }
.ds-btn.sm     { padding: 8px 14px; font-size: 14px; }
.ds-btn.block  { width: 100%; }
.ds-btn[disabled] { opacity: .5; cursor: not-allowed; }

/* price summary */
.ds-summary {
    background: var(--ds-primary-light);
    border: 1px solid #cfe2f6;
    border-radius: var(--ds-radius);
    padding: 18px 20px;
    margin: 22px 0;
}
.ds-summary .row { display: flex; justify-content: space-between; padding: 4px 0; font-size: 15px; }
.ds-summary .row.total { border-top: 1px solid #cfe2f6; margin-top: 8px; padding-top: 12px;
    font-weight: 800; font-size: 18px; }
.ds-summary .row.total .amt { color: var(--ds-accent); }

/* alerts */
.ds-alert { padding: 12px 16px; border-radius: var(--ds-radius-sm); margin-bottom: 18px; font-size: 14px; }
.ds-alert.err { background: #fdecea; color: var(--ds-danger); border: 1px solid #f5c6c0; }
.ds-alert.ok  { background: #e8f6ee; color: var(--ds-success); border: 1px solid #bfe6cf; }

/* tables (admin) */
.ds-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.ds-table th, .ds-table td { text-align: left; padding: 10px 12px; border-bottom: 1px solid var(--ds-border); }
.ds-table th { color: var(--ds-muted); font-weight: 600; }
.ds-table tr:hover td { background: var(--ds-bg); }

/* misc */
.ds-row    { display: flex; gap: 14px; flex-wrap: wrap; }
.ds-row > * { flex: 1; min-width: 160px; }
.ds-tag    { display: inline-block; font-size: 12px; padding: 2px 9px; border-radius: 999px;
             background: var(--ds-primary-light); color: var(--ds-primary-dark); font-weight: 600; }
.ds-muted  { color: var(--ds-muted); }
.ds-right  { text-align: right; }
.ds-mt     { margin-top: 18px; }
.ds-divider{ height: 1px; background: var(--ds-border); margin: 22px 0; border: 0; }

@media (max-width: 560px) {
    .ds-card { padding: 20px; }
    h1 { font-size: 22px; }
}
