/*
Theme Name: InfraApp
Theme URI: https://infrakeyboards.com
Author: Infra Keyboards
Description: Infra Keyboards APK showcase theme with optional Google Play importer.
Version: 1.1.0
Text Domain: infraapp
*/



:root{
  --bg:#ffffff;
  --fg:#0f172a;
  --muted:#64748b;
  --card:#ffffff;
  --border:#e2e8f0;
  --accent:#0ea5e9;
  --accent-2:#14b8a6;
  --shadow: 0 10px 30px rgba(2,6,23,.08);
  --radius: 16px;
  --container: 1180px;
}

[data-theme="dark"]{
  --bg:#0b1220;
  --fg:#e5e7eb;
  --muted:#94a3b8;
  --card:#0f172a;
  --border:#1f2a3a;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji";
  background:var(--bg);
  color:var(--fg);
  line-height:1.55;
}
img{max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
a:hover{color:var(--accent);}

.container{max-width:var(--container);margin:0 auto;padding:0 16px;}

.site-header{
  position:sticky; top:0; z-index:50;
  backdrop-filter:saturate(180%) blur(10px);
  background: color-mix(in srgb, var(--bg) 80%, transparent);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;gap:16px;min-height:64px;}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;}
.brand .logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--accent),var(--accent-2));box-shadow:var(--shadow);}
.brand span{font-size:18px;}

.nav{margin-left:auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.nav a{padding:8px 10px;border-radius:10px;color:var(--muted);font-weight:600;}
.nav a:hover{background:color-mix(in srgb, var(--accent) 12%, transparent);color:var(--fg);}

.header-actions{display:flex;align-items:center;gap:10px;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--fg);
  box-shadow: 0 1px 0 rgba(2,6,23,.03);
  cursor:pointer;
}
.btn:hover{border-color:color-mix(in srgb, var(--accent) 35%, var(--border));}
.btn.primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:white;}
.btn.primary:hover{filter:brightness(1.03);}

.search{flex:1;min-width:240px;max-width:520px;}
.search form{display:flex;gap:10px;}
.search input{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--fg);
  outline:none;
}
.search input:focus{border-color:color-mix(in srgb, var(--accent) 60%, var(--border));}

.hero{padding:34px 0 10px;}
.hero-card{
  border:1px solid var(--border);
  background:linear-gradient(180deg, color-mix(in srgb,var(--accent) 10%, var(--card)), var(--card));
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:16px;
}
.hero h1{margin:0 0 8px;font-size:28px;letter-spacing:-.03em;}
.hero p{margin:0;color:var(--muted);}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px;}
.badge{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border:1px solid var(--border);border-radius:999px;color:var(--muted);background:color-mix(in srgb, var(--bg) 70%, transparent);}

.grid{display:grid;gap:14px;}
.grid.apps{grid-template-columns:repeat(4,minmax(0,1fr));}
@media (max-width: 980px){.grid.apps{grid-template-columns:repeat(3,minmax(0,1fr));}.hero-card{grid-template-columns:1fr;}}
@media (max-width: 720px){.grid.apps{grid-template-columns:repeat(2,minmax(0,1fr));}.search{max-width:unset;}}
@media (max-width: 420px){.grid.apps{grid-template-columns:1fr;}}

.card{
  border:1px solid var(--border);
  background:var(--card);
  border-radius:var(--radius);
  box-shadow: 0 8px 20px rgba(2,6,23,.06);
  overflow:hidden;
}
.card .pad{padding:14px;}

