
:root{
  --bg:#0b0f14;
  --bg2:#0f1520;
  --card:rgba(255,255,255,.06);
  --card2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.12);
  --text:#f5f7ff;
  --muted:rgba(245,247,255,.72);
  --muted2:rgba(245,247,255,.56);
  --accent:#ff4d8d;
  --accent2:#ffd36e;
  --accent3:#64d2ff;
  --shadow:0 18px 55px rgba(0,0,0,.38);
  --r:18px;
  --r2:24px;
  --max:1160px;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --serif: ui-serif, Georgia, Cambria, "Times New Roman", serif;
}
*{box-sizing:border-box}
html,body{height:100%; margin:0; padding:0; overflow-x:hidden;}
body{
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(900px 520px at 18% 12%, rgba(255,77,141,.24), transparent 60%),
    radial-gradient(900px 520px at 80% 15%, rgba(100,210,255,.20), transparent 60%),
    radial-gradient(1000px 650px at 55% 110%, rgba(255,211,110,.16), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}
a{color:inherit; text-decoration:none}
a:hover{text-decoration:underline}
img,svg{max-width:100%; height:auto}
.container{max-width:var(--max); margin:0 auto; padding:20px}
.shell{border-radius:var(--r2); border:1px solid rgba(255,255,255,.08); background:rgba(255,255,255,.03); box-shadow:var(--shadow)}
.topbar{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(14px);
  background: rgba(9,12,20,.68);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.navwrap{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:14px 18px}
.brand{display:flex; align-items:center; gap:10px; min-width: 240px}
.logo{
  width:40px; height:40px; border-radius:14px;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 12px 26px rgba(255,77,141,.22);
  display:grid; place-items:center;
}
.logo svg{width:22px; height:22px}
.brand strong{display:block; font-weight:900; letter-spacing:.2px}
.brand span{display:block; color:var(--muted2); font-size:12px; margin-top:1px}
.menu{display:flex; gap:12px; flex-wrap:wrap; justify-content:center}
.menu a{font-weight:750; font-size:14px; color:var(--muted); padding:9px 10px; border-radius:14px}
.menu a:hover{background:rgba(255,255,255,.06); text-decoration:none; color:var(--text)}
.menu a.active{background:rgba(255,77,141,.16); border:1px solid rgba(255,77,141,.22); color:var(--text)}
.searchTop{
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  border-radius:999px; padding:8px 12px; min-width:260px
}
.searchTop input{width:100%; border:0; outline:none; background:transparent; color:var(--text); font-size:14px}
.searchTop input::placeholder{color:rgba(245,247,255,.45)}
.iconbtn{
  display:none; width:42px; height:42px; border-radius:14px;
  border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:var(--text);
}
.iconbtn:hover{background:rgba(255,255,255,.09); cursor:pointer}
.mobileMenu{display:none; padding:12px 18px 18px; border-top:1px solid rgba(255,255,255,.08)}
.mobileMenu a{
  display:block; padding:12px 12px; border-radius:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10);
  margin-top:10px; font-weight:800;
}
.mobileMenu a:hover{text-decoration:none; background:rgba(255,255,255,.07)}
.hero{padding:26px 22px 18px}
.heroGrid{display:grid; grid-template-columns:1.22fr .88fr; gap:16px; align-items:stretch}
.card{background:var(--card); border:1px solid var(--border); border-radius:var(--r); box-shadow: 0 10px 28px rgba(0,0,0,.22)}
.pad{padding:20px}
.kicker{color:var(--muted2); font-weight:900; letter-spacing:.22px; text-transform:uppercase; font-size:12px}
.h1{font-size: clamp(36px, 4vw, 54px); line-height:1.02; margin:0; letter-spacing:-.7px}
.lead{color:var(--muted); font-size:18px; line-height:1.5; margin:12px 0 0}
.pills{display:flex; flex-wrap:wrap; gap:10px; margin-top:14px}
.pill{font-size:12px; padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04); color:var(--muted)}
.btns{display:flex; gap:10px; flex-wrap:wrap; margin-top:16px}
.btn{display:inline-flex; align-items:center; gap:10px; padding:12px 14px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); font-weight:900}
.btn.primary{background:linear-gradient(135deg, rgba(255,77,141,.92), rgba(255,211,110,.90)); border:0; color:#1b0a14}
.btn:hover{text-decoration:none; filter:brightness(1.05)}
.hr{height:1px; background:rgba(255,255,255,.10); margin:14px 0}
.startTitle{text-align:center; margin:0 0 10px; font-weight:950}
.startList{display:flex; flex-direction:column; gap:10px}
.startItem{display:flex; align-items:center; justify-content:space-between; gap:12px; padding:14px 14px; border-radius:16px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10)}
.startItem strong{display:block; font-size:15px}
.startItem span{display:block; color:var(--muted2); font-size:13px; margin-top:3px}
.badge{font-size:12px; font-weight:950; padding:8px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.12); background:rgba(255,77,141,.14)}
.section{padding:0 22px 22px}
.section h2{margin:18px 0 10px; font-size:20px}
.grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.postCard{padding:16px}
.postCard h3{margin:0; font-size:16px; line-height:1.25}
.meta{color:var(--muted2); font-size:12px; margin-top:8px}
.postCard p{color:var(--muted); font-size:13px; line-height:1.55; margin:10px 0 0}
.postCard:hover{background:rgba(255,255,255,.07)}
.layout{display:grid; grid-template-columns:1fr 360px; gap:16px; align-items:start}
.article{padding:22px}
.article h1{font-size:40px; line-height:1.08; margin:0}
.article .meta2{color:var(--muted2); margin-top:10px; font-size:14px}
.article p{font-family:var(--serif); font-size:18px; line-height:1.75; color:rgba(245,247,255,.86)}
.article h2{margin-top:24px; margin-bottom:10px; font-size:22px}
.article ul{font-family:var(--serif); font-size:18px; line-height:1.75; color:rgba(245,247,255,.86)}
.article li{margin:6px 0}
.callout{padding:14px 16px; border-radius:16px; background:rgba(100,210,255,.10); border:1px solid rgba(100,210,255,.20); color:rgba(245,247,255,.92); margin:18px 0; font-family:var(--sans)}
.sidebar .box{padding:16px}
.sidebar h3{margin:0; font-size:16px}
.sidebar p{color:var(--muted2); font-size:13px; line-height:1.5}
.sidebar input{width:100%; margin-top:10px; padding:12px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.06); color:var(--text); outline:none}
.sidebar input::placeholder{color:rgba(245,247,255,.50)}
.sideList{display:flex; flex-direction:column; gap:10px; margin-top:10px}
.sideList a{display:block; padding:12px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.10); background:rgba(255,255,255,.04); font-weight:850}
.sideList a:hover{text-decoration:none; background:rgba(255,255,255,.07)}
.footer{padding:18px 22px 22px; color:var(--muted2); font-size:13px}
.footerGrid{display:grid; grid-template-columns:1.2fr 1fr 1fr; gap:14px}
.footer strong{display:block; color:var(--text); margin-bottom:8px}
.footer ul{list-style:none; padding:0; margin:0}
.footer li{margin:8px 0}
.cookie{
 position:fixed; left:16px; right:16px; bottom:16px; max-width:980px; margin:0 auto;
 border-radius:18px; background:rgba(9,12,20,.92); border:1px solid rgba(255,255,255,.12); box-shadow:var(--shadow);
 padding:14px; display:none;
}
.cookie .row{display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap}
.cookie p{margin:0; color:var(--muted); font-size:13px; line-height:1.45}
.cookie .actions{display:flex; gap:10px; flex-wrap:wrap}
.cookie button{padding:10px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:var(--text); font-weight:950; cursor:pointer}
.cookie button.primary{background:linear-gradient(135deg, rgba(255,77,141,.92), rgba(255,211,110,.90)); border:0; color:#1b0a14}
.toolGrid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.toolCard{padding:16px}
.toolCard h3{margin:0; font-size:16px}
.toolCard p{margin:10px 0 0; color:var(--muted); font-size:13px; line-height:1.5}
.formRow{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:10px}
.input{width:100%; padding:12px 12px; border-radius:14px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.06); color:var(--text); outline:none}
.label{font-size:12px; color:var(--muted2); margin-top:8px}
.actionRow{display:flex; gap:10px; flex-wrap:wrap; margin-top:12px}
.actionRow button{padding:12px 14px; border-radius:14px; border:1px solid rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:var(--text); font-weight:950; cursor:pointer}
.actionRow button.primary{background:linear-gradient(135deg, rgba(255,77,141,.92), rgba(255,211,110,.90)); border:0; color:#1b0a14}
.output{margin-top:12px; padding:14px 14px; border-radius:16px; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.10); color:rgba(245,247,255,.92)}
.small{font-size:12px; color:var(--muted2)}
.note{padding:14px 16px; border-radius:16px; background:rgba(255,211,110,.10); border:1px solid rgba(255,211,110,.20); color:rgba(245,247,255,.92)}
@media (max-width:980px){
  .heroGrid{grid-template-columns:1fr}
  .layout{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(2,1fr)}
  .toolGrid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:860px){
  .menu{display:none}
  .iconbtn{display:inline-grid; place-items:center}
  .searchTop{display:none}
  .grid{grid-template-columns:1fr}
  .toolGrid{grid-template-columns:1fr}
  .footerGrid{grid-template-columns:1fr}
}
