/* Kundportalen — fristående modern design, medvetet annorlunda än RR.CoreWeb/Mox-admin. */
:root {
    --portal-bg: #f5f6fb;
    --portal-surface: #ffffff;
    --portal-text: #1b1f2a;
    --portal-muted: #6b7280;
    --portal-border: #e6e8f0;
    --portal-primary: #00adf7;
    --portal-primary-2: #0a74e8;
    --portal-primary-soft: #e0f4fe;
    --portal-success: #16a34a;
    --portal-warning: #d97706;
    --portal-danger: #dc2626;
    --portal-radius: 16px;
    --portal-radius-sm: 10px;
    --portal-shadow: 0 1px 2px rgba(16, 24, 40, .06), 0 8px 24px rgba(16, 24, 40, .06);
    --portal-shadow-lg: 0 12px 40px rgba(40, 30, 90, .18);
    --portal-grad: linear-gradient(120deg, var(--portal-primary), var(--portal-primary-2));
    --portal-font: "Funnel Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }

.portal-body {
    margin: 0;
    background: var(--portal-bg);
    color: var(--portal-text);
    font-family: var(--portal-font);
    font-size: 15px;
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

a { color: var(--portal-primary); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---------- Top bar ---------- */
.portal-topbar {
    position: sticky;
    top: 0;
    z-index: 20;
    background: var(--portal-surface);
    border-bottom: 1px solid var(--portal-border);
}
.portal-topbar-inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 14px 24px;
    display: flex;
    align-items: center;
    gap: 16px;
}
.portal-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    font-weight: 700;
    font-size: 18px;
    letter-spacing: .3px;
    color: var(--portal-text);
}
.portal-brand:hover { text-decoration: none; }
.portal-brand-mark {
    width: 34px; height: 34px;
    border-radius: 10px;
    background: var(--portal-grad);
    display: grid; place-items: center;
    color: #fff; font-size: 16px;
}
.portal-brand-logo { height: 24px; width: auto; display: block; }
.portal-brand-divider { width: 1px; height: 22px; background: var(--portal-border); }
.portal-brand-label { font-weight: 600; font-size: 15px; color: var(--portal-muted); letter-spacing: .2px; }
.portal-topbar-spacer { flex: 1; }
.portal-user {
    display: flex; align-items: center; gap: 12px;
    color: var(--portal-muted); font-size: 14px;
}
.portal-user-name { color: var(--portal-text); font-weight: 600; }
.portal-logout-btn {
    border: 1px solid var(--portal-border);
    background: var(--portal-surface);
    color: var(--portal-text);
    border-radius: 999px;
    padding: 7px 14px;
    font-size: 13px;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 6px;
}
.portal-logout-btn:hover { background: #f3f4f8; }

/* ---------- Layout shell ---------- */
.portal-main { max-width: 1180px; margin: 0 auto; padding: 32px 24px 64px; }
.portal-page-head { margin-bottom: 24px; }
.portal-page-head h1 { font-size: 26px; margin: 0 0 4px; letter-spacing: -.3px; }
.portal-page-head p { margin: 0; color: var(--portal-muted); }

.portal-back {
    display: inline-flex; align-items: center; gap: 7px;
    color: var(--portal-muted); font-size: 14px; margin-bottom: 14px;
}

/* ---------- Company groups & board cards ---------- */
.portal-company { margin-bottom: 34px; }
.portal-company-title {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px;
    color: var(--portal-muted);
    margin: 0 0 14px;
}
.portal-company-title::after { content: ""; flex: 1; height: 1px; background: var(--portal-border); }

.portal-board-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 16px;
}
.portal-board-card {
    display: block;
    background: var(--portal-surface);
    border: 1px solid var(--portal-border);
    border-radius: var(--portal-radius);
    padding: 18px 18px 16px;
    box-shadow: var(--portal-shadow);
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.portal-board-card:hover {
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: var(--portal-shadow-lg);
    border-color: #d7d9ee;
}
.portal-board-card-title { font-size: 17px; font-weight: 700; color: var(--portal-text); margin-bottom: 4px; }
.portal-board-card-sub { color: var(--portal-muted); font-size: 13px; display: flex; align-items: center; gap: 6px; }
.portal-board-card-foot {
    margin-top: 16px; display: flex; align-items: center; justify-content: space-between; gap: 10px;
}
.portal-board-card-count { color: var(--portal-muted); font-size: 13px; }

.portal-status-pill {
    display: inline-flex; align-items: center; gap: 6px;
    border-radius: 999px; padding: 4px 11px; font-size: 12px; font-weight: 600;
}
.portal-status-planning { background: #eef2ff; color: #4338ca; }
.portal-status-active { background: #ecfdf5; color: #047857; }
.portal-status-done { background: #f3f4f6; color: #4b5563; }

.portal-empty {
    background: var(--portal-surface);
    border: 1px dashed var(--portal-border);
    border-radius: var(--portal-radius);
    padding: 48px 24px;
    text-align: center;
    color: var(--portal-muted);
}
.portal-empty i { font-size: 30px; display: block; margin-bottom: 12px; opacity: .6; }

/* ---------- Read-only board banner ---------- */
.portal-readonly-note {
    display: inline-flex; align-items: center; gap: 8px;
    background: var(--portal-primary-soft); color: #075985;
    border-radius: 999px; padding: 6px 14px; font-size: 13px; font-weight: 500;
}

.portal-board-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 18px; flex-wrap: wrap; }
.portal-board-head h1 { font-size: 24px; margin: 0 0 6px; letter-spacing: -.3px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

/* Kanban-kolumner i portalen: tasks.css ger #f3f4f6 som nästan smälter ihop med portalens body
   (#f5f6fb). Förstärk bakgrunden + lägg en tydlig kant så kolumnerna ramas in och de vita korten
   poppar. Scopas till .portal-body så admin-boarden (samma .tasks-column) inte påverkas. */
.portal-body .tasks-column {
    background: #e7e9f4;
    border: 1px solid #d7dbee;
}

/* Board-kort som länk: nollställ ankarstilar så tasks.css-utseendet bevaras. */
a.tasks-card, a.portal-card-link { color: inherit; text-decoration: none; cursor: pointer; }
a.tasks-card:hover { text-decoration: none; }

/* ---------- Task-detaljsida ---------- */
.portal-task {
    background: var(--portal-surface);
    border: 1px solid var(--portal-border);
    border-radius: var(--portal-radius);
    box-shadow: var(--portal-shadow);
    padding: 22px 24px;
    margin-bottom: 18px;
}
.portal-task-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.portal-task-title { font-size: 23px; margin: 0 0 12px; letter-spacing: -.3px; }
.portal-task-meta { display: flex; flex-wrap: wrap; gap: 16px; color: var(--portal-muted); font-size: 14px; margin-bottom: 18px; }
.portal-task-meta i { margin-right: 4px; }
.portal-task-section-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px; color: var(--portal-muted); margin-bottom: 8px; }
.portal-task-desc { font-size: 15px; line-height: 1.65; word-break: break-word; }
.portal-task-desc.is-empty { color: var(--portal-muted); font-style: italic; }
.portal-task-desc img { max-width: 100%; height: auto; border-radius: 8px; }
.portal-task-desc p { margin: 0 0 10px; }
.portal-task-edit-actions { display: flex; align-items: center; gap: 10px; margin-top: 14px; }

.portal-form-label { display: block; font-size: 13px; font-weight: 600; margin: 14px 0 6px; }
.portal-textarea { resize: vertical; font: inherit; line-height: 1.5; }

.portal-ghost-btn {
    border: 1px solid var(--portal-border);
    background: var(--portal-surface);
    color: var(--portal-text);
    border-radius: 10px;
    padding: 8px 14px;
    font: inherit;
    font-size: 14px;
    cursor: pointer;
    display: inline-flex; align-items: center; gap: 7px;
}
.portal-ghost-btn:hover { background: #f3f4f8; }
.portal-btn-inline { width: auto; margin-top: 0; padding: 10px 20px; }

.portal-alert-error { background: #fef2f2; color: #b91c1c; }

/* ---------- Kommentarer ---------- */
.portal-comments-title { font-size: 17px; margin: 0 0 14px; display: flex; align-items: center; gap: 8px; }
.portal-count {
    font-size: 12px; font-weight: 700; color: var(--portal-muted);
    background: var(--portal-bg); border-radius: 999px; padding: 2px 9px;
}
.portal-comment-form { margin-bottom: 20px; }
.portal-comment-form .portal-textarea { margin-bottom: 10px; }
.portal-comments { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 14px; }
.portal-comment { border-top: 1px solid var(--portal-border); padding-top: 14px; }
.portal-comment:first-child { border-top: none; padding-top: 0; }
.portal-comment-head { display: flex; align-items: center; gap: 10px; margin-bottom: 5px; }
.portal-comment-author { font-weight: 600; font-size: 14px; display: inline-flex; align-items: center; gap: 8px; }
.portal-comment-time { color: var(--portal-muted); font-size: 12px; }
.portal-comment-body { font-size: 14px; line-height: 1.6; word-break: break-word; }
.portal-comment-body p { margin: 0 0 8px; }
.portal-comment-body ul, .portal-comment-body ol { margin: 4px 0; padding-left: 20px; }
.portal-comment-body a { color: var(--portal-primary, #2563eb); text-decoration: underline; }
.portal-comment-body code { background: #f0f0f0; border-radius: 3px; padding: 1px 4px; font-size: 85%; }
.portal-comment-body pre { background: #f0f0f0; border-radius: 4px; padding: 6px 10px; white-space: pre-wrap; }

/* @-mention-spann i postade kommentarer (samma utseende som i editorn/admin). */
.portal-comment-body .mention {
    background: #dbeafe; color: #1e40af;
    padding: 1px 6px; border-radius: 10px;
    font-weight: 500; font-size: 12px; white-space: nowrap;
}

/* Quill-editorn i portalen: tvinga auto-höjd så fältet växer med innehållet och inte lägger sig
   ovanpå Skicka-knappen (Quills standard-CSS sätter height:100% på container/editor). */
.portal-comment-form .tasks-comment-quill { margin-bottom: 10px; }
.portal-comment-form .tasks-comment-quill.ql-container { height: auto; }
.portal-comment-form .tasks-comment-quill .ql-editor { height: auto; min-height: 60px; max-height: 220px; overflow-y: auto; }
.portal-badge {
    font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: .4px;
    background: var(--portal-primary-soft); color: #075985;
    border-radius: 999px; padding: 2px 8px;
}
.portal-comments-empty { color: var(--portal-muted); font-size: 14px; }

/* ---------- Wish list quick add (portal-only) ---------- */
.portal-wish-add { margin-top: 8px; }
.portal-wish-add-input {
    width: 100%;
    border: 1px solid var(--portal-border);
    border-radius: var(--portal-radius-sm);
    padding: 9px 11px;
    font: inherit;
    background: var(--portal-surface);
    resize: vertical;
}
.portal-wish-add-input:focus { outline: none; border-color: var(--portal-primary); box-shadow: 0 0 0 3px rgba(0,173,247,.18); }
.portal-wish-add-hint { color: var(--portal-muted); font-size: 12px; margin-top: 6px; }

/* ---------- Auth pages ---------- */
.portal-auth-body {
    margin: 0;
    min-height: 100vh;
    background: var(--portal-grad);
    color: var(--portal-text);
    font-family: var(--portal-font);
    display: grid;
    place-items: center;
    padding: 24px;
}
.portal-auth-card {
    width: 100%;
    max-width: 420px;
    background: var(--portal-surface);
    border-radius: 22px;
    padding: 36px 34px;
    box-shadow: var(--portal-shadow-lg);
}
.portal-auth-mark {
    width: 52px; height: 52px; border-radius: 14px;
    background: var(--portal-grad);
    display: grid; place-items: center; color: #fff; font-size: 22px;
    margin-bottom: 18px;
}
.portal-auth-logo { height: 40px; width: auto; display: block; margin: 0 0 22px; }
.portal-auth-card h1 { font-size: 22px; margin: 0 0 6px; }
.portal-auth-card .portal-auth-sub { color: var(--portal-muted); margin: 0 0 24px; font-size: 14px; }
.portal-auth-card label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 6px; }
.portal-input {
    width: 100%;
    border: 1px solid var(--portal-border);
    border-radius: 12px;
    padding: 12px 14px;
    font: inherit;
    background: #fff;
    margin-bottom: 4px;
}
.portal-input:focus { outline: none; border-color: var(--portal-primary); box-shadow: 0 0 0 3px rgba(0,173,247,.18); }
.portal-input-code {
    text-align: center;
    font-size: 28px;
    letter-spacing: 12px;
    font-weight: 700;
    padding: 14px;
}
.portal-btn {
    width: 100%;
    border: none;
    background: var(--portal-grad);
    color: #fff;
    font-weight: 600;
    font-size: 15px;
    padding: 13px 16px;
    border-radius: 12px;
    cursor: pointer;
    margin-top: 14px;
    transition: filter .12s ease;
}
.portal-btn:hover { filter: brightness(1.06); }
.portal-auth-foot { margin-top: 18px; text-align: center; font-size: 13px; color: var(--portal-muted); }
.portal-field-error { color: var(--portal-danger); font-size: 13px; margin: 2px 0 10px; }
.portal-alert {
    background: var(--portal-primary-soft); color: #075985;
    border-radius: 12px; padding: 11px 14px; font-size: 14px; margin-bottom: 18px;
}
.portal-validation { margin: 0 0 14px; }
