:root{
  --bg:#f4f5fb;
  --panel:rgba(255,255,255,.78);
  --panel-solid:#ffffff;
  --ink:#241f33;
  --ink-soft:#6b6480;
  --line:rgba(40,30,70,.10);
  --accent:#6c5ce7;
  --accent-2:#00cec9;
  --accent-grad:linear-gradient(135deg,#6c5ce7,#00cec9);
  --shadow:0 18px 50px -22px rgba(50,30,90,.45);
  --radius:20px;
  --radius-sm:13px;
  font-synthesis:none;
}
[data-theme="dark"]{
  --bg:#0f0d1a;
  --panel:rgba(28,24,44,.72);
  --panel-solid:#1b1730;
  --ink:#f1eefb;
  --ink-soft:#a79fc4;
  --line:rgba(255,255,255,.09);
  --shadow:0 22px 60px -25px rgba(0,0,0,.7);
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;padding:0}
body{
  font-family:'Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);
  color:var(--ink);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.aurora{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.55;
  background:
    radial-gradient(40vw 40vw at 12% 8%,rgba(108,92,231,.40),transparent 60%),
    radial-gradient(38vw 38vw at 88% 18%,rgba(0,206,201,.35),transparent 60%),
    radial-gradient(45vw 45vw at 70% 95%,rgba(253,121,168,.30),transparent 60%);
  filter:blur(10px);
}

/* Topbar */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:calc(16px + env(safe-area-inset-top,0px)) calc(clamp(16px,4vw,40px) + env(safe-area-inset-right,0px)) 16px calc(clamp(16px,4vw,40px) + env(safe-area-inset-left,0px));
  position:sticky;top:0;z-index:30;
  backdrop-filter:blur(14px);
  background:linear-gradient(var(--bg),transparent);
}
/* Native apps draw under the status bar; guarantee clearance even if the
   WebView reports no safe-area inset. */
html.native .topbar{ padding-top:max(calc(16px + env(safe-area-inset-top,0px)), 42px); }
html.native .footer{ padding-bottom:calc(40px + env(safe-area-inset-bottom,0px)); }
.brand{display:flex;align-items:center;gap:10px}
.brand-mark svg{width:34px;height:34px;display:block}
.brand-mark svg rect:first-child{fill:var(--accent)}
.brand-mark svg g rect{fill:#fff}
.brand-name{font-weight:800;font-size:22px;letter-spacing:-.5px;
  background:var(--accent-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.brand-by{font-size:12px;font-weight:600;color:var(--ink-soft);margin-left:-2px;align-self:flex-end;padding-bottom:3px}
.topbar-actions{display:flex;align-items:center;gap:10px}
.badge{font-size:12px;font-weight:600;color:var(--ink-soft);
  border:1px solid var(--line);padding:6px 11px;border-radius:999px;background:var(--panel)}
.icon-btn{border:1px solid var(--line);background:var(--panel);border-radius:12px;
  width:40px;height:40px;font-size:18px;cursor:pointer;color:var(--ink)}
.icon-btn:hover{transform:translateY(-1px)}

/* Layout */
.layout{
  display:grid;grid-template-columns:1.15fr .85fr;gap:22px;
  max-width:1180px;margin:0 auto;padding:8px clamp(16px,4vw,40px) 40px;
  align-items:start;
}
.panel{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);backdrop-filter:blur(16px);padding:clamp(18px,3vw,28px);
}
.hero-title{font-size:clamp(24px,3.4vw,32px);margin:0 0 6px;letter-spacing:-.6px;line-height:1.1}
.hero-sub{margin:0 0 20px;color:var(--ink-soft);font-size:15px;max-width:52ch}

/* Type tabs */
.type-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.type-tab{
  display:flex;align-items:center;gap:7px;border:1px solid var(--line);
  background:var(--panel-solid);color:var(--ink);border-radius:999px;
  padding:9px 14px;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;
}
.type-tab .ic{font-size:16px}
.type-tab:hover{border-color:var(--accent)}
.type-tab.active{background:var(--accent-grad);color:#fff;border-color:transparent;
  box-shadow:0 8px 20px -8px var(--accent)}

/* Forms */
.content-form{display:flex;flex-direction:column;gap:14px;margin-bottom:8px}
.fld{display:flex;flex-direction:column;gap:6px}
.fld.row{flex-direction:row;gap:12px}
.fld.row>*{flex:1}
.fld label,.field label{font-size:13px;font-weight:600;color:var(--ink-soft)}
input[type=text],input[type=url],input[type=email],input[type=tel],
input[type=number],input[type=password],input[type=datetime-local],input[type=date],input[type=time],textarea,select{
  width:100%;min-width:0;border:1px solid var(--line);background:var(--panel-solid);color:var(--ink);
  border-radius:var(--radius-sm);padding:12px 14px;font-size:15px;font-family:inherit;outline:none;transition:.15s;
}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,92,231,.18)}
textarea{resize:vertical;min-height:90px}
select{cursor:pointer;appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238b85a8' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
.checkbox-line{display:flex;align-items:center;gap:10px}
.checkbox-line input{width:20px;height:20px;accent-color:var(--accent)}
.checkbox-line label{font-size:14px;color:var(--ink)}

/* Accordion */
.accordion{border:1px solid var(--line);border-radius:var(--radius-sm);margin-top:14px;
  background:var(--panel-solid);overflow:hidden}
.accordion>summary{
  list-style:none;cursor:pointer;padding:15px 18px;font-weight:700;font-size:15px;
  display:flex;align-items:center;justify-content:space-between;user-select:none;
}
.accordion>summary::-webkit-details-marker{display:none}
.accordion .chev{transition:.2s;color:var(--ink-soft)}
.accordion[open] .chev{transform:rotate(180deg)}
.accordion-body{padding:4px 18px 20px;display:flex;flex-direction:column;gap:16px}

/* Presets */
.presets{display:flex;flex-wrap:wrap;gap:10px}
.preset{width:46px;height:46px;border-radius:13px;border:2px solid var(--line);cursor:pointer;
  padding:0;position:relative;overflow:hidden;transition:.15s}
.preset:hover{transform:translateY(-2px) scale(1.04)}
.preset.active{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,92,231,.25)}
.preset span{position:absolute;inset:9px;border-radius:5px}

/* Field grids */
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px}
.field.wide{grid-column:1/-1}
.field.check{flex-direction:row;align-items:center;justify-content:space-between}
.field.check input{width:22px;height:22px;accent-color:var(--accent)}
input[type=color]{width:100%;height:44px;border:1px solid var(--line);border-radius:var(--radius-sm);
  background:var(--panel-solid);cursor:pointer;padding:4px}