.app-card{display:flex;gap:12px;align-items:flex-start;}
.app-icon{width:56px;height:56px;border-radius:14px;flex:0 0 auto;overflow:hidden;border:1px solid var(--border);background:color-mix(in srgb, var(--bg) 70%, transparent);}
.app-icon__placeholder{
  width:100%;height:100%;
  display:grid;place-items:center;
  font-weight:900;
  color:white;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
}
.app-title{font-weight:800;line-height:1.2;margin:0 0 4px;}
.app-meta{color:var(--muted);font-size:13px;display:flex;gap:10px;flex-wrap:wrap;}
.stars{display:inline-flex;gap:2px;align-items:center;color:color-mix(in srgb, var(--accent) 80%, #f59e0b);} 

.section{padding:18px 0;}
.section-title{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:0 0 10px;}
.section-title h2{margin:0;font-size:18px;letter-spacing:-.02em;}
.section-title a{color:var(--muted);font-weight:700;}

.single-wrap{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;padding:18px 0;}
@media(max-width:980px){.single-wrap{grid-template-columns:1fr;}}

.kv{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.kv .item{border:1px solid var(--border);border-radius:14px;padding:12px;background:color-mix(in srgb, var(--bg) 75%, transparent);}
.kv .k{font-size:12px;color:var(--muted);}
.kv .v{font-weight:800;margin-top:2px;}

.downloads{display:grid;gap:10px;}
.dl-row{display:flex;gap:10px;align-items:center;justify-content:space-between;border:1px solid var(--border);border-radius:14px;padding:12px;background:color-mix(in srgb, var(--bg) 75%, transparent);}
.dl-row .left{display:flex;flex-direction:column;gap:2px;}
.dl-row .left .small{font-size:12px;color:var(--muted);}

.screens{display:flex;gap:10px;overflow:auto;padding:12px;scroll-snap-type:x mandatory;}
.screens img{height:320px;border-radius:16px;border:1px solid var(--border);scroll-snap-align:start;}

.site-footer{border-top:1px solid var(--border);padding:26px 0;margin-top:24px;color:var(--muted);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr;}}

.widget{margin:0 0 14px;}
.widget h3{margin:0 0 10px;color:var(--fg);}

.notice{padding:12px 14px;border-radius:14px;border:1px dashed var(--border);color:var(--muted);background:color-mix(in srgb,var(--accent) 8%, transparent);} 

/* ---------- Advanced UI additions (Appyn-like) ---------- */

.home-banner{border:1px solid var(--border);border-radius:var(--radius);background:var(--card);box-shadow:0 8px 20px rgba(2,6,23,.06);padding:16px;display:grid;place-items:center;min-height:96px;}
.home-banner.placeholder{background:color-mix(in srgb,var(--bg) 75%, transparent);}
.home-banner .muted{color:var(--muted);font-weight:800;letter-spacing:.06em;}

.carousel{position:relative;}
.carousel-track{display:flex;gap:14px;overflow:auto;padding:4px 0 10px;scroll-snap-type:x mandatory;scrollbar-width:thin;}
.carousel-item{flex:0 0 auto;min-width:300px;scroll-snap-align:start;}
@media(max-width:720px){.carousel-item{min-width:260px;}}
.carousel-btn{position:absolute;top:40%;transform:translateY(-50%);width:40px;height:40px;border-radius:999px;border:1px solid var(--border);background:color-mix(in srgb,var(--bg) 80%, transparent);backdrop-filter:saturate(180%) blur(10px);box-shadow:0 10px 25px rgba(2,6,23,.12);cursor:pointer;display:grid;place-items:center;font-size:22px;color:var(--fg);}
.carousel-btn:hover{border-color:color-mix(in srgb,var(--accent) 35%, var(--border));}
.carousel-btn[data-carousel-btn="prev"]{left:-8px;}
.carousel-btn[data-carousel-btn="next"]{right:-8px;}
@media(max-width:980px){.carousel-btn{display:none;}}

/* Live search dropdown */
[data-infraapp-search]{position:relative;}
.infra-search__dropdown{position:absolute;left:0;right:0;top:calc(100% + 8px);border:1px solid var(--border);background:var(--card);border-radius:16px;box-shadow:0 18px 50px rgba(2,6,23,.18);overflow:hidden;z-index:60;}
.infra-search__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-top:1px solid color-mix(in srgb,var(--border) 70%, transparent);}
.infra-search__item:first-child{border-top:none;}
.infra-search__item:hover{background:color-mix(in srgb,var(--accent) 10%, transparent);}
.infra-search__item img{width:34px;height:34px;border-radius:10px;border:1px solid var(--border);object-fit:cover;flex:0 0 auto;}
.infra-search__ico{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;background:color-mix(in srgb,var(--accent) 12%, transparent);border:1px solid var(--border);}
.infra-search__txt{display:flex;flex-direction:column;min-width:0;flex:1;}
.infra-search__title{font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.infra-search__meta{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.infra-search__tag{font-size:11px;font-weight:900;letter-spacing:.08em;color:var(--muted);border:1px solid var(--border);padding:4px 8px;border-radius:999px;background:color-mix(in srgb,var(--bg) 70%, transparent);}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,Apple Color Emoji,Segoe UI Emoji;
  background:var(--bg);
  color:var(--fg);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
a:hover{color:var(--accent)}
img{max-width:100%;height:auto}

.infra-container{max-width:var(--container);margin:0 auto;padding:0 18px}

/* Header */
.infra-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border)}
[data-theme="dark"] .infra-header{background:rgba(11,18,32,.85)}
.infra-header__row{display:flex;align-items:center;gap:14px;padding:12px 0}
.infra-brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:.2px}
.infra-brand__logo{width:34px;height:34px;border-radius:10px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white}
.infra-nav{margin-left:auto;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.infra-nav a{font-weight:600;color:var(--muted)}
.infra-nav a:hover{color:var(--fg)}

.infra-search{flex:1;min-width:220px;max-width:520px}
.infra-search form{display:flex;gap:10px}
.infra-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--fg);outline:none}
.infra-input:focus{border-color:rgba(14,165,233,.7);box-shadow:0 0 0 4px rgba(14,165,233,.18)}

.infra-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:999px;border:1px solid var(--border);background:var(--card);cursor:pointer;color:var(--fg);font-weight:600}
.infra-btn:hover{border-color:rgba(14,165,233,.55)}
.infra-btn--primary{border-color:transparent;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:white}

