/* ============================================================
   APK KING — Design system (phase A1 foundation)
   Identity: clean app-store clarity with a technical edge.
   Display: Space Grotesk · Body: Instrument Sans · Data: JetBrains Mono
   Accent: Android green (#3DDC84) — overridable via Customizer.
   ============================================================ */

:root{
  --ak-accent:#3DDC84;
  --ak-accent-ink:#0B130E;          /* text on accent */
  --ak-accent-deep:#0E9F5D;         /* accent usable as text on light bg */

  --ak-bg:#F4F7F5;
  --ak-surface:#FFFFFF;
  --ak-surface-2:#ECF1EE;
  --ak-text:#15211B;
  --ak-text-2:#56655D;
  --ak-text-3:#8A998F;
  --ak-line:#DFE7E2;
  --ak-shadow:0 1px 2px rgba(21,33,27,.06),0 4px 14px rgba(21,33,27,.05);
  --ak-shadow-lg:0 8px 30px rgba(21,33,27,.10);

  --ak-radius:14px;
  --ak-radius-sm:9px;
  --ak-font-display:'Space Grotesk',system-ui,sans-serif;
  --ak-font-body:'Instrument Sans',system-ui,sans-serif;
  --ak-font-mono:'JetBrains Mono',ui-monospace,monospace;
}

[data-theme="dark"]{
  --ak-accent-deep:#3DDC84;
  --ak-bg:#0D1411;
  --ak-surface:#151E19;
  --ak-surface-2:#1C2720;
  --ak-text:#E9F2EC;
  --ak-text-2:#9BADA2;
  --ak-text-3:#6B7C72;
  --ak-line:#243129;
  --ak-shadow:0 1px 2px rgba(0,0,0,.4),0 4px 14px rgba(0,0,0,.3);
  --ak-shadow-lg:0 8px 30px rgba(0,0,0,.45);
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition:none!important}
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  font-family:var(--ak-font-body);
  background:var(--ak-bg);
  color:var(--ak-text);
  font-size:15px;line-height:1.55;
}
img{max-width:100%;height:auto}
a{color:var(--ak-accent-deep);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:var(--ak-font-display);line-height:1.2;font-weight:600}

.ak-container{max-width:1200px;margin:0 auto;padding:0 20px}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
:focus-visible{outline:2px solid var(--ak-accent);outline-offset:2px;border-radius:4px}

/* ---------- Header ---------- */
.ak-header{
  position:sticky;top:0;z-index:100;
  background:color-mix(in srgb,var(--ak-surface) 92%,transparent);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--ak-line);
}
.ak-header-inner{display:flex;align-items:center;gap:18px;height:64px}
.ak-brand{display:flex;align-items:center;gap:10px;font-family:var(--ak-font-display);font-weight:700;font-size:1.15rem;color:var(--ak-text);white-space:nowrap}
.ak-brand:hover{text-decoration:none}
.ak-brand .ak-brand-dot{width:30px;height:30px;border-radius:9px;background:var(--ak-accent);display:inline-flex;align-items:center;justify-content:center;color:var(--ak-accent-ink);font-weight:700}
.ak-search{flex:1;max-width:520px}
.ak-search form{display:flex;align-items:center;gap:9px;background:var(--ak-surface-2);border:1.5px solid transparent;border-radius:24px;padding:0 16px;height:42px;transition:border-color .15s}
.ak-search form:focus-within{border-color:var(--ak-accent);background:var(--ak-surface)}
.ak-search input{flex:1;border:0;background:none;color:var(--ak-text);font:inherit;outline:none}
.ak-search svg{width:17px;height:17px;fill:var(--ak-text-3);flex:none}
.ak-header-actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.ak-mode-toggle{background:none;border:1px solid var(--ak-line);border-radius:9px;width:38px;height:38px;cursor:pointer;font-size:1rem;color:var(--ak-text);display:inline-flex;align-items:center;justify-content:center}
.ak-mode-toggle:hover{border-color:var(--ak-accent)}

