:root{
  --bg:#08162f;
  --bg-deep:#060f22;
  --card:#15284a;
  --card-soft:#132440;
  --muted:#9db4d8;
  --text:#edf4ff;
  --brand:#6ec7ff;
  --brand-strong:#3da9ff;
  --good:#38d8aa;
  --warn:#f7c35f;
  --bad:#f07f86;
  --border:rgba(172,206,255,0.24);
  --border-soft:rgba(172,206,255,0.16);
  --shadow:0 16px 30px rgba(4,10,25,0.42);
  --font-size:16px;
  --font-weight-normal:400;
  --font-weight-medium:500;
  --line-height:1.5;
  --text-xs:0.75rem;
  --text-sm:0.875rem;
  --text-base:1rem;
  --text-lg:1.125rem;
  --text-xl:1.25rem;
  --text-2xl:1.5rem;
  --text-3xl:1.875rem;
}

*{box-sizing:border-box}
html,body{min-height:100%}
html{font-size:var(--font-size)}
body{
  margin:0;
  font-family:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-size:var(--text-base);
  font-weight:var(--font-weight-normal);
  line-height:var(--line-height);
  background:
    radial-gradient(900px 520px at 2% -10%, rgba(80,160,255,0.35), transparent 60%),
    radial-gradient(780px 440px at 96% -8%, rgba(25,215,223,0.28), transparent 58%),
    linear-gradient(180deg, #0a1731 0%, #0c1c38 45%, #0a1931 100%);
  color:var(--text);
}

h1{
  font-size:var(--text-2xl);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
h2{
  font-size:var(--text-xl);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
h3{
  font-size:var(--text-lg);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
h4{
  font-size:var(--text-base);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
label{
  font-size:var(--text-base);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
button{
  font-size:var(--text-base);
  font-weight:var(--font-weight-medium);
  line-height:var(--line-height);
}
input,select,textarea{
  font-size:var(--text-base);
  font-weight:var(--font-weight-normal);
  line-height:var(--line-height);
}

a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:none}

.container{max-width:1120px;margin:0 auto;padding:20px 18px 22px}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  border:1px solid var(--border-soft);
  border-radius:18px;
  background:linear-gradient(140deg, rgba(18,34,67,0.92), rgba(13,29,58,0.82));
  box-shadow:var(--shadow);
}
.logo{
  display:inline-flex;
  align-items:center;
  gap:10px;
  color:var(--text);
  font-size:var(--text-2xl);
  font-weight:var(--font-weight-medium);
  letter-spacing:.25px;
}
.logo-mark{
  width:36px;
  height:36px;
  flex:0 0 36px;
}
.logo-text{line-height:1}
.logo-text span{color:#8ed7ff}

.navlinks{
  display:flex;
  gap:6px;
  flex-wrap:wrap;
  padding:6px;
  border-radius:14px;
  border:1px solid var(--border-soft);
  background:rgba(8,18,35,0.56);
}

.pill{
  border:1px solid var(--border-soft);
  padding:8px 10px;
  border-radius:12px;
  color:var(--text);
  background:rgba(255,255,255,0.03);
  transition:background .2s ease,border-color .2s ease,transform .2s ease;
}
.pill:hover{
  background:rgba(132,190,255,0.14);
  border-color:rgba(172,206,255,0.4);
}
.pill-download{
  border-color:rgba(108,224,165,0.58);
  color:#f2fff8;
  background:linear-gradient(180deg, rgba(48,158,106,0.9), rgba(34,131,86,0.92));
}
.pill-download:hover{
  background:linear-gradient(180deg, rgba(64,179,123,0.94), rgba(43,149,99,0.95));
  border-color:rgba(136,239,186,0.72);
}

.navpill{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:8px 12px;
  font-size:var(--text-base);
  font-weight:var(--font-weight-medium);
}
.navpill.active{
  background:linear-gradient(180deg,rgba(75,149,231,0.44),rgba(52,112,188,0.46));
  border-color:rgba(167,209,255,0.55);
  color:#ffffff;
}
.navpill.active:hover{transform:none}
.navicon{
  font-size:var(--text-base);
  line-height:1;
}

.hero{
  display:grid;
  grid-template-columns: 1.4fr .6fr;
  gap:16px;
  align-items:stretch;
  margin-top:16px;
}
@media (max-width:980px){
  .hero{grid-template-columns:1fr}
}

.card{
  border:1px solid var(--border-soft);
  background:linear-gradient(155deg, rgba(22,41,77,0.74), rgba(15,31,61,0.74));
  border-radius:18px;
  padding:18px;
  backdrop-filter: blur(8px);
  box-shadow:var(--shadow);
}

.h1{
  margin:0 0 10px;
  font-size:var(--text-2xl);
  line-height:var(--line-height);
  font-weight:var(--font-weight-medium);
}
.h2{
  margin:0 0 8px;
  font-size:var(--text-xl);
  line-height:var(--line-height);
  font-weight:var(--font-weight-medium);
}
.p{color:var(--muted);margin:8px 0 0;line-height:1.58}

.trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.badge{
  border:1px solid var(--border-soft);
  border-radius:999px;
  padding:6px 10px;
  font-size:var(--text-sm);
  color:#d7e8ff;
  background:rgba(255,255,255,0.04);
}

.grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(210px, 1fr));
  gap:14px;
  margin-top:14px;
}
@media (max-width:1000px){
  .grid{grid-template-columns:repeat(2, minmax(190px, 1fr))}
}
@media (max-width:700px){
  .grid{grid-template-columns:1fr}
}

.toolcard{
  display:flex;
  flex-direction:column;
  gap:12px;
  min-height:260px;
  padding:22px;
  border-radius:16px;
  border:1px solid rgba(153,194,255,0.26);
  background:linear-gradient(165deg, rgba(26,47,84,0.96), rgba(17,34,65,0.98));
}
.toolcard-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
}
.toolicon{
  width:48px;
  height:48px;
  border-radius:13px;
  border:1px solid rgba(170,206,255,0.34);
  background:linear-gradient(165deg, rgba(68,130,217,0.45), rgba(40,76,146,0.58));
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  font-size:var(--text-lg);
}
.tooltag{
  border:1px solid rgba(178,214,255,0.36);
  border-radius:999px;
  padding:6px 11px;
  font-size:var(--text-xs);
  font-weight:var(--font-weight-medium);
  letter-spacing:.75px;
  color:#cfebff;
  background:rgba(142,188,255,0.12);
}
.toolcard h3{
  margin:0;
  font-size:var(--text-xl);
  line-height:1.25;
  font-weight:var(--font-weight-medium);
}
.toolcard p{
  margin:0;
  color:var(--muted);
  line-height:1.5;
  flex:1;
}
.toolcard .go{
  margin-top:auto;
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:11px;
  border:1px solid rgba(178,215,255,0.27);
  background:linear-gradient(180deg, rgba(91,128,177,0.56), rgba(67,98,144,0.6));
  font-weight:var(--font-weight-medium);
  font-size:14px;
}
.toolcard .go:hover{
  background:linear-gradient(180deg, rgba(104,145,198,0.66), rgba(75,109,160,0.68));
  border-color:rgba(193,225,255,0.46);
}

.home-main-card{
  border-color:rgba(168,206,255,0.28);
  background:
    radial-gradient(450px 220px at 50% -6%, rgba(103,179,255,0.16), transparent 70%),
    linear-gradient(160deg, rgba(18,36,70,0.9), rgba(12,28,57,0.9));
}
.home-page .h1{
  background:linear-gradient(105deg,#f2f8ff 0%, #bfe5ff 52%, #89d0ff 100%);
  -webkit-background-clip:text;
  color:transparent;
}
.home-side-card{
  border-color:rgba(156,214,255,0.22);
  background:
    radial-gradient(250px 180px at 90% -12%, rgba(43,200,224,0.2), transparent 68%),
    linear-gradient(155deg, rgba(20,42,78,0.88), rgba(13,31,62,0.88));
}
.home-side-title{
  margin:0 0 6px;
  font-size:var(--text-lg);
}
.home-page .trust .badge:nth-child(1){background:rgba(78,133,224,0.26)}
.home-page .trust .badge:nth-child(2){background:rgba(55,210,185,0.2)}
.home-page .trust .badge:nth-child(3){background:rgba(111,159,255,0.26)}
.home-page .trust .badge:nth-child(4){background:rgba(98,124,223,0.26)}
.home-page .trust .badge:nth-child(5){background:rgba(64,192,219,0.24)}
.seo-copy{
  margin-top:16px;
  border-color:rgba(164,211,255,0.24);
  background:
    radial-gradient(380px 160px at 6% -18%, rgba(93,170,255,0.14), transparent 72%),
    linear-gradient(155deg, rgba(16,35,68,0.9), rgba(12,30,58,0.9));
}
.seo-links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}

.toolwrap{
  display:grid;
  grid-template-columns: 1fr 320px;
  gap:16px;
  margin-top:16px;
}
@media (max-width:1000px){
  .toolwrap{grid-template-columns:1fr}
}

.drop{
  border:1px dashed rgba(178,213,255,0.46);
  border-radius:16px;
  padding:16px;
  background:rgba(255,255,255,0.03);
}
.drop.dragover{
  outline:2px solid rgba(95,186,255,0.9);
  outline-offset:2px;
}

.row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:10px;
}
.row label{font-size:var(--text-base);color:var(--muted)}

input[type="text"],
input[type="number"],
input[type="color"],
select,
textarea{
  background:rgba(1,6,18,0.45);
  border:1px solid var(--border-soft);
  color:var(--text);
  border-radius:10px;
  padding:10px;
  min-width:180px;
}
textarea{
  resize:vertical;
  min-height:90px;
}
input[type="file"]{
  color:var(--muted);
}

button{
  border:1px solid rgba(108,189,255,0.48);
  background:linear-gradient(180deg, rgba(86,162,224,0.42), rgba(58,129,197,0.44));
  color:var(--text);
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
  font-weight:var(--font-weight-medium);
}
button:hover{
  background:linear-gradient(180deg, rgba(98,177,242,0.52), rgba(69,142,213,0.54));
}
button.action-green{
  border-color:rgba(84,220,176,0.58);
  background:linear-gradient(180deg, rgba(57,196,152,0.36), rgba(43,163,127,0.38));
}
button.action-green:hover{
  background:linear-gradient(180deg, rgba(69,213,166,0.5), rgba(49,178,139,0.52));
}

input[type="range"]{
  width:220px;
  margin-top:6px;
  accent-color:var(--good);
}

.small{font-size:var(--text-sm);color:var(--muted)}
.hr{
  height:1px;
  background:var(--border-soft);
  margin:14px 0;
}

.faq h3{margin:0 0 10px}
.faq details{
  border:1px solid var(--border-soft);
  border-radius:12px;
  padding:10px 12px;
  background:rgba(255,255,255,0.03);
  margin-bottom:10px;
}
.faq summary{cursor:pointer;font-weight:var(--font-weight-medium)}
.faq p{margin:8px 0 0;color:var(--muted);line-height:1.5}

.ads{
  border:1px solid var(--border-soft);
  border-radius:16px;
  padding:12px;
  background:rgba(255,255,255,0.03);
  color:var(--muted);
  font-size:var(--text-sm);
}
.ads .slot{
  border:1px dashed rgba(172,206,255,0.26);
  border-radius:12px;
  padding:10px;
  margin-top:10px;
  min-height:90px;
  display:flex;
  align-items:center;
  justify-content:center;
}

.footer{
  margin-top:18px;
  padding:18px 0;
  color:var(--muted);
  font-size:var(--text-sm);
  border-top:1px solid var(--border-soft);
}

@media (max-width:1080px){
  .nav{
    flex-direction:column;
    align-items:stretch;
  }
  .logo{
    justify-content:center;
    text-align:center;
  }
  .navlinks{
    flex-wrap:nowrap;
    overflow-x:auto;
    white-space:nowrap;
  }
  .toolcard h3{font-size:var(--text-lg)}
}

@media (max-width:680px){
  .container{padding:14px 12px 18px}
  .h1{font-size:var(--text-2xl)}
  .home-page .h1{font-size:var(--text-2xl)}
  .toolcard{padding:18px;min-height:0}
  .toolcard h3{font-size:var(--text-lg)}
}

/* Upload workflow pages */
.tool-page .tool-layout{
  grid-template-columns:minmax(0, 1fr) 380px;
  align-items:start;
  gap:18px;
}
.tool-page .tool-main{
  display:flex;
  flex-direction:column;
  gap:14px;
  min-width:0;
}
.tool-page .tool-sidebar{
  min-width:0;
}
.tool-page .tool-sidebar-inner{
  position:sticky;
  top:18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.tool-hero .h1{
  margin-bottom:8px;
  font-size:var(--text-3xl);
  letter-spacing:.2px;
}
.tool-note{
  margin-top:14px;
  border:1px solid rgba(106,177,255,0.34);
  border-radius:14px;
  padding:12px 14px;
  color:#c8dffb;
  background:linear-gradient(160deg, rgba(17,41,81,0.68), rgba(10,29,59,0.72));
  line-height:1.6;
}

.workflow-form{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.flow-step{
  padding:20px;
}
.step-head{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:14px;
}
.step-num{
  width:32px;
  height:32px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:var(--text-base);
  font-weight:var(--font-weight-medium);
  color:#dff2ff;
  border:1px solid rgba(101,174,255,0.42);
  background:linear-gradient(180deg, rgba(45,109,193,0.68), rgba(39,91,162,0.66));
}
.step-title{
  margin:0;
  font-size:var(--text-xl);
  line-height:var(--line-height);
  font-weight:var(--font-weight-medium);
}

.upload-drop{
  position:relative;
  border:1px dashed rgba(149,203,255,0.32);
  border-radius:16px;
  background:linear-gradient(160deg, rgba(27,50,87,0.68), rgba(18,37,68,0.72));
  padding:24px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:10px;
  transition:border-color .18s ease, background .18s ease, transform .18s ease;
}
.upload-drop.is-empty{
  border-style:dashed;
}
.upload-drop.dragover{
  border-color:rgba(114,195,255,0.92);
  background:linear-gradient(165deg, rgba(25,59,106,0.76), rgba(20,47,90,0.8));
  transform:translateY(-1px);
}
.upload-drop.has-file{
  border-style:solid;
  border-color:rgba(120,203,165,0.6);
  background:linear-gradient(165deg, rgba(23,66,74,0.52), rgba(18,56,68,0.58));
}
.drop-icon{
  width:58px;
  height:58px;
  border-radius:999px;
  border:1px solid rgba(161,210,255,0.3);
  background:linear-gradient(180deg, rgba(63,106,164,0.5), rgba(46,84,136,0.52));
  color:#d7ecff;
  font-size:var(--text-lg);
  font-weight:var(--font-weight-medium);
  display:flex;
  align-items:center;
  justify-content:center;
}
.drop-title{
  font-size:var(--text-xl);
  font-weight:var(--font-weight-medium);
  color:#ecf6ff;
  line-height:var(--line-height);
}
.upload-drop .drop-copy{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.upload-drop [data-filename]{
  color:#eaf4ff;
  font-weight:var(--font-weight-medium);
}
.upload-drop [data-filemeta]{
  color:#9bd0ff;
}
.drop-browse{
  margin-top:6px;
  border:1px solid rgba(130,200,255,0.54);
  background:linear-gradient(180deg, rgba(68,138,215,0.7), rgba(47,112,185,0.72));
  border-radius:10px;
  padding:10px 18px;
  color:#f6fbff;
  font-weight:var(--font-weight-medium);
}
.drop-browse:hover{
  background:linear-gradient(180deg, rgba(83,157,235,0.8), rgba(60,128,205,0.82));
}
.upload-drop input[type="file"]{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}

.profile-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(180px, 1fr));
  gap:12px;
}
.profile-card{
  position:relative;
  display:block;
  cursor:pointer;
}
.profile-card input{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
}
.profile-content{
  display:flex;
  flex-direction:column;
  gap:6px;
  min-height:148px;
  border-radius:14px;
  border:1px solid rgba(154,200,255,0.22);
  background:linear-gradient(170deg, rgba(22,43,78,0.9), rgba(17,35,65,0.9));
  padding:14px;
  transition:border-color .18s ease, background .18s ease, transform .18s ease;
}
.profile-card:hover .profile-content{
  border-color:rgba(155,214,255,0.45);
  transform:translateY(-1px);
}
.profile-card input:checked + .profile-content{
  border-color:rgba(91,176,255,0.9);
  background:linear-gradient(165deg, rgba(25,62,110,0.88), rgba(20,49,90,0.9));
  box-shadow:0 0 0 1px rgba(87,172,255,0.38) inset;
}
.profile-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}
.profile-name{
  font-size:var(--text-xl);
  line-height:1.2;
  font-weight:var(--font-weight-medium);
  color:#eff7ff;
}
.profile-desc{
  color:#9fbce0;
  line-height:1.45;
  flex:1;
  font-size:14px;
}
.profile-estimate{
  color:#63c2ff;
  font-weight:var(--font-weight-medium);
}
.profile-badge{
  display:inline-flex;
  align-items:center;
  border-radius:999px;
  padding:5px 9px;
  font-size:var(--text-xs);
  font-weight:var(--font-weight-medium);
  text-transform:uppercase;
  letter-spacing:.45px;
  line-height:1;
  white-space:nowrap;
  color:#e8fff3;
  background:rgba(35,203,128,0.9);
}

.options-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(160px, 1fr));
  gap:12px;
  margin-top:12px;
}
.options-grid.two-col{
  grid-template-columns:repeat(2, minmax(200px, 1fr));
}
.options-grid.one-col{
  grid-template-columns:1fr;
}
.field-block{
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:var(--text-base);
  color:#d1e5ff;
}
.field-block strong{
  font-size:var(--text-base);
  color:#e9f4ff;
}
.field-help{
  color:#8fb0d6;
  font-size:var(--text-sm);
  line-height:1.45;
}

