/* ============================================================
   DigitalCaddie.no — AI / chat components, built on ds.css tokens.
   Purple-forward (the caddy accent) chat UI: avatars, message
   bubbles, typing dots, chat-window chrome, capability cards,
   suggestion chips.
   ============================================================ */

/* purple-leaning primary for this brand */
.btn-primary.cad{background:linear-gradient(135deg,#a35cff 0%,#7b3fd6 100%);box-shadow:0 10px 30px -10px #a35cffaa}
.btn-primary.cad:hover{box-shadow:0 16px 40px -10px #a35cffcc}

/* avatar with glow */
.cad-av{flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;
  background:radial-gradient(circle at 32% 28%,#ffffff45,transparent 55%),var(--accent-gradient)}
.cad-av.sm{width:30px;height:30px}
.cad-av.md{width:40px;height:40px;box-shadow:0 0 20px -2px #a35cff90}
.cad-av.lg{width:52px;height:52px;box-shadow:0 0 28px -2px #a35cffb0;animation:cadGlow 3.4s ease-in-out infinite}
@keyframes cadGlow{0%,100%{box-shadow:0 0 18px -2px #a35cff70}50%{box-shadow:0 0 30px 2px #4d9fff90}}

/* chat window chrome */
.chatwin{display:flex;flex-direction:column;background:var(--bg-panel-solid);border:1px solid color-mix(in srgb,var(--accent-purple) 30%,var(--line-soft));
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 40px 90px -34px #a35cff66,0 0 0 1px #ffffff08}
.chatwin-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line-faint);
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent-purple) 10%,transparent),transparent)}
.chatwin-head .ttl{font-family:var(--font-display);font-size:15px;font-weight:700;margin:0;display:flex;align-items:center;gap:8px}
.chatwin-head .sub{font-size:11.5px;color:var(--text-tertiary);margin:1px 0 0;display:flex;align-items:center;gap:6px}
.chatwin-head .live{width:7px;height:7px;border-radius:50%;background:var(--level-beginner);box-shadow:0 0 8px var(--level-beginner)}
.chatwin-body{display:flex;flex-direction:column;gap:14px;padding:20px 18px;flex:1;overflow:hidden}

/* messages */
.msg{display:flex;gap:9px;align-items:flex-start;max-width:100%}
.msg.user{align-self:flex-end;margin-left:auto}
.msg.user .bub{background:var(--accent-gradient);color:#fff;border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md)}
.msg.ai .bub{background:var(--bg-input);border:1px solid var(--line-faint);color:var(--text-secondary);border-radius:4px var(--radius-md) var(--radius-md) var(--radius-md)}
.bub{padding:11px 14px;font-size:13.5px;line-height:1.6;max-width:340px}
.msg.user .bub{max-width:300px}
.bub b{color:var(--text-primary);font-weight:700}
.msg.user .bub b{color:#fff}
.bub .flightline{font-family:var(--font-mono);font-size:12px;color:var(--accent-blue);font-weight:600}
.bub ul{margin:8px 0 0;padding-left:17px}
.bub li{margin-bottom:5px}
.bub li::marker{color:var(--accent-purple)}

/* typing indicator */
.typing{display:inline-flex;gap:4px;background:var(--bg-input);border:1px solid var(--line-faint);border-radius:var(--radius-pill);padding:11px 15px}
.typing span{width:6px;height:6px;border-radius:50%;background:var(--accent-purple);animation:cadType 1.1s ease-in-out infinite}
.typing span:nth-child(2){animation-delay:.15s}
.typing span:nth-child(3){animation-delay:.3s}
@keyframes cadType{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}

/* input bar */
.chatwin-foot{display:flex;gap:10px;padding:14px 16px 16px;border-top:1px solid var(--line-faint)}
.chatwin-input{flex:1;display:flex;align-items:center;gap:10px;background:var(--bg-input);border:1px solid var(--line-soft);border-radius:var(--radius-pill);padding:11px 16px;color:var(--text-tertiary);font-size:13px}
.chatwin-send{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;background:linear-gradient(135deg,#a35cff,#7b3fd6)}

/* suggestion chips */
.suggrow{display:flex;flex-wrap:wrap;gap:9px}
.suggchip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--text-secondary);
  background:var(--bg-panel-solid);border:1px solid var(--line-soft);border-radius:var(--radius-pill);padding:9px 15px;transition:.15s}
.suggchip:hover{color:var(--accent-purple);border-color:var(--accent-purple);background:#a35cff14}
.suggchip svg{color:var(--accent-purple);flex-shrink:0}

/* capability card */
.cap{position:relative;overflow:hidden;background:var(--bg-panel);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:26px 24px;transition:transform .25s,border-color .25s,box-shadow .25s}
.cap:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--c,var(--accent-purple)) 50%,var(--line-soft));box-shadow:0 24px 50px -24px var(--c,var(--accent-purple))}
.cap-ico{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  color:var(--c,var(--accent-purple));background:color-mix(in srgb,var(--c,var(--accent-purple)) 14%,transparent);border:1px solid color-mix(in srgb,var(--c,var(--accent-purple)) 30%,transparent)}
.cap h3{font-family:var(--font-display);font-size:18.5px;font-weight:700;margin:0 0 8px;letter-spacing:-.01em}
.cap p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin:0}

/* section heading shared */
.cad-shead h2{font-family:var(--font-display);font-size:clamp(28px,3.4vw,42px);font-weight:800;letter-spacing:-.02em;margin:12px 0 0;line-height:1.05}
.cad-shead.center{text-align:center;max-width:640px;margin:0 auto}
.cad-shead p.sub{color:var(--text-secondary);font-size:16px;line-height:1.6;margin:12px 0 0}
.section{padding-top:96px}
@media (width<=820px){.section{padding-top:72px}}

/* player profile editor */
.prof{display:flex;flex-direction:column;gap:11px;background:var(--bg-panel);border:1px solid var(--line-soft);border-radius:var(--radius-lg);padding:18px 20px}
.prof-title{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:15px;margin:0}
.prof-hint{font-size:12px;color:var(--text-tertiary);margin:-4px 0 4px}
.prof-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.prof-lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);width:104px;flex-shrink:0}
.seg{display:inline-flex;gap:6px;flex-wrap:wrap}
.seg-btn{font-size:13px;font-weight:600;color:var(--text-secondary);background:var(--bg-panel-solid);border:1px solid var(--line-soft);border-radius:var(--radius-pill);padding:7px 14px;cursor:pointer;transition:.13s}
.seg-btn:hover{color:var(--text-primary);border-color:var(--line-strong)}
.seg-btn.on{color:#0a0c10;background:var(--accent-purple);border-color:var(--accent-purple);font-weight:700}
/* Nivå segment colour-coded to match the disc-card level pills */
.seg[data-key="level"] .seg-btn{display:inline-flex;align-items:center;gap:7px}
.seg[data-key="level"] .seg-btn::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--dot,var(--line-strong))}
.seg[data-key="level"] .seg-btn[data-val="Nybegynner"]{--dot:var(--level-beginner)}
.seg[data-key="level"] .seg-btn[data-val="Avansert"]{--dot:var(--level-advanced)}
.seg[data-key="level"] .seg-btn[data-val="Proff"]{--dot:var(--level-pro)}
.seg[data-key="level"] .seg-btn[data-val="Nybegynner"].on{background:var(--level-beginner);border-color:var(--level-beginner)}
.seg[data-key="level"] .seg-btn[data-val="Avansert"].on{background:var(--level-advanced);border-color:var(--level-advanced)}
.seg[data-key="level"] .seg-btn[data-val="Proff"].on{background:var(--level-pro);border-color:var(--level-pro)}
.seg[data-key="level"] .seg-btn.on::before{background:#0a0c10}
@media (width<=520px){.prof-lbl{width:100%}}

/* caddie image upload */
.cad-attach{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--line-soft);cursor:pointer;transition:.15s}
.cad-attach:hover{color:var(--accent-purple);border-color:var(--accent-purple);background:#a35cff10}
.cad-cam{flex-shrink:0;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--line-soft);cursor:pointer;transition:.15s}
.cad-cam:hover{color:var(--accent-purple);border-color:var(--accent-purple);background:#a35cff10}
.cad-cammodal{position:fixed;inset:0;z-index:9999;background:#000d;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px}
.cad-cammodal .cam-inner{max-width:720px;width:100%;display:flex;flex-direction:column;gap:16px}
.cad-cammodal video{width:100%;max-height:70vh;border-radius:18px;background:#000;border:1px solid #ffffff22;object-fit:cover}
.cad-cammodal .cam-actions{display:flex;gap:12px;justify-content:center}
.cam-shoot{background:linear-gradient(135deg,#a35cff,#7b3fd6);color:#fff;font-weight:700;border:none;border-radius:999px;padding:14px 28px;font-size:15px;cursor:pointer;box-shadow:0 10px 30px -10px #a35cffaa}
.cam-cancel{background:#ffffff14;color:#fff;border:1px solid #ffffff2e;border-radius:999px;padding:14px 24px;font-weight:600;font-size:15px;cursor:pointer}
.cad-attach-thumb{display:flex;align-items:center;gap:10px;padding:0 16px 12px}
.cad-attach-thumb img{height:46px;width:64px;object-fit:cover;border-radius:8px;border:1px solid var(--line-soft)}
.cad-attach-thumb .thumb-name{font-size:12.5px;color:var(--text-secondary);font-weight:600}
.thumb-x{width:24px;height:24px;border-radius:50%;background:var(--bg-panel-raised);border:1px solid var(--line-soft);color:var(--text-secondary);font-size:15px;line-height:1;cursor:pointer;margin-left:auto;flex-shrink:0}
.thumb-x:hover{color:#ff8080;border-color:#ff808055}
.msg-img{max-width:200px;border-radius:10px;margin-bottom:7px;display:block;border:1px solid #ffffff22}