.ak-nav{display:flex;gap:4px;align-items:center;list-style:none}
.ak-nav a{display:inline-block;padding:8px 11px;border-radius:8px;color:var(--ak-text-2);font-weight:500}
.ak-nav a:hover{background:var(--ak-surface-2);color:var(--ak-text);text-decoration:none}

/* ---------- Cards grid ---------- */
.ak-main{padding:26px 0 60px}
.ak-section-title{font-size:1.25rem;margin:26px 0 14px;display:flex;align-items:baseline;gap:10px}
.ak-section-title small{font-family:var(--ak-font-body);font-weight:400;font-size:.82rem;color:var(--ak-text-3)}
.ak-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}

.ak-card{
  background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:var(--ak-radius);
  padding:16px 12px;text-align:center;color:var(--ak-text);display:block;position:relative;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
}
.ak-card:hover{transform:translateY(-3px);box-shadow:var(--ak-shadow-lg);border-color:var(--ak-accent);text-decoration:none}
.ak-card .ak-icon{width:72px;height:72px;margin:0 auto 10px;border-radius:18px;overflow:hidden;background:var(--ak-surface-2);display:flex;align-items:center;justify-content:center}
.ak-card .ak-icon img{width:100%;height:100%;object-fit:cover}
.ak-icon-fallback{font-family:var(--ak-font-display);font-weight:700;font-size:1.6rem;color:var(--ak-accent-deep)}
.ak-card-name{font-weight:600;font-size:.92rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ak-card-meta{margin-top:5px;font-size:.78rem;color:var(--ak-text-3)}

/* Version chip — the APK King signature: data in mono */
.ak-vchip{
  font-family:var(--ak-font-mono);font-size:.72rem;font-weight:600;
  background:color-mix(in srgb,var(--ak-accent) 14%,transparent);
  color:var(--ak-accent-deep);
  border-radius:6px;padding:2px 7px;display:inline-block;margin-top:7px;
}
.ak-badge-mod{
  position:absolute;top:10px;right:10px;
  font-family:var(--ak-font-mono);font-size:.62rem;font-weight:600;letter-spacing:.06em;
  background:var(--ak-accent);color:var(--ak-accent-ink);border-radius:5px;padding:2px 6px;
}

/* ---------- Buttons ---------- */
.ak-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font:600 .95rem var(--ak-font-body);
  border-radius:11px;border:1px solid transparent;cursor:pointer;
  padding:12px 24px;transition:transform .12s,box-shadow .12s,background .12s;
}
.ak-btn:hover{text-decoration:none;transform:translateY(-1px)}
.ak-btn-primary{background:var(--ak-accent);color:var(--ak-accent-ink)}
.ak-btn-primary:hover{box-shadow:0 6px 18px color-mix(in srgb,var(--ak-accent) 35%,transparent)}
.ak-btn-ghost{border-color:var(--ak-line);color:var(--ak-text)}
.ak-btn-ghost:hover{border-color:var(--ak-accent)}

/* ---------- App detail (foundation; full layout in A2) ---------- */
.ak-detail-head{background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:var(--ak-radius);padding:24px;display:flex;gap:20px;align-items:flex-start;flex-wrap:wrap}
.ak-detail-head .ak-icon{width:96px;height:96px;border-radius:22px;overflow:hidden;background:var(--ak-surface-2);display:flex;align-items:center;justify-content:center;flex:none}
.ak-detail-head .ak-icon img{width:100%;height:100%;object-fit:cover}
.ak-detail-title{font-size:1.5rem;margin-bottom:4px}
.ak-detail-dev{color:var(--ak-text-2);font-size:.9rem}
.ak-stat-row{display:flex;gap:26px;margin-top:14px;flex-wrap:wrap}
.ak-stat b{font-family:var(--ak-font-mono);font-size:1.02rem;display:block}
.ak-stat span{font-size:.74rem;color:var(--ak-text-3);text-transform:uppercase;letter-spacing:.06em}

