/* extensionsableton.live — Ableton-inspirerad: platt, skarpa hörn (0 radius), ren blå accent. */

:root{
  --bg:#f3f3f3;
  --surface:#ffffff;
  --panel:#eeeeee;
  --ink:#000000;
  --muted:#5f5f5f;
  --faint:#8a8a8a;
  --line:#d0d0d0;
  --line-strong:#000000;
  --blue:#0000ff;
  --blue-hover:#0000cc;
  --dark:#000000;
  --dark-2:#1a1a1a;
  --maxw:1180px;
  --header-h:60px;
}

*{box-sizing:border-box;border-radius:0 !important;}
html,body{margin:0;padding:0;}
html{-webkit-text-size-adjust:100%;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Jost','Futura PT',Futura,'Century Gothic',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-size:16px;line-height:1.55;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;}
a{color:var(--blue);text-decoration:none;}
a:hover{text-decoration:underline;}
h1,h2,h3,h4{font-weight:500;line-height:1.15;margin:0 0 .5em;letter-spacing:-.01em;}
h1{font-size:2.1rem;}
h2{font-size:1.5rem;}
h3{font-size:1.15rem;}
p{margin:0 0 1rem;}
small{font-size:.82rem;}
hr{border:0;border-top:1px solid var(--line);margin:1.5rem 0;}
code{font-family:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:var(--panel);padding:.1em .35em;font-size:.88em;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 20px;}
.muted{color:var(--muted);}
.tcenter{text-align:center;}
.nowrap{white-space:nowrap;}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);}