.flow-submit{
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
}
.primary-action{
  width:100%;
  padding:14px 16px;
  font-size:var(--text-xl);
  line-height:var(--line-height);
  font-weight:var(--font-weight-medium);
  border-radius:12px;
  border:1px solid rgba(112,189,255,0.54);
  color:#eef8ff;
  background:linear-gradient(180deg, rgba(62,126,196,0.82), rgba(45,102,167,0.86));
}
.primary-action:hover{
  background:linear-gradient(180deg, rgba(77,145,218,0.9), rgba(58,117,187,0.9));
}
.primary-action.is-disabled,
.primary-action:disabled{
  cursor:not-allowed;
  opacity:.72;
  color:#b8cae0;
  border-color:rgba(129,168,212,0.36);
  background:linear-gradient(180deg, rgba(53,87,130,0.56), rgba(46,75,111,0.58));
}
.primary-action.is-busy{
  color:#e0f3ff;
}
.step-help{
  color:#9ab8da;
}
.status-msg{
  min-height:22px;
  border-radius:10px;
  padding:0;
  color:#9ab3d3;
}
.status-msg.has-text{
  padding:8px 10px;
  border:1px solid rgba(150,193,240,0.22);
  background:rgba(34,52,84,0.45);
}
.status-msg[data-tone="info"]{
  border-color:rgba(105,183,255,0.45);
  color:#b6defd;
}
.status-msg[data-tone="success"]{
  border-color:rgba(95,220,154,0.5);
  color:#beefd5;
  background:rgba(21,73,53,0.42);
}
.status-msg[data-tone="error"]{
  border-color:rgba(239,137,145,0.56);
  color:#ffdce0;
  background:rgba(100,28,40,0.42);
}