.ak-panel{background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:var(--ak-radius);padding:22px;margin-top:18px}
.ak-panel h2{font-size:1.1rem;margin-bottom:14px}

.ak-version-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--ak-line);border-radius:var(--ak-radius-sm);padding:12px 14px;margin-bottom:10px;color:var(--ak-text)}
.ak-version-row:hover{border-color:var(--ak-accent);text-decoration:none;background:color-mix(in srgb,var(--ak-accent) 6%,var(--ak-surface))}
.ak-version-row .ak-vname{font-family:var(--ak-font-mono);font-weight:600}
.ak-version-row .ak-vdate{font-size:.82rem;color:var(--ak-text-3)}

.ak-mod-list{list-style:none}
.ak-mod-list li{padding:7px 0 7px 26px;position:relative;border-bottom:1px dashed var(--ak-line)}
.ak-mod-list li:last-child{border-bottom:0}
.ak-mod-list li::before{content:"";position:absolute;left:2px;top:13px;width:12px;height:12px;border-radius:4px;background:var(--ak-accent)}

/* ---------- Footer ---------- */
.ak-footer{border-top:1px solid var(--ak-line);background:var(--ak-surface);margin-top:40px}
.ak-footer-inner{padding:26px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.86rem;color:var(--ak-text-2)}
.ak-credit a{font-weight:600}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .ak-nav{display:none}
  .ak-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr))}
}
@media(max-width:560px){
  .ak-header-inner{gap:10px}
  .ak-brand span.ak-brand-text{display:none}
  .ak-detail-head{padding:18px}
}

/* ---------- Breadcrumbs ---------- */
.ak-crumbs{margin:2px 0 18px;font-size:.84rem}
.ak-crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:4px;align-items:center}
.ak-crumbs li{display:flex;align-items:center;gap:4px;color:var(--ak-text-3)}
.ak-crumbs li+li::before{content:"›";color:var(--ak-text-3);margin:0 3px}
.ak-crumbs a{color:var(--ak-text-2)}
.ak-crumbs span[aria-current]{color:var(--ak-text)}

/* ---------- Version chip variants ---------- */
.ak-vchip-lg{font-size:.85rem;padding:4px 11px;vertical-align:middle}
.ak-version-row.is-current{border-color:var(--ak-accent);background:color-mix(in srgb,var(--ak-accent) 8%,var(--ak-surface))}

/* ---------- Info table (soft, not rustic) ---------- */
.ak-info-table{width:100%;border-collapse:collapse}
.ak-info-table td{padding:10px 0;border-bottom:1px solid var(--ak-line)}
.ak-info-table tr:last-child td{border-bottom:0}
.ak-info-table td:first-child{color:var(--ak-text-2);width:42%}
.ak-info-table td:last-child{font-family:var(--ak-font-mono);font-size:.88rem}