/* ---------- Header ---------- */
.site-header{background:var(--dark);color:#fff;position:sticky;top:0;z-index:50;}
.site-header .wrap{display:flex;align-items:center;gap:18px;height:var(--header-h);}
.brand{display:flex;align-items:center;gap:10px;color:#fff;font-weight:500;font-size:1.05rem;letter-spacing:.01em;flex-shrink:0;}
.brand:hover{text-decoration:none;}
.brand .mark{width:18px;height:18px;background:var(--blue);flex-shrink:0;}
.brand .mark-sub{font-size:.7rem;color:var(--faint);font-weight:400;}
.main-nav{display:flex;align-items:center;gap:22px;margin-left:8px;}
.main-nav a{color:#cfcfcf;font-size:.95rem;}
.main-nav a:hover,.main-nav a.active{color:#fff;text-decoration:none;}
.header-spacer{flex:1;}
.header-search{display:flex;align-items:stretch;width:min(320px,34vw);}
.header-search input{flex:1;height:38px;border:1px solid #000;background:#fff;color:#000;padding:0 12px;font-size:.9rem;font-family:inherit;}
.header-search button{background:var(--blue);color:#fff;border:0;width:42px;display:flex;align-items:center;justify-content:center;cursor:pointer;}
.header-search button:hover{background:var(--blue-hover);}
.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0;}
.header-actions a{color:#fff;font-size:.92rem;}
.avatar-ini{width:32px;height:32px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;text-transform:uppercase;}
.menu-toggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem;cursor:pointer;padding:4px;}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:.95rem;font-weight:500;line-height:1;padding:12px 20px;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);cursor:pointer;transition:background .12s,color .12s;text-align:center;}
.btn:hover{text-decoration:none;background:var(--panel);}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff;}
.btn-primary:hover{background:var(--blue-hover);border-color:var(--blue-hover);color:#fff;}
.btn-dark{background:var(--dark);border-color:var(--dark);color:#fff;}
.btn-dark:hover{background:var(--dark-2);color:#fff;}
.btn-block{display:flex;width:100%;}
.btn-lg{padding:15px 28px;font-size:1.05rem;}
.btn-sm{padding:8px 14px;font-size:.85rem;}
.btn:disabled{opacity:.5;cursor:not-allowed;}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;}

/* ---------- Hero ---------- */
.hero{background:var(--blue);color:#fff;}
.hero .wrap{padding:56px 20px 52px;}
.hero h1{font-size:2.9rem;max-width:16ch;margin-bottom:.4em;color:#fff;}
.hero p{font-size:1.2rem;max-width:54ch;color:rgba(255,255,255,.9);margin-bottom:1.6rem;}
.hero .btn-row .btn{border-color:#fff;}
.hero .btn-ghost{background:transparent;color:#fff;border-color:#fff;}
.hero .btn-ghost:hover{background:rgba(255,255,255,.12);}
.hero .btn-white{background:#fff;color:#000;border-color:#fff;}
.hero .btn-white:hover{background:var(--panel);}
.hero-note{margin-top:1.4rem;font-size:.9rem;color:rgba(255,255,255,.75);}

/* ---------- Sections ---------- */
.section{padding:42px 0;}
.section-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:22px;}
.section-head h2{margin:0;}
.section-head a{font-size:.92rem;}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:var(--muted);font-weight:500;margin-bottom:6px;}

/* ---------- Category chips ---------- */
.cat-strip{display:flex;flex-wrap:wrap;gap:8px;}
.cat-chip{display:inline-flex;align-items:center;gap:8px;padding:9px 15px;background:var(--surface);border:1px solid var(--line);color:var(--ink);font-size:.9rem;font-weight:500;}
.cat-chip:hover{text-decoration:none;border-color:#000;}
.cat-chip .dot{width:12px;height:12px;flex-shrink:0;}
.cat-chip .n{color:var(--muted);font-weight:400;font-size:.85rem;}
.cat-chip.is-active{border-color:#000;background:#000;color:#fff;}

/* ---------- Extension grid + cards ---------- */
.ext-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:18px;}
.ext-card{background:var(--surface);border:1px solid var(--line);display:flex;flex-direction:column;transition:border-color .12s;}
.ext-card:hover{text-decoration:none;border-color:#000;}
.ext-thumb{aspect-ratio:16/10;background:var(--dark-2);overflow:hidden;display:flex;align-items:center;justify-content:center;}
.ext-thumb img{width:100%;height:100%;object-fit:cover;}
.ext-thumb.empty{background:repeating-linear-gradient(45deg,#1a1a1a,#1a1a1a 10px,#202020 10px,#202020 20px);color:#444;}
.ext-thumb.empty span{font-size:2rem;color:#333;}
.ext-body{padding:14px 15px 15px;display:flex;flex-direction:column;flex:1;}
.ext-title{font-size:1.05rem;font-weight:500;color:var(--ink);margin:0 0 3px;line-height:1.2;}
.ext-tagline{font-size:.86rem;color:var(--muted);margin:0 0 12px;line-height:1.4;flex:1;}
.ext-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:auto;font-size:.8rem;}
.ext-cat{display:inline-flex;align-items:center;gap:6px;color:var(--ink);}
.ext-cat .dot{width:10px;height:10px;}
.ext-dl{color:var(--muted);display:inline-flex;align-items:center;gap:5px;}
.ext-author{font-size:.8rem;color:var(--muted);margin:0 0 10px;display:flex;align-items:center;gap:6px;}
.ext-author a{color:var(--muted);}
.ext-author a:hover{color:var(--blue);}
/* Avatarer: img delar klass med initial-cirkeln, bara object-fit skiljer */
img.avatar-ini,img.profile-av,img.av-xs,img.av-sm,img.av-md{object-fit:cover;}
.av-xs,.av-sm,.av-md{flex-shrink:0;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:500;text-transform:uppercase;}
.av-xs{width:18px;height:18px;font-size:.6rem;}
.av-sm{width:38px;height:38px;font-size:1rem;}
.av-md{width:48px;height:48px;font-size:1.2rem;}

/* Kommentarer */
.comment{display:flex;gap:12px;padding:14px 0;border-top:1px solid var(--line);}
.comment:first-of-type{border-top:0;}
.comment-main{flex:1;min-width:0;}
.comment-head{display:flex;align-items:center;gap:7px;font-size:.9rem;margin-bottom:3px;flex-wrap:wrap;}
.comment-head a{color:var(--ink);font-weight:500;}
.comment-text{font-size:.95rem;line-height:1.6;word-wrap:break-word;}
.comment-del{background:none;border:0;color:var(--muted);font-size:.78rem;cursor:pointer;padding:0;font-family:inherit;text-decoration:underline;}
.comment-del:hover{color:#cc0000;}

/* ---------- Filter bar ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line);}
.filterbar .left{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.seg{display:flex;border:1px solid var(--line-strong);}
.seg a{padding:8px 14px;font-size:.85rem;color:var(--ink);border-right:1px solid var(--line-strong);}
.seg a:last-child{border-right:0;}
.seg a:hover{text-decoration:none;background:var(--panel);}
.seg a.active{background:#000;color:#fff;}
select,input[type=text],input[type=email],input[type=password],input[type=url],input[type=search],textarea{
  font-family:inherit;font-size:.95rem;border:1px solid var(--line-strong);background:var(--surface);color:var(--ink);padding:11px 12px;width:100%;
}
select{height:42px;padding:0 12px;cursor:pointer;}
textarea{line-height:1.5;resize:vertical;min-height:140px;}
input:focus,select:focus,textarea:focus{outline:2px solid var(--blue);outline-offset:-1px;}
.inline-select{width:auto;height:38px;}

/* ---------- Detail page ---------- */
.detail{display:grid;grid-template-columns:1fr 320px;gap:36px;padding:34px 0 60px;}
.detail-main{min-width:0;}
.detail h1{font-size:2.3rem;margin-bottom:.15em;}
.detail-tagline{font-size:1.2rem;color:var(--muted);margin-bottom:18px;}
.gallery{margin:0 0 28px;border:1px solid var(--line);background:var(--dark-2);}
.gallery-main{aspect-ratio:16/9;background:var(--dark-2);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.gallery-main img{width:100%;height:100%;object-fit:contain;}
.gallery-thumbs{display:flex;gap:0;background:#000;border-top:1px solid #000;}
.gallery-thumbs button{flex:1;max-width:120px;aspect-ratio:16/10;border:0;border-right:1px solid #000;padding:0;background:#1a1a1a;cursor:pointer;opacity:.55;overflow:hidden;}
.gallery-thumbs button.active,.gallery-thumbs button:hover{opacity:1;}
.gallery-thumbs img{width:100%;height:100%;object-fit:cover;}
.gallery-empty{aspect-ratio:16/9;background:repeating-linear-gradient(45deg,#1a1a1a,#1a1a1a 14px,#202020 14px,#202020 28px);display:flex;align-items:center;justify-content:center;color:#3a3a3a;font-size:1rem;}
.prose{font-size:1.02rem;line-height:1.7;}
.prose a{text-decoration:underline;}

/* sidebar */
.detail-side{align-self:start;position:sticky;top:calc(var(--header-h) + 22px);}
.side-card{background:var(--surface);border:1px solid var(--line);padding:20px;margin-bottom:18px;}
.side-card.dl{border-color:#000;}
.dl-count{font-size:.85rem;color:var(--muted);margin-bottom:14px;display:flex;align-items:center;gap:6px;}
.meta-list{list-style:none;margin:0;padding:0;font-size:.9rem;}
.meta-list li{display:flex;justify-content:space-between;gap:12px;padding:9px 0;border-bottom:1px solid var(--line);}
.meta-list li:last-child{border-bottom:0;}
.meta-list .k{color:var(--muted);}
.meta-list .v{text-align:right;font-weight:500;}
.gate-note{font-size:.82rem;color:var(--muted);margin-top:12px;line-height:1.5;}
.warn-box{background:var(--panel);border-left:3px solid var(--blue);padding:12px 14px;font-size:.84rem;color:var(--muted);margin-top:16px;line-height:1.5;}

/* version history */
.ver{border:1px solid var(--line);background:var(--surface);margin-bottom:12px;}
.ver-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;background:var(--panel);}
.ver-head .v{font-weight:500;}
.ver-body{padding:12px 16px;font-size:.92rem;color:var(--muted);white-space:pre-wrap;}

/* badges */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:.78rem;font-weight:500;border:1px solid var(--line-strong);}
.badge-cat{color:#000;}
.badge-cat .dot{width:10px;height:10px;}
.badge-pending{background:#fda43a;border-color:#fda43a;color:#000;}
.badge-rejected{background:#ff8389;border-color:#ff8389;color:#000;}
.badge-dark{background:#000;color:#fff;}
.tag-list{display:flex;flex-wrap:wrap;gap:7px;margin-top:6px;}
.tag{display:inline-block;padding:5px 11px;background:var(--panel);border:1px solid var(--line);font-size:.82rem;color:var(--ink);}
.tag:hover{border-color:#000;text-decoration:none;}

/* ---------- Forms / auth ---------- */
.page-narrow{max-width:560px;margin:0 auto;}
.field{display:block;margin-bottom:18px;}
.field .lab{display:block;font-size:.88rem;font-weight:500;margin-bottom:7px;}
.field .help{display:block;font-size:.8rem;color:var(--muted);margin-top:6px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.check{display:flex;gap:10px;align-items:flex-start;font-size:.9rem;margin-bottom:18px;}
.check input{width:auto;margin-top:3px;}
.auth-wrap{padding:48px 0 60px;}
.auth-card{max-width:440px;margin:0 auto;background:var(--surface);border:1px solid var(--line);padding:34px;}
.auth-card h1{font-size:1.6rem;}
.auth-card .sub{color:var(--muted);margin-top:-.3em;}
.auth-foot{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);font-size:.9rem;color:var(--muted);}
.flash{padding:12px 15px;border:1px solid var(--blue);background:#e6e6ff;color:#000;font-size:.9rem;margin-bottom:18px;}
.flash-err{border-color:#cc0000;background:#ffe6e6;}
.flash-ok{border-color:#1d9e75;background:#e1f5ee;}

/* page header block */
.page-head{padding:34px 0 8px;}
.page-head h1{margin-bottom:.2em;}
.page-head .lead{font-size:1.1rem;color:var(--muted);max-width:60ch;}

/* upload dropzones */
.dropzone{border:1px dashed var(--line-strong);background:var(--surface);padding:22px;text-align:center;cursor:pointer;font-size:.9rem;color:var(--muted);transition:background .1s,border-color .1s,color .1s;}
.dropzone:hover{background:var(--panel);}
.dropzone.dragover{background:#e6e6ff;border-color:var(--blue);border-style:solid;color:var(--blue);}
.file-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px;}
.file-pill{font-size:.82rem;background:var(--panel);border:1px solid var(--line);padding:5px 10px;}
.file-thumb{display:inline-flex;flex-direction:column;gap:3px;align-items:center;}
.file-thumb img{width:96px;height:72px;object-fit:cover;border:1px solid var(--line-strong);}
.file-thumb span{font-size:.72rem;color:var(--muted);}

/* ---------- Pagination ---------- */
.pager{display:flex;gap:0;justify-content:center;margin-top:36px;}
.pager a,.pager span{padding:10px 16px;border:1px solid var(--line-strong);border-right:0;font-size:.9rem;color:var(--ink);}
.pager a:last-child,.pager span:last-child{border-right:1px solid var(--line-strong);}
.pager a:hover{background:var(--panel);text-decoration:none;}
.pager .cur{background:#000;color:#fff;}
.pager .disabled{color:var(--faint);}

/* ---------- empty state ---------- */
.empty-state{text-align:center;padding:60px 20px;color:var(--muted);}
.empty-state .big{font-size:3rem;color:var(--line);margin-bottom:10px;}

/* ---------- profile ---------- */
.profile-head{display:flex;align-items:center;gap:20px;padding:34px 0;border-bottom:1px solid var(--line);}
.profile-av{width:72px;height:72px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:500;text-transform:uppercase;flex-shrink:0;}
.profile-head h1{margin:0;font-size:1.8rem;}
.profile-head .u{color:var(--muted);}

/* ---------- table (admin) ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:.9rem;background:var(--surface);border:1px solid var(--line);}
.tbl th,.tbl td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle;}
.tbl th{background:var(--panel);font-weight:500;}
.tbl tr:last-child td{border-bottom:0;}

/* ---------- Footer ---------- */
.site-footer{background:var(--dark);color:#cfcfcf;margin-top:60px;padding:44px 0 30px;font-size:.9rem;}
.footer-grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;}
.footer-grid h4{color:#fff;font-size:.8rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;}
.footer-col a{display:block;color:#cfcfcf;margin-bottom:8px;}
.footer-col a:hover{color:#fff;}
.footer-brand{max-width:300px;}
.footer-brand .brand{margin-bottom:12px;}
.footer-bottom{margin-top:34px;padding-top:20px;border-top:1px solid #2a2a2a;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;color:var(--faint);font-size:.82rem;}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .detail{grid-template-columns:1fr;}
  .detail-side{position:static;}
  .hero h1{font-size:2.2rem;}
  .hero p{font-size:1.05rem;}
}
@media(max-width:680px){
  .main-nav,.header-search{display:none;}
  .menu-toggle{display:block;}
  .site-header .wrap{gap:10px;}
  .header-spacer{flex:1;}
  .mobile-nav{display:none;background:var(--dark-2);border-top:1px solid #2a2a2a;}
  .mobile-nav.open{display:block;}
  .mobile-nav a{display:block;padding:14px 20px;color:#fff;border-bottom:1px solid #2a2a2a;}
  .mobile-nav .ms{padding:12px 20px;}
  .field-row{grid-template-columns:1fr;}
  h1{font-size:1.7rem;}
  .hero .wrap{padding:40px 20px;}
}
@media(min-width:681px){ .mobile-nav{display:none;} }
