:root{
--bg:#f7f8fb;
--surface:#ffffff;
--ink:#111827;
--muted:#667085;
--line:#e5e7eb;
--soft:#eef8ff;
--brand:#0f8ff2;
--brand-dark:#06165c;
--danger:#dc2626;
--success:#16a34a;
--shadow:0 24px 80px rgba(17,24,39,.08);
--radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:radial-gradient(circle at top left,#ffffff 0,#f7f8fb 46%,#f2f4f8 100%);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;line-height:1.5;min-height:100vh}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1120px,calc(100% - 32px));margin-inline:auto}
.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.82);backdrop-filter:blur(18px);border-bottom:1px solid rgba(229,231,235,.72)}
.header-inner{height:82px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:-.04em;font-size:22px;min-width:0}
.brand img{width:auto;height:54px;max-width:230px;border-radius:0;box-shadow:none;object-fit:contain}
.site-nav{display:flex;align-items:center;gap:4px}
.site-nav a{padding:10px 12px;border-radius:999px;color:#344054;font-size:14px;font-weight:650}
.site-nav a:hover{background:#f3f4f6;color:#111827}
.menu-toggle{display:none;border:0;background:#111827;color:#fff;border-radius:12px;width:42px;height:42px;font-size:22px}
.page-shell{padding:28px 0 44px}
.card{background:rgba(255,255,255,.94);border:1px solid rgba(229,231,235,.9);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-grid{display:grid;grid-template-columns:1.65fr .85fr;gap:22px;align-items:stretch;margin-top:18px}
.hero-card{padding:42px}
.hero-card h1{font-size:clamp(34px,6vw,68px);line-height:.94;letter-spacing:-.075em;margin:10px 0 18px;max-width:850px}
.hero-card p{color:var(--muted);font-size:18px;max-width:760px;margin:0 0 24px}
.eyebrow{display:inline-flex;align-items:center;gap:8px;color:var(--brand-dark);font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:.12em}
.short-form,.admin-form{display:grid;gap:14px;margin-top:24px}
.short-form label,.admin-form label{display:grid;gap:8px;color:#344054;font-size:14px;font-weight:750}
input,textarea,select{width:100%;border:1px solid var(--line);border-radius:18px;background:#fff;color:var(--ink);font:inherit;padding:15px 16px;outline:none;transition:.2s ease}
textarea{resize:vertical;min-height:220px}
input:focus,textarea:focus,select:focus{border-color:rgba(16,185,129,.75);box-shadow:0 0 0 4px rgba(16,185,129,.12)}

.slug-field{display:flex;align-items:center;border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;transition:.2s ease}
.slug-field:focus-within{border-color:rgba(16,185,129,.75);box-shadow:0 0 0 4px rgba(16,185,129,.12)}
.slug-field input{border:0;border-radius:0;box-shadow:none!important;padding-left:10px;background:transparent}
.slug-prefix{flex:0 0 auto;padding:0 0 0 16px;color:var(--muted);font-weight:800;white-space:nowrap;font-size:14px}
.field-help{display:block;color:var(--muted);font-weight:650;font-size:13px;line-height:1.45;margin-top:2px}
.slug-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:-4px}
.slug-status{font-size:14px;font-weight:800;color:var(--muted);min-height:22px}
.slug-status.ok{color:#166534}
.slug-status.error{color:#991b1b}
.slug-status.loading{color:var(--brand-dark)}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn{border:0;background:var(--ink);color:#fff;padding:14px 20px;border-radius:999px;font-weight:800;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;box-shadow:0 12px 30px rgba(17,24,39,.18);transition:.2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-1px);box-shadow:0 16px 36px rgba(17,24,39,.22)}
.btn.full{width:100%}
.btn.ghost{background:#fff;color:#111827;border:1px solid var(--line);box-shadow:none}
.btn.disabled{pointer-events:none;opacity:.55}
.mini-panel{padding:30px;display:flex;flex-direction:column;justify-content:center;background:linear-gradient(180deg,#ffffff,#f9fafb)}
.mini-panel h2{font-size:26px;letter-spacing:-.04em;margin:0 0 12px}
ul{padding-left:18px;color:var(--muted)}
li{margin:8px 0}
.section{margin-top:24px}
.section-title{margin:0 0 16px}
.section-title h2,.section-title h1{font-size:clamp(28px,4vw,44px);line-height:1;letter-spacing:-.06em;margin:8px 0 0}
.section-title.compact h1{font-size:34px}
.feature-grid,.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.stats-grid{grid-template-columns:repeat(4,1fr);margin-bottom:18px}
.feature,.stat{padding:26px}
.feature strong{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:var(--soft);color:var(--brand-dark);font-size:18px;margin-bottom:16px}
.feature h3{font-size:22px;margin:0 0 8px;letter-spacing:-.04em}
.feature p{color:var(--muted);margin:0}
.stat span{display:block;color:var(--muted);font-weight:700;font-size:14px}
.stat strong{display:block;font-size:38px;letter-spacing:-.06em;margin-top:8px}
.result-card{padding:30px;margin:22px 0}
.result-card h2{font-size:32px;letter-spacing:-.05em;margin:8px 0 16px}
.copy-row,.search-row{display:flex;gap:10px;align-items:center}
.copy-row input{font-weight:750;color:var(--brand-dark)}
.alert{padding:14px 16px;border-radius:18px;margin-top:16px;font-weight:750}
.alert.error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}
.alert.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}
.redirect-grid{display:grid;grid-template-columns:1.4fr .6fr;gap:20px;align-items:start;margin-top:18px}
.redirect-card{padding:42px;text-align:center;overflow:hidden;position:relative}
.redirect-card h1{font-size:clamp(34px,5vw,58px);line-height:.96;letter-spacing:-.07em;margin:12px 0 16px}
.redirect-card p{color:var(--muted);font-size:18px}
.progress-orb{width:150px;height:150px;border-radius:50%;display:grid;place-items:center;margin:28px auto;background:radial-gradient(circle,#fff 0,#fff 54%,rgba(16,185,129,.15) 55%,rgba(16,185,129,.28) 100%);border:1px solid rgba(16,185,129,.25);box-shadow:inset 0 0 34px rgba(16,185,129,.12),0 20px 40px rgba(16,185,129,.12)}
.progress-orb span{font-size:54px;line-height:1;font-weight:900;letter-spacing:-.08em;color:var(--brand-dark)}
.progress-line{height:10px;border-radius:999px;background:#ecfdf5;overflow:hidden;margin:20px 0}
.progress-line span{display:block;width:0;height:100%;background:linear-gradient(90deg,#10b981,#059669);border-radius:inherit;transition:width 1s linear}
.muted{color:var(--muted);font-size:14px}
.auth-card{width:min(480px,100%);margin:20px auto;padding:34px}
.auth-card h1{font-size:42px;letter-spacing:-.06em;margin:10px 0 8px}
.admin-menu{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 18px}
.admin-menu a,.small-link{background:#fff;border:1px solid var(--line);padding:10px 14px;border-radius:999px;font-weight:800;color:#344054}
.admin-menu a:hover,.small-link:hover{background:#111827;color:#fff}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:separate;border-spacing:0;margin-top:16px;font-size:14px}
th,td{text-align:left;padding:14px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:#475467;font-size:12px;text-transform:uppercase;letter-spacing:.08em}
tr:last-child td{border-bottom:0}
.clip{max-width:360px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.inline-actions{display:flex;gap:6px;flex-wrap:wrap;margin:0}
.inline-actions button{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 10px;font-weight:800;cursor:pointer}
.inline-actions button:hover{background:#111827;color:#fff}
.admin-form.two-cols{grid-template-columns:repeat(2,1fr)}
.admin-form .wide{grid-column:1/-1}
.legal-page{padding:42px}
.legal-page h1{font-size:clamp(36px,5vw,58px);line-height:.98;letter-spacing:-.07em;margin:10px 0 18px}
.legal-page h2{font-size:25px;letter-spacing:-.04em;margin-top:28px}
.content-text{color:#475467;font-size:18px;white-space:normal}
.site-footer{border-top:1px solid rgba(229,231,235,.8);background:rgba(255,255,255,.78);padding:34px 0;color:#667085}
.footer-grid{display:grid;grid-template-columns:1fr 2fr;gap:24px;align-items:start}
.footer-grid strong{display:block;color:#111827;font-size:20px;margin-bottom:8px}
.footer-grid p{margin:0;max-width:360px}
.footer-grid nav{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.footer-grid nav a{padding:8px 10px;border-radius:999px;background:#f9fafb;border:1px solid #eef2f7;font-size:13px;font-weight:700}
.footer-copy{font-size:13px;margin-top:22px}
@media (max-width:900px){
.header-inner{height:auto;min-height:70px;flex-wrap:wrap;padding:12px 0}
.menu-toggle{display:block}
.site-nav{display:none;width:100%;flex-direction:column;align-items:stretch;padding-bottom:10px}
.site-nav.open{display:flex}
.site-nav a{border-radius:14px;background:#f9fafb}
.hero-grid,.redirect-grid,.footer-grid{grid-template-columns:1fr}
.feature-grid,.stats-grid{grid-template-columns:1fr 1fr}
.footer-grid nav{justify-content:flex-start}
.hero-card,.redirect-card,.legal-page{padding:30px}
}
@media (max-width:620px){
.container{width:min(100% - 22px,1120px)}
.page-shell{padding-top:16px}
.hero-card h1{font-size:40px}
.feature-grid,.stats-grid,.admin-form.two-cols{grid-template-columns:1fr}
.copy-row,.search-row{flex-direction:column;align-items:stretch}
.card{border-radius:22px}
.hero-card,.redirect-card,.legal-page{padding:24px}
.progress-orb{width:126px;height:126px}
.progress-orb span{font-size:44px}
}
.hero-clean{width:min(760px,100%);margin:18px auto 0}
.clean-card{padding:38px;text-align:left}
.clean-card h1{font-size:clamp(38px,7vw,72px);margin-bottom:12px}
.clean-card p{font-size:17px;margin-bottom:20px;max-width:520px}
.redirect-clean{width:min(620px,100%);margin:18px auto 0}
.redirect-clean .redirect-card{padding:38px}
.redirect-clean .redirect-card h1{font-size:clamp(72px,16vw,132px);margin:4px 0;line-height:.9}
.redirect-clean .redirect-card p{font-size:17px;margin:8px 0 18px}
.result-card{width:min(760px,100%);margin:18px auto;padding:26px}
.result-card h2{font-size:28px;margin-bottom:14px}
.short-form{margin-top:18px}
.site-header{position:relative}
.page-shell{padding-top:22px}
@media (max-width:620px){
.clean-card,.redirect-clean .redirect-card{padding:24px}
.clean-card h1{font-size:42px}
.redirect-clean .redirect-card h1{font-size:86px}
}
.btn.small{padding:10px 14px;font-size:13px;box-shadow:none}
.btn.copied{transform:none}
.copy-row.compact{gap:8px}
.copy-row.compact input{min-width:220px}
@media (max-width:720px){.copy-row.compact input{min-width:0;width:100%}}
.result-card .copy-row{display:flex;align-items:stretch;gap:12px;width:100%;margin-bottom:14px}
.result-card .copy-row input{flex:1 1 auto;min-width:0;height:68px}
.result-card .copy-row .btn{flex:0 0 auto;min-width:110px;height:58px;align-self:center}
.result-card > .small-link{display:inline-flex;align-items:center;justify-content:center;margin-top:0;min-height:52px;padding:12px 30px;line-height:1}
@media (max-width:720px){.result-card .copy-row{flex-direction:column;align-items:stretch}.result-card .copy-row input{height:auto}.result-card .copy-row .btn{width:100%;height:auto;align-self:stretch}.result-card > .small-link{width:100%;margin-top:0}}

.result-card{display:flex;flex-direction:column;align-items:flex-start;overflow:hidden}
.result-card .copy-row{display:grid!important;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:12px;width:100%;margin:0!important}
.result-card .copy-row input{width:100%;min-width:0;height:68px;display:block}
.result-card .copy-row .btn{height:58px;min-width:110px;align-self:center;justify-self:end;display:flex}
.result-card > a.small-link{display:flex!important;align-items:center;justify-content:center;width:max-content;max-width:100%;min-height:52px;margin-top:20px!important;clear:both;position:relative;z-index:2;line-height:1;padding:12px 30px}
@media (max-width:720px){.result-card .copy-row{grid-template-columns:1fr}.result-card .copy-row .btn{width:100%;height:auto;justify-self:stretch}.result-card > a.small-link{width:100%;margin-top:16px!important}}

.clean-card > form.short-form + a.small-link{
  display:inline-flex!important;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  min-height:52px;
  margin-top:24px!important;
  clear:both;
  position:relative;
  z-index:2;
  line-height:1;
  padding:12px 30px;
}
.clean-card .short-form{
  margin-bottom:0!important;
}
@media (max-width:720px){
  .clean-card > form.short-form + a.small-link{
    width:100%;
    margin-top:18px!important;
  }
}

/* NewLinky branding */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media (max-width:620px){.brand img{height:44px;max-width:190px}.header-inner{min-height:68px}}

@media (max-width:620px){.slug-field{flex-direction:column;align-items:stretch}.slug-prefix{padding:12px 16px 0}.slug-actions .btn{width:100%}}

/* Painel de usuário */
.quick-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;align-items:center}
.auth-note{margin-top:16px;color:var(--muted);font-size:15px}
.auth-note a{font-weight:800;color:#0b63f6}
.user-menu a{border-color:rgba(14,165,233,.22)}
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:18px}
.user-page .stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}
@media (max-width:1080px){.user-page .stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.report-grid{grid-template-columns:1fr}}
@media (max-width:620px){.quick-links .btn,.quick-links .small-link{width:100%;justify-content:center}.user-page .stats-grid{grid-template-columns:1fr}}

/* Gerador de QR Code */
.qr-page-card{padding:30px;overflow:hidden}
.qr-grid{display:grid;grid-template-columns:1fr 1fr minmax(280px,.9fr);gap:18px;align-items:start;margin-top:20px}
.qr-controls{display:grid;gap:14px;align-content:start}
.qr-controls label{display:grid;gap:8px;color:#344054;font-size:14px;font-weight:750}
.form-split{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.check-line{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;gap:10px;border:1px solid var(--line);border-radius:18px;padding:14px 16px;background:#fff}
.check-line input{width:auto;min-width:18px;height:18px;padding:0;accent-color:var(--brand-dark)}
.qr-actions{display:grid;gap:10px;margin-top:2px}
.qr-preview{position:sticky;top:20px;display:grid;gap:14px;background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid var(--line);border-radius:26px;padding:18px;box-shadow:0 18px 60px rgba(17,24,39,.07)}
.qr-preview-head h2{margin:6px 0 0;font-size:26px;letter-spacing:-.04em;word-break:break-word}
.qr-preview-head p{margin:4px 0 0;color:var(--muted);font-size:13px;word-break:break-word}
.qr-preview-box{display:grid;place-items:center;background:#fff;border:1px dashed rgba(15,143,242,.25);border-radius:22px;padding:14px;min-height:260px;overflow:hidden}
.qr-preview-box svg{width:100%;height:auto;max-height:560px;display:block}
.mini-action{display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 10px;font-weight:800;color:#344054}
.mini-action:hover{background:#111827;color:#fff}
@media (max-width:1080px){.qr-grid{grid-template-columns:1fr 1fr}.qr-preview{grid-column:1/-1;position:relative;top:auto}.qr-preview-box svg{max-width:520px}}
@media (max-width:720px){.qr-grid,.form-split{grid-template-columns:1fr}.qr-page-card{padding:20px}.qr-preview-box{min-height:220px}.qr-actions .btn{width:100%}}
@media print{.site-header,.site-footer,.admin-menu,.qr-controls,.qr-actions,.copy-row,.field-help{display:none!important}.page-shell{padding:0}.container{width:100%}.qr-page-card{border:0;box-shadow:none;padding:0}.qr-grid{display:block}.qr-preview{box-shadow:none;border:0;position:static}.qr-preview-head{display:none}.qr-preview-box{border:0;padding:0}.qr-preview-box svg{max-width:100%;width:100%}}

/* Ajustes QR Code visível na home e ações do link gerado */
.result-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px;width:100%}
.result-actions .small-link{display:inline-flex!important;align-items:center;justify-content:center;min-height:52px;padding:12px 30px;line-height:1}
.qr-link{background:#ecfdf5!important;border-color:#bbf7d0!important;color:#047857!important}
.qr-link:hover{background:#047857!important;color:#fff!important}
.home-qr-section{margin:24px auto 0;width:min(1120px,100%)}
.home-qr-section .section-title p{color:var(--muted);max-width:760px;margin:8px 0 0}
@media (max-width:720px){.result-actions .small-link{width:100%}.home-qr-section{margin-top:18px}}

/* Abas da página inicial: Encurtador ou QR Code */
.home-tool-tabs{width:min(1120px,100%);margin:18px auto 0}
.tool-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px;background:rgba(255,255,255,.8);border:1px solid var(--line);border-radius:999px;padding:8px;margin:0 auto 18px;box-shadow:0 18px 60px rgba(17,24,39,.06)}
.tool-tab{border:0;border-radius:999px;background:transparent;color:#475467;font:inherit;font-weight:900;padding:16px 18px;cursor:pointer;transition:.2s ease;letter-spacing:-.02em}
.tool-tab:hover{background:#f3f4f6;color:#111827}
.tool-tab.active{background:#111827;color:#fff;box-shadow:0 14px 34px rgba(17,24,39,.18)}
.tool-tab-panel{display:none}
.tool-tab-panel.active{display:block}
.home-tool-tabs .hero-clean{width:min(760px,100%);margin:0 auto}
.home-tool-tabs .home-qr-section{margin:0 auto;width:min(1120px,100%)}
.qr-created-box{border:1px solid #bbf7d0;background:#f0fdf4;border-radius:22px;padding:16px;display:grid;gap:10px}
.qr-created-box h2{font-size:22px;line-height:1.05;letter-spacing:-.04em;margin:0;color:#064e3b}
.qr-created-box p{margin:0;color:#166534;font-size:14px}
@media (max-width:620px){.tool-tabs{grid-template-columns:1fr;border-radius:22px}.tool-tab{border-radius:16px}.home-tool-tabs{margin-top:10px}}

/* Correção visual da prévia do QR Code: evita cortes e organiza melhor os controles */
.qr-page-card{
  overflow:visible;
}
.qr-grid,
.qr-controls,
.qr-preview,
.qr-preview-box{
  min-width:0;
}
.qr-preview{
  max-width:100%;
  overflow:visible;
  align-self:start;
}
.qr-preview-head{
  min-width:0;
}
.qr-preview-box{
  width:100%;
  min-height:340px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:auto;
  padding:20px;
}
.qr-preview-box svg{
  width:min(100%,560px);
  max-width:100%;
  height:auto;
  max-height:none;
  flex:0 0 auto;
}
.qr-preview .copy-row.compact{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:10px;
  width:100%;
}
.qr-preview .copy-row.compact input{
  min-width:0;
  width:100%;
}
.qr-preview .copy-row.compact .btn{
  min-width:max-content;
  height:52px;
  box-shadow:none;
}

@media (min-width:1081px){
  .qr-grid{
    grid-template-columns:minmax(0,1fr) minmax(380px,420px);
    grid-auto-rows:auto;
    gap:22px;
  }
  .qr-grid > .qr-controls:nth-of-type(1){
    grid-column:1;
    grid-row:1;
  }
  .qr-grid > .qr-controls:nth-of-type(2){
    grid-column:1;
    grid-row:2;
  }
  .qr-grid > .qr-preview{
    grid-column:2;
    grid-row:1 / span 2;
    position:sticky;
    top:20px;
  }
}

@media (max-width:1080px){
  .qr-preview-box{
    min-height:300px;
  }
  .qr-preview-box svg{
    width:min(100%,520px);
  }
}

@media (max-width:720px){
  .qr-preview{
    padding:14px;
    border-radius:22px;
  }
  .qr-preview-box{
    min-height:240px;
    padding:12px;
    border-radius:18px;
  }
  .qr-preview-box svg{
    width:100%;
  }
  .qr-preview .copy-row.compact{
    grid-template-columns:1fr;
  }
  .qr-preview .copy-row.compact .btn{
    width:100%;
    min-width:0;
  }
}

.status-pill{display:inline-flex;align-items:center;border:1px solid #bbf7d0;background:#f0fdf4;color:#166534;border-radius:999px;padding:4px 8px;font-size:11px;margin-left:6px}
.inline-actions button[value="deleted"]{border-color:#fecaca;color:#991b1b}
.inline-actions button[value="deleted"]:hover{background:#991b1b;color:#fff}
.inline-actions button[value="blocked"]{border-color:#fed7aa;color:#9a3412}
.inline-actions button[value="blocked"]:hover{background:#9a3412;color:#fff}