/* ---------- Download page ---------- */
.ak-dl-wrap{max-width:620px;margin:0 auto}
.ak-dl-card{
  background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:20px;
  padding:34px 26px;text-align:center;box-shadow:var(--ak-shadow);
}
.ak-dl-icon{width:88px;height:88px;border-radius:22px;overflow:hidden;background:var(--ak-surface-2);display:inline-flex;align-items:center;justify-content:center;margin-bottom:12px}
.ak-dl-icon img{width:100%;height:100%;object-fit:cover}
.ak-dl-name{font-size:1.35rem;margin-bottom:8px}
.ak-dl-stats{display:flex;justify-content:center;gap:26px;margin:18px 0 6px;flex-wrap:wrap}
.ak-dl-stats span{font-size:.74rem;color:var(--ak-text-3);text-transform:uppercase;letter-spacing:.05em}
.ak-dl-stats b{display:block;font:600 .95rem var(--ak-font-mono);color:var(--ak-text);text-transform:none;letter-spacing:0}
.ak-ring{position:relative;width:96px;height:96px;margin:16px auto 8px}
.ak-ring-fg{transform:rotate(-90deg);transform-origin:50% 50%;transition:stroke-dashoffset .25s linear}
.ak-ring-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font:600 1.7rem var(--ak-font-mono)}
.ak-ring.is-done .ak-ring-num{color:var(--ak-accent-deep)}
.ak-dl-msg{color:var(--ak-text-2);margin-bottom:18px;font-size:.92rem}
.ak-dl-btn{width:min(320px,100%);opacity:.45;pointer-events:none;transition:opacity .3s,transform .12s,box-shadow .12s}
.ak-dl-btn.is-ready{opacity:1;pointer-events:auto;animation:ak-pop .35s ease}
@keyframes ak-pop{0%{transform:scale(.96)}60%{transform:scale(1.03)}100%{transform:scale(1)}}
.ak-dl-alt{margin-top:16px;font-size:.86rem;color:var(--ak-text-3)}
.ak-steps{margin:0;padding-left:0;list-style:none;counter-reset:akstep}
.ak-steps li{counter-increment:akstep;position:relative;padding:9px 0 9px 40px;border-bottom:1px dashed var(--ak-line)}
.ak-steps li:last-child{border-bottom:0}
.ak-steps li::before{
  content:counter(akstep);position:absolute;left:0;top:8px;width:26px;height:26px;border-radius:9px;
  background:color-mix(in srgb,var(--ak-accent) 14%,transparent);color:var(--ak-accent-deep);
  font:600 .85rem var(--ak-font-mono);display:flex;align-items:center;justify-content:center;
}

/* ---------- 404 ---------- */
.ak-404{max-width:520px;margin:40px auto;text-align:center}
.ak-404-code{font:700 5.4rem var(--ak-font-display);letter-spacing:.04em;line-height:1;margin-bottom:10px}
.ak-404-droid{color:var(--ak-accent)}
.ak-404 h1{font-size:1.4rem;margin-bottom:8px}
.ak-404 p{color:var(--ak-text-2)}
.ak-404-search{max-width:380px;margin:18px auto}

/* ---------- Sticky mobile download bar ---------- */
.ak-stickybar{
  position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;
  background:color-mix(in srgb,var(--ak-surface) 94%,transparent);backdrop-filter:blur(10px);
  border-top:1px solid var(--ak-line);padding:10px 16px calc(10px + env(safe-area-inset-bottom));
}
.ak-stickybar .ak-btn{width:100%}
@media(max-width:680px){
  .ak-stickybar{display:block}
  body:has(.ak-stickybar) .ak-main{padding-bottom:90px}
}

/* ---------- Hero ---------- */
.ak-hero{
  text-align:center;padding:44px 20px 38px;margin-bottom:8px;border-radius:20px;
  background:
    radial-gradient(600px 220px at 50% -40px,color-mix(in srgb,var(--ak-accent) 16%,transparent),transparent 70%),
    var(--ak-surface);
  border:1px solid var(--ak-line);
}
.ak-hero-title{font-size:clamp(1.6rem,4vw,2.4rem);letter-spacing:-.01em}
.ak-hero-sub{color:var(--ak-text-2);max-width:560px;margin:10px auto 0}
.ak-hero-search{max-width:520px;margin:22px auto 0}
.ak-hero-search form{height:50px;background:var(--ak-bg)}

/* ---------- Category chips ---------- */
.ak-chips{display:flex;flex-wrap:wrap;gap:9px}
.ak-chip{
  display:inline-flex;align-items:center;padding:9px 16px;border-radius:22px;
  background:var(--ak-surface);border:1px solid var(--ak-line);color:var(--ak-text);
  font-weight:500;font-size:.9rem;transition:border-color .12s,transform .12s;
}
.ak-chip:hover{border-color:var(--ak-accent);transform:translateY(-1px);text-decoration:none}
.ak-chip.is-active{background:var(--ak-accent);border-color:var(--ak-accent);color:var(--ak-accent-ink)}