input[type=range]{width:100%;accent-color:var(--accent);cursor:pointer}
.val{float:right;font-weight:700;color:var(--accent)}

/* Segmented */
.seg{display:flex;border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden}
.seg button{flex:1;border:none;background:var(--panel-solid);color:var(--ink-soft);
  padding:11px;font-weight:600;font-size:14px;cursor:pointer}
.seg button.active{background:var(--accent-grad);color:#fff}

/* Logo */
.hint{font-size:13px;color:var(--ink-soft);margin:0}
.logo-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.file-btn{background:var(--accent-grad);color:#fff;padding:11px 16px;border-radius:var(--radius-sm);
  font-weight:600;font-size:14px;cursor:pointer;display:inline-block}
.ghost-btn{background:transparent;border:1px solid var(--line);color:var(--ink);
  padding:10px 14px;border-radius:var(--radius-sm);font-weight:600;cursor:pointer}
.logo-name{font-size:13px;color:var(--ink-soft);overflow:hidden;text-overflow:ellipsis;max-width:140px;white-space:nowrap}

/* Preview */
.preview{align-self:center}
.preview-sticky{position:sticky;top:84px;display:flex;flex-direction:column;gap:14px}
.qr-stage{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;
  background:repeating-conic-gradient(var(--line) 0% 25%,transparent 0% 50%) 0 0/22px 22px,var(--panel-solid);
  border:1px solid var(--line);border-radius:var(--radius);padding:24px}

/* Single export button on the QR's top-right + its menu */
.export-fab{position:absolute;top:12px;right:12px;z-index:4;width:44px;height:44px;border-radius:50%;
  border:none;background:var(--accent-grad);color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 18px -5px var(--accent),0 0 0 2px var(--panel-solid)}
.export-fab svg{display:block;margin-top:-1px}
.export-fab:hover{transform:translateY(-1px)}
.export-fab[aria-expanded="true"]{filter:brightness(.95)}
.export-menu{position:absolute;top:62px;right:12px;z-index:6;min-width:196px;
  background:var(--panel-solid);border:1px solid var(--line);border-radius:15px;
  box-shadow:var(--shadow);padding:6px;display:flex;flex-direction:column;gap:2px;
  animation:pop .16s ease both}
.export-menu button{display:flex;align-items:center;gap:10px;width:100%;text-align:left;
  border:none;background:transparent;color:var(--ink);font-size:14px;font-weight:600;
  font-family:inherit;padding:11px 12px;border-radius:10px;cursor:pointer}
.export-menu button:hover{background:var(--panel)}
.qr-canvas{border-radius:14px;overflow:hidden;line-height:0;
  filter:drop-shadow(0 14px 30px rgba(50,30,90,.18));max-width:100%}
.qr-canvas canvas,.qr-canvas svg{display:block;max-width:100%;height:auto !important;border-radius:8px}
.scan-tip{margin:0;font-size:13px;color:var(--ink-soft);font-weight:600}
.size-row{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink-soft)}

