:root{--cream:#f5f0e8;--dg:#1a2e20;--mg:#2d4a35;--lg:#3d6b4a;--gold:#c9a84c;--gl:#e8c97a;--red:#c0392b;--text:#1a1a1a;--muted:#6b7c6e}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--cream);font-family:'Outfit',sans-serif;color:var(--text);min-height:100vh}
header{background:var(--dg);color:var(--cream);padding:26px 36px 22px;display:flex;justify-content:space-between;align-items:flex-end;border-bottom:3px solid var(--gold)}
header h1{font-family:'Playfair Display',serif;font-size:1.6rem;line-height:1.2}
.header-actions{display:flex;gap:10px;align-items:center}
.btn-outline{font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:500;color:var(--cream);background:none;border:1.5px solid rgba(255,255,255,.3);border-radius:4px;padding:7px 16px;cursor:pointer;transition:all .15s}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
#upload-view{display:flex;align-items:center;justify-content:center;min-height:calc(100vh - 80px);padding:40px 20px}
.upload-card{background:white;border-radius:8px;padding:48px 40px;max-width:480px;width:100%;box-shadow:0 2px 12px rgba(0,0,0,.08);text-align:center}
.upload-card h2{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--dg);margin-bottom:8px}
.upload-card p{font-size:.88rem;color:var(--muted);margin-bottom:32px;line-height:1.6}
.drop-zone{border:2px dashed rgba(0,0,0,.18);border-radius:6px;padding:36px 20px;cursor:pointer;transition:all .2s;margin-bottom:20px}
.drop-zone:hover,.drop-zone.drag-over{border-color:var(--gold);background:rgba(201,168,76,.05)}
.drop-zone input{display:none}
.drop-icon{font-size:2rem;margin-bottom:10px;opacity:.5}
.drop-label{font-size:.86rem;color:var(--muted)}
.input-tabs{display:flex;gap:0;margin-bottom:20px;border:1.5px solid rgba(0,0,0,.14);border-radius:4px;overflow:hidden}
.input-tab{flex:1;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:500;padding:9px 12px;border:none;background:white;color:var(--muted);cursor:pointer;transition:all .15s}
.input-tab:not(:last-child){border-right:1.5px solid rgba(0,0,0,.14)}
.input-tab:hover{color:var(--dg);background:rgba(0,0,0,.02)}
.input-tab.active{background:var(--dg);color:var(--cream)}
.input-mode{display:none}.input-mode.active{display:block}
#paste-input{width:100%;padding:14px;border:1.5px solid rgba(0,0,0,.15);border-radius:6px;font-family:'Outfit',sans-serif;font-size:.88rem;line-height:1.6;resize:vertical;margin-bottom:14px;transition:border-color .15s}
#paste-input:focus{outline:none;border-color:var(--gold)}
#url-input{width:100%;padding:12px 14px;border:1.5px solid rgba(0,0,0,.15);border-radius:6px;font-family:'Outfit',sans-serif;font-size:.88rem;margin-bottom:8px;transition:border-color .15s}
#url-input:focus{outline:none;border-color:var(--gold)}
.url-hint{font-size:.78rem;color:var(--muted);margin-bottom:14px;line-height:1.5}
.file-chosen{font-size:.84rem;color:var(--lg);font-weight:500;margin-bottom:14px;min-height:20px}
.btn-primary{background:var(--dg);color:var(--cream);border:none;border-radius:4px;padding:12px 32px;font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:600;cursor:pointer;transition:all .15s;width:100%}
.btn-primary:hover{background:var(--mg)}
.btn-primary:disabled{opacity:.4;cursor:not-allowed}
.error-msg{color:var(--red);font-size:.84rem;margin-top:12px;min-height:20px}
.spinner{display:none;flex-direction:column;align-items:center;gap:14px;padding:20px 0}
.spinner.visible{display:flex}
.spin{width:36px;height:36px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.spin-label{font-size:.86rem;color:var(--muted)}
#result-view{display:none}
#result-view.visible{display:block}
nav{background:var(--mg);display:flex;border-bottom:2px solid var(--gold);overflow-x:auto}
nav button{font-family:'Outfit',sans-serif;font-size:.8rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase;color:var(--cream);background:none;border:none;padding:13px 20px;cursor:pointer;opacity:.6;transition:all .2s;white-space:nowrap;border-bottom:3px solid transparent;margin-bottom:-2px}
nav button:hover{opacity:.9}
nav button.active{opacity:1;border-bottom-color:var(--gold);background:rgba(201,168,76,.1)}
main{padding:32px 36px;max-width:920px}
.section{display:none}.section.active{display:block}
.sec-title{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--dg);margin-bottom:5px}
.sec-sub{font-size:.86rem;color:var(--muted);margin-bottom:22px}
.tema-card{background:white;border-radius:6px;padding:20px 22px;margin-bottom:14px;border:1px solid rgba(0,0,0,.08)}
.tema-title{font-family:'Playfair Display',serif;font-size:1rem;color:var(--dg);margin-bottom:12px}
.tema-card ul{list-style:none}
.tema-card li{font-size:.88rem;line-height:1.65;color:#333;padding:5px 0;border-bottom:1px solid rgba(0,0,0,.04);display:flex;gap:9px}
.tema-card li:last-child{border-bottom:none}
.tema-card li::before{content:'→';color:var(--gold);flex-shrink:0}
.qa-grid{display:grid;gap:9px}
.qi{background:white;border-radius:6px;border:1px solid rgba(0,0,0,.08);overflow:hidden}
.qq{padding:12px 16px;font-size:.9rem;font-weight:500;cursor:pointer;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;background:white;transition:background .15s}
.qq:hover{background:#f8f5ef}
.qq-text{flex:1}
.qtog{color:var(--muted);font-size:.78rem;transition:transform .2s;flex-shrink:0;margin-top:3px}
.qi.open .qtog{transform:rotate(180deg)}
.qa-body{display:none;padding:0 16px 14px;font-size:.88rem;line-height:1.68;color:#2a2a2a;background:#fafaf8;border-top:1px solid rgba(0,0,0,.06)}
.qi.open .qa-body{display:block;padding-top:12px}
.hint{font-size:.8rem;color:var(--muted);margin-top:8px;font-style:italic}
.arg-list{list-style:none;margin:8px 0}
.arg-list li{font-size:.86rem;line-height:1.6;color:#333;padding:4px 0;display:flex;gap:8px}
.arg-list li::before{content:'→';color:var(--gold);flex-shrink:0}
.begrep-grid{display:grid;gap:12px}
.begrep-card{background:white;border-radius:6px;padding:18px 20px;border:1px solid rgba(0,0,0,.08)}
.begrep-title{font-family:'Playfair Display',serif;font-size:.97rem;color:var(--dg);margin-bottom:6px}
.begrep-forklaring{font-size:.87rem;line-height:1.6;color:#333;margin-bottom:6px}
.begrep-sammenheng{font-size:.8rem;color:var(--muted);font-style:italic}
.arg-mot{margin-top:12px;padding:14px 16px;background:#fdf6f0;border-left:3px solid var(--gold);border-radius:0 4px 4px 0}
.arg-mot-label{font-size:.76rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.arg-mot-list{list-style:none;margin:0}
.arg-mot-list li{font-size:.86rem;line-height:1.6;color:#444;padding:4px 0;display:flex;gap:8px}
.arg-mot-list li::before{content:'↔';color:var(--red);flex-shrink:0}
.arg-vurdering{margin-top:10px;padding:10px 14px;background:rgba(45,74,53,.06);border-radius:4px;font-size:.84rem;line-height:1.6;color:var(--dg);font-style:italic}
.kk-field{font-size:.87rem;line-height:1.6;color:#333;padding:6px 0;border-bottom:1px solid rgba(0,0,0,.04)}
.kk-field:last-child{border-bottom:none}
.kk-label{font-weight:600;color:var(--dg)}
.kk-styrke{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:4px;font-size:.88rem;font-weight:600;margin-bottom:10px}
.kk-styrke--sterk{background:#d1fae5;color:#065f46}
.kk-styrke--middels{background:#fef3c7;color:#92400e}
.kk-styrke--svak{background:#fee2e2;color:#991b1b}
.kk-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}
.kk-styrke--sterk .kk-dot{background:#059669}
.kk-styrke--middels .kk-dot{background:#d97706}
.kk-styrke--svak .kk-dot{background:#dc2626}
.kk-group-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--dg);margin:24px 0 2px;padding-top:8px;border-top:1px solid rgba(0,0,0,.08)}
.kk-group-title:first-of-type{margin-top:16px;border-top:none}
.kk-group-sub{font-size:.82rem;color:var(--gl);margin-bottom:12px}
.kk-pastand{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.04)}
.kk-pastand:last-child{border-bottom:none}
.kk-pastand-title{font-weight:600;color:var(--dg);margin-bottom:4px}
.kk-list-label{font-size:.82rem;font-weight:600;color:var(--gl);margin-top:12px;margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}
@media(max-width:600px){header{padding:18px;flex-direction:column;align-items:flex-start;gap:10px}main{padding:20px 14px}.upload-card{padding:32px 20px}.sgrid{grid-template-columns:1fr}}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;align-items:center;justify-content:center;padding:20px}
.modal-overlay.visible{display:flex}
.modal{background:white;border-radius:8px;padding:32px 28px;max-width:460px;width:100%;box-shadow:0 8px 32px rgba(0,0,0,.18);position:relative;max-height:90vh;overflow-y:auto}
.modal h2{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--dg);margin-bottom:6px}
.modal p{font-size:.88rem;color:#444;line-height:1.65;margin-bottom:14px}
.modal label{font-size:.82rem;font-weight:600;color:var(--dg);display:block;margin-bottom:5px}
.modal input[type="password"],.modal input[type="text"]{width:100%;padding:10px 12px;border:1.5px solid rgba(0,0,0,.15);border-radius:4px;font-family:'Outfit',sans-serif;font-size:.88rem;margin-bottom:14px;transition:border-color .15s}
.modal input:focus{outline:none;border-color:var(--gold)}
.modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--muted);line-height:1}
.modal-close:hover{color:var(--text)}
.modal-actions{display:flex;gap:10px;margin-top:8px}
.modal .btn-primary{width:auto;padding:10px 24px}
.modal .btn-secondary{background:none;border:1.5px solid rgba(0,0,0,.15);border-radius:4px;padding:10px 24px;font-family:'Outfit',sans-serif;font-size:.88rem;cursor:pointer;color:var(--muted);transition:all .15s}
.modal .btn-secondary:hover{border-color:var(--gold);color:var(--dg)}
.key-status{font-size:.78rem;margin-bottom:10px;padding:6px 10px;border-radius:3px}
.key-status.ok{background:#d1fae5;color:#065f46}
.key-status.missing{background:#fee2e2;color:#991b1b}
.about-section{margin-bottom:16px}
.about-section h3{font-family:'Playfair Display',serif;font-size:.95rem;color:var(--dg);margin-bottom:4px}
.about-section p{margin-bottom:6px}
.about-link{color:var(--lg);text-decoration:none;font-weight:500}
.about-link:hover{color:var(--gold)}
.provider-group{margin-bottom:20px;padding-bottom:18px;border-bottom:1px solid rgba(0,0,0,.08)}
.provider-group:last-of-type{border-bottom:none;margin-bottom:10px}
.provider-title{font-family:'Playfair Display',serif;font-size:.95rem;color:var(--dg);margin-bottom:8px}
.key-input-row{display:flex;gap:8px;margin-bottom:10px}
.key-input-row input{flex:1;margin-bottom:0}
.btn-icon{background:none;border:1.5px solid rgba(0,0,0,.15);border-radius:4px;width:38px;cursor:pointer;font-size:1.1rem;color:var(--muted);transition:all .15s;flex-shrink:0}
.btn-icon:hover{border-color:var(--red);color:var(--red)}
.model-options{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.model-option{display:flex;align-items:center;gap:8px;font-size:.84rem;color:var(--text);cursor:pointer;padding:6px 10px;border-radius:4px;transition:background .15s}
.model-option:hover{background:rgba(0,0,0,.03)}
.model-option input[type="radio"]{accent-color:var(--lg);cursor:pointer}
.model-option.disabled{opacity:.4;cursor:not-allowed}
.model-option.disabled input[type="radio"]{cursor:not-allowed}