/* ---------- Filter bar ---------- */
.ak-filterbar{display:flex;flex-wrap:wrap;gap:9px;align-items:center;margin:0 0 18px}
.ak-filterbar .ak-chip{padding:7px 14px;font-size:.85rem}
.ak-filterbar .sep{width:1px;height:22px;background:var(--ak-line);margin:0 4px}

/* ---------- Search suggestions ---------- */
.ak-search{position:relative}
.ak-suggest{
  position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:120;
  background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:14px;
  box-shadow:var(--ak-shadow-lg);overflow:hidden;display:none;
}
.ak-suggest.open{display:block;animation:ak-fade .14s ease}
@keyframes ak-fade{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.ak-suggest a{display:flex;align-items:center;gap:11px;padding:9px 13px;color:var(--ak-text)}
.ak-suggest a:hover,.ak-suggest a.is-active{background:var(--ak-surface-2);text-decoration:none}
.ak-suggest .s-icon{width:38px;height:38px;border-radius:11px;overflow:hidden;background:var(--ak-surface-2);flex:none;display:flex;align-items:center;justify-content:center;font:700 1rem var(--ak-font-display);color:var(--ak-accent-deep)}
.ak-suggest .s-icon img{width:100%;height:100%;object-fit:cover}
.ak-suggest .s-name{font-weight:600;font-size:.9rem;line-height:1.25}
.ak-suggest .s-meta{font-size:.76rem;color:var(--ak-text-3)}
.ak-suggest .s-v{margin-left:auto;font-family:var(--ak-font-mono);font-size:.74rem;color:var(--ak-accent-deep);flex:none}
.ak-suggest .s-empty{padding:13px;color:var(--ak-text-3);font-size:.88rem;text-align:center}

/* ---------- Mirrors ---------- */
.ak-mirrors{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;margin-top:16px}
.ak-mirrors-label{font-size:.74rem;color:var(--ak-text-3);text-transform:uppercase;letter-spacing:.06em;margin-right:2px}
.ak-mirror{
  display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:10px;
  border:1px solid var(--ak-line);color:var(--ak-text);font-size:.86rem;font-weight:500;
}
.ak-mirror:hover{border-color:var(--ak-accent);text-decoration:none}

/* ---------- Report form ---------- */
.ak-report-open{background:none;border:0;color:var(--ak-text-3);cursor:pointer;font:inherit;font-size:.86rem;padding:0;text-decoration:underline dotted}
.ak-report-open:hover{color:var(--ak-text)}
.ak-report{margin-top:16px;padding:16px;border:1px dashed var(--ak-line);border-radius:12px;display:grid;gap:9px;text-align:left}
.ak-report label{font-weight:600;font-size:.88rem}
.ak-report select,.ak-report textarea{
  font:inherit;color:var(--ak-text);background:var(--ak-bg);
  border:1px solid var(--ak-line);border-radius:9px;padding:9px 11px;width:100%;
}
.ak-report select:focus,.ak-report textarea:focus{outline:none;border-color:var(--ak-accent)}
.ak-report .ak-hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.ak-report-msg{font-size:.86rem;color:var(--ak-accent-deep)}

/* ---------- FAQ accordion ---------- */
.ak-faq{border:1px solid var(--ak-line);border-radius:var(--ak-radius-sm);margin-bottom:10px;overflow:hidden}
.ak-faq summary{
  cursor:pointer;list-style:none;padding:13px 42px 13px 15px;font-weight:600;position:relative;user-select:none;
}
.ak-faq summary::-webkit-details-marker{display:none}
.ak-faq summary::after{
  content:"+";position:absolute;right:14px;top:50%;transform:translateY(-50%);
  font:600 1.1rem var(--ak-font-mono);color:var(--ak-accent-deep);transition:transform .18s;
}
.ak-faq[open] summary::after{transform:translateY(-50%) rotate(45deg)}
.ak-faq[open] summary{border-bottom:1px solid var(--ak-line)}
.ak-faq-a{padding:13px 15px;color:var(--ak-text-2)}
.ak-faq summary:hover{background:var(--ak-surface-2)}

/* ---------- Ad zones ---------- */
.ak-ad{margin:14px 0;text-align:center}
.ak-ad:empty{display:none}

/* ---------- Star rating widget ---------- */
.ak-rate{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap}
.ak-star{
  background:none;border:0;cursor:pointer;font-size:1.45rem;line-height:1;padding:1px;
  color:var(--ak-line);transition:transform .1s,color .1s;
}
.ak-star.is-on{color:#F5B301}
.ak-star:hover{transform:scale(1.15)}
.ak-rate.voted .ak-star{cursor:default}
.ak-rate.voted .ak-star:hover{transform:none}
.ak-rate-info{font-size:.88rem;color:var(--ak-text-2)}
.ak-rate-info b{font-family:var(--ak-font-mono)}

/* ---------- Comments ---------- */
.ak-comments h2{font-size:1.1rem;margin-bottom:14px}
.ak-comment-list{list-style:none;margin:0 0 18px;padding:0}
.ak-comment-list .comment{border:1px solid var(--ak-line);border-radius:var(--ak-radius-sm);padding:14px;margin-bottom:12px}
.ak-comment-list .children{list-style:none;margin:12px 0 0 26px;padding:0}
.ak-comment-list .comment-author{display:flex;align-items:center;gap:9px;font-weight:600}
.ak-comment-list .comment-author .avatar{border-radius:50%}
.ak-comment-list .comment-author .says{display:none}
.ak-comment-list .comment-metadata{font-size:.78rem;margin:3px 0 8px}
.ak-comment-list .comment-metadata a{color:var(--ak-text-3)}
.ak-comment-list .comment-content{color:var(--ak-text-2);font-size:.93rem}
.ak-comment-list .reply{margin-top:8px;font-size:.84rem}
.comment-respond label{display:block;font-weight:600;font-size:.88rem;margin-bottom:4px}
.comment-respond input[type=text],.comment-respond input[type=email],.comment-respond input[type=url],.comment-respond textarea{
  width:100%;font:inherit;color:var(--ak-text);background:var(--ak-bg);
  border:1px solid var(--ak-line);border-radius:9px;padding:10px 12px;margin-bottom:12px;
}
.comment-respond input:focus,.comment-respond textarea:focus{outline:none;border-color:var(--ak-accent)}
.comment-respond .comment-reply-title{font-size:1.05rem;margin-bottom:12px}
.comment-respond .comment-notes,.comment-respond .logged-in-as{font-size:.84rem;color:var(--ak-text-3);margin-bottom:10px}
.comment-respond .comment-form-cookies-consent{display:flex;gap:8px;align-items:flex-start;margin-bottom:12px}
.comment-respond .comment-form-cookies-consent label{font-weight:400;font-size:.84rem;color:var(--ak-text-2)}
.ak-comments-closed{color:var(--ak-text-3)}

/* ---------- Language switcher ---------- */
.ak-langdd{position:relative}
.ak-langdd summary{
  list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:5px;
  border:1px solid var(--ak-line);border-radius:9px;height:38px;padding:0 11px;
  font:600 .82rem var(--ak-font-mono);color:var(--ak-text);user-select:none;
}
.ak-langdd summary::-webkit-details-marker{display:none}
.ak-langdd summary:hover{border-color:var(--ak-accent)}
.ak-langdd[open] .caret{transform:rotate(180deg)}
.ak-langdd .caret{font-size:.6rem;transition:transform .15s}
.ak-langdd-menu{
  position:absolute;right:0;top:calc(100% + 8px);min-width:170px;z-index:130;
  background:var(--ak-surface);border:1px solid var(--ak-line);border-radius:12px;
  box-shadow:var(--ak-shadow-lg);padding:6px;animation:ak-fade .14s ease;
}
.ak-langdd-menu a{display:block;padding:8px 11px;border-radius:8px;color:var(--ak-text);font-size:.9rem}
.ak-langdd-menu a:hover{background:var(--ak-surface-2);text-decoration:none}
.ak-langdd-menu a.is-current{color:var(--ak-accent-deep);font-weight:600}

/* ---------- Screenshot gallery (scroll-snap + modern scrollbar) ---------- */
.ak-shots{
  display:flex;gap:12px;overflow-x:auto;margin-top:18px;padding-bottom:12px;
  scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;
  scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--ak-accent) 55%,var(--ak-line)) transparent;
}
.ak-shots::-webkit-scrollbar{height:8px}
.ak-shots::-webkit-scrollbar-track{background:var(--ak-surface-2);border-radius:999px}
.ak-shots::-webkit-scrollbar-thumb{
  background:linear-gradient(90deg,var(--ak-accent),color-mix(in srgb,var(--ak-accent) 55%,var(--ak-text-3)));
  border-radius:999px;border:2px solid var(--ak-surface-2);
}
.ak-shots::-webkit-scrollbar-thumb:hover{background:var(--ak-accent)}
.ak-shots img{
  height:300px;width:auto;flex:none;border-radius:14px;border:1px solid var(--ak-line);
  scroll-snap-align:start;background:var(--ak-surface-2);
}
@media(max-width:560px){.ak-shots img{height:230px}}