.export-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.export-actions:has(.share){grid-template-columns:1fr 1fr}
.btn{border:1px solid var(--line);background:var(--panel-solid);color:var(--ink);
  border-radius:var(--radius-sm);padding:13px 10px;font-weight:700;font-size:14px;cursor:pointer;transition:.15s}
.btn:hover{transform:translateY(-2px);border-color:var(--accent)}
.btn.primary{background:var(--accent-grad);color:#fff;border-color:transparent;box-shadow:0 10px 24px -10px var(--accent)}
.btn.share{background:#fd79a8;color:#fff;border-color:transparent}
.toast{min-height:18px;text-align:center;font-size:13px;font-weight:600;color:var(--accent);margin:0;transition:.2s}

/* Install button */
.install-btn{border:1px solid transparent;background:var(--accent-grad);color:#fff;font-weight:700;
  font-size:13px;padding:9px 14px;border-radius:999px;cursor:pointer;white-space:nowrap}
.install-btn:hover{transform:translateY(-1px)}

/* Account button + modal */
.account-btn{border:1px solid var(--line);background:var(--panel-solid);color:var(--ink);font-weight:700;
  font-size:13px;padding:8px 14px;border-radius:999px;cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:7px}
.account-btn:hover{border-color:var(--accent)}
.account-btn img{width:24px;height:24px;border-radius:50%;margin:-4px -6px -4px -4px}
.account-card{max-width:min(92vw,400px);padding:26px 24px}
.account-title{margin:6px 0 4px;font-size:20px;letter-spacing:-.3px}
.account-sub{margin:0 0 18px;color:var(--ink-soft);font-size:14px}
.account-note{margin:14px 0 0;font-size:12px;color:var(--ink-soft)}
.sso-slot{display:flex;justify-content:center;min-height:44px;margin-bottom:10px}
.sso-btn{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 14px;font-weight:600;
  font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.sso-btn.google{background:#fff;color:#3c4043;border-color:#dadce0;font-weight:600}
.sso-btn.google::before{content:"";width:17px;height:17px;background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 48 48'%3E%3Cpath fill='%23EA4335' d='M24 9.5c3.5 0 6.6 1.2 9.1 3.6l6.8-6.8C35.9 2.4 30.4 0 24 0 14.6 0 6.5 5.4 2.6 13.2l7.9 6.1C12.4 13.3 17.7 9.5 24 9.5z'/%3E%3Cpath fill='%234285F4' d='M46.1 24.5c0-1.6-.1-3.1-.4-4.5H24v9h12.4c-.5 2.9-2.1 5.3-4.6 7l7.1 5.5c4.2-3.9 6.6-9.6 6.6-17z'/%3E%3Cpath fill='%23FBBC05' d='M10.5 28.3c-.5-1.4-.8-2.9-.8-4.3s.3-3 .8-4.3l-7.9-6.1C1 16.6 0 20.2 0 24s1 7.4 2.6 10.5l7.9-6.2z'/%3E%3Cpath fill='%2334A853' d='M24 48c6.5 0 11.9-2.1 15.9-5.8l-7.1-5.5c-2 1.4-4.6 2.2-8.8 2.2-6.3 0-11.6-3.8-13.5-9.3l-7.9 6.1C6.5 42.6 14.6 48 24 48z'/%3E%3C/svg%3E")}
.sso-btn.apple{background:#000;color:#fff;border-color:#000}
.sso-btn.apple::before{content:"";width:15px;height:15px;background:#fff;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16.4 12.8c0-2.6 2.1-3.8 2.2-3.9-1.2-1.8-3.1-2-3.8-2-1.6-.2-3.1.9-3.9.9s-2-.9-3.4-.9c-1.7 0-3.3 1-4.2 2.6-1.8 3.1-.5 7.7 1.3 10.2.9 1.2 1.9 2.6 3.3 2.5 1.3-.1 1.8-.8 3.4-.8s2 .8 3.4.8 2.3-1.2 3.2-2.5c1-1.4 1.4-2.8 1.4-2.9-.1 0-2.6-1-2.6-3.9zM14 5.4c.7-.9 1.2-2.1 1.1-3.4-1 0-2.3.7-3 1.6-.7.8-1.3 2-1.1 3.2 1.1.1 2.3-.6 3-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16.4 12.8c0-2.6 2.1-3.8 2.2-3.9-1.2-1.8-3.1-2-3.8-2-1.6-.2-3.1.9-3.9.9s-2-.9-3.4-.9c-1.7 0-3.3 1-4.2 2.6-1.8 3.1-.5 7.7 1.3 10.2.9 1.2 1.9 2.6 3.3 2.5 1.3-.1 1.8-.8 3.4-.8s2 .8 3.4.8 2.3-1.2 3.2-2.5c1-1.4 1.4-2.8 1.4-2.9-.1 0-2.6-1-2.6-3.9zM14 5.4c.7-.9 1.2-2.1 1.1-3.4-1 0-2.3.7-3 1.6-.7.8-1.3 2-1.1 3.2 1.1.1 2.3-.6 3-1.4z'/%3E%3C/svg%3E") center/contain no-repeat}
.acc-avatar{width:64px;height:64px;border-radius:50%;border:2px solid var(--line);object-fit:cover;background:var(--panel)}
.acc-stat{margin:10px 0 16px;font-size:14px;color:var(--ink-soft)}
.acc-stat strong{color:var(--accent);font-size:16px}
.acc-keys{border-top:1px solid var(--line);padding-top:14px;margin-bottom:16px;text-align:left}
.acc-keys-head{display:flex;align-items:center;justify-content:space-between;font-weight:700;font-size:14px;margin-bottom:10px}
.key-list{display:flex;flex-direction:column;gap:8px}
.key-row{display:flex;align-items:center;gap:8px;background:var(--panel);border:1px solid var(--line);
  border-radius:10px;padding:9px 11px;font-size:12px}
.key-row code{flex:1;font-family:ui-monospace,Menlo,Consolas,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.key-row button{border:none;background:transparent;cursor:pointer;font-size:14px;color:var(--ink-soft);padding:2px 4px}
.key-row button:hover{color:var(--accent)}

/* QR as a tappable, zoomable button */
button.qr-canvas{position:relative;border:none;background:transparent;padding:0;cursor:zoom-in;display:block}
.qr-canvas .zoom-hint{position:absolute;left:50%;bottom:9px;transform:translateX(-50%);
  background:rgba(20,12,40,.68);color:#fff;font-size:11px;font-weight:700;letter-spacing:.2px;
  padding:5px 11px;border-radius:999px;opacity:0;transition:.18s;pointer-events:none;
  backdrop-filter:blur(4px);white-space:nowrap;z-index:2}
.qr-canvas:hover .zoom-hint{opacity:1}
@media (hover:none){.qr-canvas .zoom-hint{opacity:.92}}

/* Zoom modal */
.qr-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.qr-modal-backdrop{position:absolute;inset:0;background:rgba(15,10,28,.74);backdrop-filter:blur(9px);animation:fade .2s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.qr-modal-card{position:relative;background:var(--panel-solid);border:1px solid var(--line);border-radius:26px;
  padding:24px;max-width:min(92vw,520px);box-shadow:var(--shadow);text-align:center;
  animation:pop .25s cubic-bezier(.16,1,.3,1) both}
@keyframes pop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:none}}
.qr-modal-close{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;
  border:1px solid var(--line);background:var(--panel);color:var(--ink);font-size:15px;cursor:pointer;z-index:2}
.qr-modal-canvas{line-height:0;border-radius:18px;overflow:hidden;margin:6px auto 16px;width:min(78vw,420px)}
.qr-modal-canvas canvas,.qr-modal-canvas svg{display:block;width:100%!important;height:auto!important}
.qr-modal-tip{margin:0 0 16px;font-size:13px;color:var(--ink-soft);font-weight:600}
.qr-modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Footer */
.footer{text-align:center;padding:24px 20px 40px;font-size:13px;color:var(--ink-soft)}
.footer a{color:var(--accent);text-decoration:none;font-weight:600}
.footer a:hover{text-decoration:underline}
.foot-sep{margin:0 6px;opacity:.5}

/* Responsive — mobile first priority */
@media (max-width:880px){
  .layout{grid-template-columns:1fr;gap:14px}
  /* Header scrolls away for a fullscreen feel */
  .topbar{position:static}
  /* Pin the real QR preview to the top so it stays visible while you edit */
  .preview{order:-1;position:sticky;top:0;z-index:25;padding:12px 14px 10px;
    background:var(--panel-solid);
    box-shadow:0 14px 30px -18px rgba(40,20,90,.55)}
  html.native .preview{padding-top:calc(10px + env(safe-area-inset-top,0px))}
  .preview-sticky{position:static;gap:6px}
  .qr-stage{padding:10px}
  .qr-canvas{max-width:min(42vw,158px)}
  .scan-tip{display:none}
  .size-row{display:none}              /* keep the pinned bar compact; exports use the default size */
  .toast{min-height:0}                 /* don't reserve empty space under the QR */
  .fld.row{flex-direction:column}      /* stack half-fields (e.g. Event Starts/Ends) so they don't overflow */
  .hero-title{font-size:24px}
  .badge{display:none}
}
@media (max-width:480px){
  .topbar{padding:12px 16px}
  .panel{padding:18px 15px;border-radius:18px}
  .field-grid{grid-template-columns:1fr}
  .qr-stage{padding:16px}
  .type-tab{padding:8px 12px;font-size:13px}
  .export-actions{gap:8px}
}
@media (prefers-reduced-motion:reduce){*{transition:none !important}}