/* Hero */
.infra-hero{padding:28px 0 10px}
.infra-hero__grid{display:grid;grid-template-columns: 1.4fr .6fr;gap:18px;align-items:stretch}
@media (max-width: 980px){.infra-hero__grid{grid-template-columns:1fr}}
.infra-hero__card{background:linear-gradient(135deg, rgba(14,165,233,.14), rgba(20,184,166,.10));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}
.infra-hero h1{margin:0 0 6px;font-size:34px;line-height:1.1}
.infra-hero p{margin:0;color:var(--muted)}

.infra-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.infra-chip{padding:8px 12px;border:1px solid var(--border);border-radius:999px;background:var(--card);color:var(--muted);font-weight:600}
.infra-chip:hover{color:var(--fg);border-color:rgba(14,165,233,.55)}

/* Layout */
.infra-main{padding:18px 0 44px}
.infra-grid{display:grid;grid-template-columns: 1fr 340px;gap:18px;align-items:start}
@media (max-width: 1100px){.infra-grid{grid-template-columns:1fr}}

.infra-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}

/* App cards */
.app-grid{display:grid;grid-template-columns: repeat(3, 1fr);gap:14px}
@media (max-width: 980px){.app-grid{grid-template-columns: repeat(2, 1fr)}}
@media (max-width: 620px){.app-grid{grid-template-columns: 1fr}}

.app-card{padding:14px;display:flex;gap:12px;align-items:flex-start}
.app-icon{width:58px;height:58px;border-radius:16px;overflow:hidden;border:1px solid var(--border);flex:0 0 auto}
.app-title{margin:0;font-size:16px;line-height:1.2}
.app-meta{margin-top:4px;color:var(--muted);font-size:13px}
.app-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.badge{font-size:12px;font-weight:700;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted);background:rgba(148,163,184,.12)}
.badge--new{background:rgba(20,184,166,.14);color:var(--fg)}
.badge--updated{background:rgba(14,165,233,.14);color:var(--fg)}
.badge--manual{background:rgba(245,158,11,.14);color:var(--fg)}

/* Single app */
.app-header{padding:18px}
.app-header__top{display:flex;gap:16px;align-items:center}
@media (max-width: 680px){.app-header__top{align-items:flex-start}}
.app-header__title{margin:0;font-size:26px;line-height:1.15}
.rating{display:flex;gap:8px;align-items:center;color:var(--muted);font-weight:700}

.kv{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:14px}
@media (max-width: 680px){.kv{grid-template-columns:1fr}}
.kv .item{padding:12px;border:1px solid var(--border);border-radius:14px;background:rgba(148,163,184,.06)}
.kv .k{color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.kv .v{margin-top:4px;font-weight:700}

.screens{padding:0 18px 18px}
.screens__row{display:flex;gap:10px;overflow:auto;scroll-snap-type:x mandatory;padding-bottom:6px}
.screens__row img{height:320px;border-radius:16px;border:1px solid var(--border);scroll-snap-align:start}
@media (max-width: 680px){.screens__row img{height:240px}}

/* Carousel controls (Appyn-style minimal) */
.carousel__btns{display:flex;gap:8px;align-items:center}
.carousel__btn{width:34px;height:34px;border-radius:999px;border:1px solid var(--border);background:var(--card);color:var(--text);cursor:pointer;display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.06)}
.carousel__btn:hover{transform:translateY(-1px)}

/* Screenshot lightbox */
.infraapp-lightbox{position:fixed;inset:0;z-index:9999}
.infraapp-lightbox__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.infraapp-lightbox__dialog{position:absolute;inset:24px;display:flex;align-items:center;justify-content:center}
.infraapp-lightbox__dialog img{max-width:100%;max-height:100%;border-radius:18px;border:1px solid rgba(255,255,255,.15);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.infraapp-lightbox__close{position:absolute;top:18px;right:18px;width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:rgba(0,0,0,.35);color:#fff;font-size:22px;cursor:pointer}
.infraapp-lightbox__close:hover{background:rgba(0,0,0,.5)}

.app-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

/* Sidebar */
.sidebar{padding:14px}
.widget{margin-bottom:16px}
.widget h3{margin:0 0 10px;font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.widget ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.widget li a{display:flex;gap:10px;align-items:center;padding:10px;border:1px solid var(--border);border-radius:14px}
.widget li a:hover{border-color:rgba(14,165,233,.55)}

/* Footer */
.infra-footer{border-top:1px solid var(--border);padding:26px 0;color:var(--muted)}
.infra-footer__row{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}

/* WP content */
.entry{padding:18px}
.entry h2{margin:0 0 10px}
.entry p{color:var(--muted)}
.entry-content a{color:var(--accent)}
.entry-content a:hover{text-decoration:underline}

/* Accessibility */
.screen-reader-text{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