/* Status page */
.status-page .status-main{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.status-flow-card{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.status-queue{
  min-height:20px;
  margin-top:0;
  color:#b2c8e3;
}
.status-download-wrap{
  margin-top:2px;
}
.status-download-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.status-error{
  margin-top:2px;
}
.status-joke-card .p{
  margin-top:0;
}
.status-joke-box{
  border:1px solid rgba(143,198,252,0.28);
  border-radius:12px;
  padding:12px;
  color:#dcecff;
  background:rgba(18,44,81,0.56);
  line-height:1.52;
}
.status-joke-actions{
  margin-top:12px;
}
.status-joke-btn{
  width:100%;
}

.download-reminder{
  position:fixed;
  right:16px;
  bottom:16px;
  width:min(320px, calc(100vw - 24px));
  border-radius:12px;
  border:1px solid rgba(111,190,255,0.44);
  background:linear-gradient(165deg, rgba(20,47,86,0.96), rgba(14,33,63,0.96));
  box-shadow:0 14px 34px rgba(2,10,24,0.42);
  padding:10px 12px;
  z-index:1300;
  opacity:0;
  transform:translateY(10px);
  pointer-events:none;
  transition:opacity .16s ease, transform .16s ease;
}
.download-reminder.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.download-reminder-copy{
  color:#d9ebff;
  font-size:13px;
  line-height:1.4;
}
.download-reminder-actions{
  margin-top:8px;
  display:flex;
  align-items:center;
  gap:8px;
}
.download-reminder-link,
.download-reminder-later{
  border:1px solid rgba(111,190,255,0.42);
  border-radius:999px;
  padding:5px 10px;
  font-size:12px;
  font-weight:var(--font-weight-medium);
  text-decoration:none;
}
.download-reminder-link{
  color:#eef8ff;
  background:linear-gradient(180deg, rgba(67,133,205,0.85), rgba(47,102,166,0.9));
}
.download-reminder-link:hover{
  color:#ffffff;
}
.download-reminder-later{
  color:#b6cee7;
  background:rgba(34,56,87,0.9);
}

@media (max-width:760px){
  .download-reminder{
    right:12px;
    bottom:12px;
    width:calc(100vw - 24px);
  }
}

.sidebar-card h3{
  margin:0 0 10px;
  font-size:var(--text-xl);
  line-height:var(--line-height);
  font-weight:var(--font-weight-medium);
}
.sidebar-card.accent{
  border-color:rgba(119,184,255,0.33);
  background:
    radial-gradient(220px 120px at 92% -8%, rgba(74,186,255,0.2), transparent 66%),
    linear-gradient(165deg, rgba(20,40,76,0.9), rgba(13,31,62,0.9));
}
.tips-list,
.check-list{
  margin:0;
  padding:0;
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.tips-list li,
.check-list li{
  position:relative;
  padding-left:20px;
  line-height:1.45;
  color:#c2d7f0;
}
.tips-list li::before,
.check-list li::before{
  content:"";
  position:absolute;
  left:0;
  top:.55em;
  width:8px;
  height:8px;
  border-radius:999px;
  background:#54b2ff;
}
.check-list li::before{
  width:9px;
  height:9px;
  background:#35d293;
}
.privacy-line{
  margin:0;
  color:#d2e7ff;
  line-height:1.5;
}

.clean-accordion h3{
  margin:0 0 10px;
}
.clean-accordion details{
  border:0;
  border-top:1px solid rgba(147,196,248,0.2);
  border-radius:0;
  margin:0;
  padding:0;
  background:transparent;
}
.clean-accordion details:last-child{
  border-bottom:1px solid rgba(147,196,248,0.2);
}
.clean-accordion summary{
  list-style:none;
  position:relative;
  cursor:pointer;
  font-size:var(--text-lg);
  font-weight:var(--font-weight-medium);
  color:#eef5ff;
  padding:16px 28px 16px 0;
}
.clean-accordion summary::-webkit-details-marker{
  display:none;
}
.clean-accordion summary::after{
  content:"+";
  position:absolute;
  right:2px;
  top:14px;
  color:#8fb8e4;
  font-size:var(--text-xl);
  line-height:1;
}
.clean-accordion details[open] summary::after{
  content:"-";
}
.clean-accordion p{
  margin:0 0 14px;
  color:#a9c3e0;
  line-height:1.55;
}

/* QR page */
.qr-page .qr-layout{
  grid-template-columns:minmax(0, 1fr) 390px;
  align-items:start;
  gap:18px;
}
.qr-main{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.qr-sidebar{
  min-width:0;
}
.qr-sidebar-inner{
  position:sticky;
  top:18px;
  display:flex;
  flex-direction:column;
  gap:14px;
}

.qr-section{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.section-head{
  display:flex;
  align-items:flex-start;
  gap:10px;
}
.section-icon{
  flex:0 0 40px;
  width:40px;
  height:40px;
  border-radius:12px;
  border:1px solid rgba(138,200,255,0.34);
  color:#e4f3ff;
  background:linear-gradient(160deg, rgba(52,104,182,0.6), rgba(43,83,150,0.62));
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:var(--text-sm);
  font-weight:var(--font-weight-medium);
}
.section-icon.green{
  border-color:rgba(96,220,170,0.4);
  background:linear-gradient(160deg, rgba(39,126,102,0.7), rgba(32,105,84,0.7));
}
.section-icon.purple{
  border-color:rgba(184,134,255,0.38);
  background:linear-gradient(160deg, rgba(87,64,151,0.72), rgba(69,50,121,0.72));
}
.section-title{
  margin:0;
}
.section-subtitle{
  margin:2px 0 0;
  color:var(--muted);
}

.qr-dynamic-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
}
.qr-dynamic-grid .options-grid{
  margin-top:0;
}

.qr-color-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(220px, 1fr));
  gap:12px;
}
.qr-color-control{
  display:flex;
  align-items:center;
  gap:8px;
}
.qr-color-control input[type="color"]{
  width:74px;
  min-width:74px;
  height:42px;
  padding:4px;
  border-radius:10px;
  border:1px solid var(--border-soft);
  background:rgba(1,6,18,0.45);
  cursor:pointer;
}
.qr-color-control input[type="text"]{
  flex:1;
  min-width:0;
}

.qr-file-row{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  border:1px solid var(--border-soft);
  border-radius:10px;
  padding:6px 8px;
  background:rgba(1,6,18,0.45);
}
.qr-file-row input[type="file"]{
  position:absolute;
  width:1px;
  height:1px;
  opacity:0;
  pointer-events:none;
}
.qr-file-trigger{
  padding:8px 14px;
  border-radius:9px;
  border:1px solid rgba(136,196,255,0.4);
  background:linear-gradient(180deg, rgba(61,126,197,0.56), rgba(48,103,167,0.58));
  color:#ecf7ff;
}
.qr-file-name{
  color:#cfdef1;
}

.qr-note{
  margin-top:0;
}

.qr-preview-card h3{
  margin:0 0 4px;
}
.qr-preview-copy{
  margin:0;
  color:var(--muted);
}
.qr-preview-box{
  margin-top:12px;
  min-height:300px;
  border-radius:14px;
  border:1px dashed rgba(145,196,245,0.3);
  background:linear-gradient(165deg, rgba(37,58,90,0.62), rgba(28,47,77,0.66));
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:10px;
  padding:20px;
}
.qr-preview-placeholder{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  gap:10px;
}
.qr-preview-icon{
  width:76px;
  height:76px;
  border-radius:16px;
  border:1px solid rgba(145,196,245,0.26);
  color:#9db7d8;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:var(--text-xl);
  font-weight:var(--font-weight-medium);
}
.qr-preview-image{
  display:none;
  width:100%;
  max-width:310px;
  height:auto;
  border-radius:10px;
  background:#ffffff;
  padding:8px;
  border:1px solid rgba(145,196,245,0.28);
  box-shadow:0 10px 22px rgba(2,9,24,0.32);
}
.qr-download-btn{
  margin-top:12px;
}
.qr-download-btn:disabled{
  opacity:.62;
}

.qr-submit{
  margin-top:2px;
}
.qr-submit .primary-action{
  font-size:var(--text-xl);
}

@media (max-width:1200px){
  .tool-page .tool-layout{
    grid-template-columns:minmax(0, 1fr) 330px;
  }
  .qr-page .qr-layout{
    grid-template-columns:minmax(0, 1fr) 340px;
  }
}
@media (max-width:1024px){
  .tool-page .tool-layout{
    grid-template-columns:1fr;
  }
  .tool-page .tool-sidebar-inner{
    position:static;
  }
  .tool-hero .h1{
    font-size:var(--text-3xl);
  }
  .qr-page .qr-layout{
    grid-template-columns:1fr;
  }
  .qr-sidebar-inner{
    position:static;
  }
}
@media (max-width:760px){
  .tool-hero .h1{
    font-size:var(--text-2xl);
  }
  .step-title,
  .profile-name,
  .sidebar-card h3{
    font-size:var(--text-xl);
  }
  .drop-title{
    font-size:var(--text-xl);
  }
  .primary-action{
    font-size:var(--text-lg);
  }
  .profile-grid,
  .options-grid,
  .options-grid.two-col{
    grid-template-columns:1fr;
  }
  .qr-color-grid{
    grid-template-columns:1fr;
  }
}