/* ---------- File type + build variants ---------- */
.ak-ftype{
  display:inline-block;margin-left:6px;font:600 .72rem var(--ak-font-mono);letter-spacing:.05em;
  border:1px solid var(--ak-accent);color:var(--ak-accent-deep);border-radius:6px;padding:3px 8px;vertical-align:middle;
}
.ak-variants{display:grid;gap:8px;max-width:380px;margin:6px auto 16px;text-align:left}
.ak-variant{
  display:flex;align-items:center;gap:10px;width:100%;cursor:pointer;
  font:inherit;color:var(--ak-text);background:var(--ak-bg);
  border:1.5px solid var(--ak-line);border-radius:11px;padding:11px 14px;transition:border-color .12s;
}
.ak-variant:hover{border-color:var(--ak-accent)}
.ak-variant.is-sel{border-color:var(--ak-accent);background:color-mix(in srgb,var(--ak-accent) 8%,var(--ak-bg))}
.ak-variant.is-sel::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--ak-accent);flex:none}
.ak-variant .va-arch{font:600 .88rem var(--ak-font-mono)}
.ak-variant .va-type{font-size:.74rem;color:var(--ak-accent-deep);border:1px solid var(--ak-line);border-radius:5px;padding:1px 6px}
.ak-variant .va-size{margin-left:auto;font-size:.8rem;color:var(--ak-text-3)}

/* ---------- Rich text inside app descriptions ---------- */
.ak-desc{color:var(--ak-text-2)}
.ak-desc p{margin:0 0 14px}
.ak-desc p:last-child{margin-bottom:0}
.ak-desc ul,.ak-desc ol{margin:0 0 14px 22px}
.ak-desc li{margin-bottom:4px}
.ak-desc h2,.ak-desc h3,.ak-desc h4{margin:18px 0 8px;color:var(--ak-text)}
.ak-desc strong,.ak-desc b{color:var(--ak-text)}
.ak-desc blockquote{margin:0 0 14px;padding:10px 16px;border-left:3px solid var(--ak-accent);background:var(--ak-surface-2);border-radius:0 8px 8px 0}
.ak-desc a{word-break:break-all}
