@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css');
@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Great+Vibes&family=Allura&family=Parisienne&family=Sacramento&family=Playfair+Display:ital,wght@0,600;1,700&display=swap");

/* tc-scoped:tc-wp-tool-root */

.tc-wp-tool-root {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
  display: flow-root;
  isolation: isolate;
  position: relative;
}
.tc-wp-tool-root img,
.tc-wp-tool-root video,
.tc-wp-tool-root svg,
.tc-wp-tool-root iframe {
  max-width: 100%;
  height: auto;
}

.tc-wp-tool-root #esg-wrap#esg-wrap{
  --esg-primary: #172554;
  --esg-secondary: #06b6d4;
  --esg-accent: #8b5cf6;
  --esg-soft-bg: #eef7ff;
  --esg-card-bg: rgba(255, 255, 255, .92);
  --esg-heading: #0f172a;
  --esg-body: #273449;
  --esg-muted: #64748b;
  --esg-border: rgba(30, 64, 175, .14);
  --esg-button-gradient: linear-gradient(135deg, #172554 0%, #2563eb 44%, #06b6d4 100%);
  --esg-shadow: 0 22px 65px rgba(15, 23, 42, .12);
  --esg-radius: 22px;
  --esg-section-gap: 16px;
  --esg-card-gap: 16px;
  --esg-control-gap: 12px;
  --esg-button-height: 46px;
  --esg-input-height: 48px;
  position: relative;
  width: 100%;
  overflow-x: hidden;
  box-sizing: border-box;
  padding: 20px 18px;
  background:
    radial-gradient(circle at 20% 0%, rgba(6, 182, 212, .18), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(139, 92, 246, .16), transparent 30%),
    linear-gradient(180deg, #f8fbff 0%, var(--esg-soft-bg) 100%);
  color: var(--esg-body);
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}.tc-wp-tool-root #esg-wrap#esg-wrap *, .tc-wp-tool-root #esg-wrap#esg-wrap *::before, .tc-wp-tool-root #esg-wrap#esg-wrap *::after{
  box-sizing: border-box;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-shell{
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  gap: var(--esg-section-gap);
  justify-items: center;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-hero{
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
  display: grid;
  gap: 8px;
  justify-items: center;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-title{
  margin: 0;
  max-width: 900px;
  color: var(--esg-heading);
  font-size: clamp(1.7rem, 8vw, 3.65rem);
  line-height: 1.04;
  letter-spacing: 0;
  font-weight: 800;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-subtitle{
  margin: 0;
  max-width: 720px;
  color: var(--esg-muted);
  font-size: clamp(.95rem, 2.8vw, 1.12rem);
  line-height: 1.55;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-results-grid{
  width: 100%;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card{
  background: var(--esg-card-bg);
  border: 1px solid var(--esg-border);
  border-radius: var(--esg-radius);
  box-shadow: var(--esg-shadow);
  padding: 18px;
  backdrop-filter: blur(18px);
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-control-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--esg-control-gap);
  align-items: end;
  justify-items: center;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-field, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-toggle-field, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-actions{
  width: 100%;
  display: grid;
  gap: 8px;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-label{
  color: var(--esg-heading);
  font-size: .86rem;
  font-weight: 700;
  line-height: 1.2;
  display: flex;
  justify-content: space-between;
  gap: 10px;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="text"].esg-input, .tc-wp-tool-root #esg-wrap#esg-wrap input[type="color"].esg-color, .tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range{
  width: 100%;
  font: inherit;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="text"].esg-input{
  height: var(--esg-input-height);
  border: 1px solid var(--esg-border);
  border-radius: 14px;
  background: #fff;
  color: var(--esg-heading);
  padding: 0 14px;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="text"].esg-input:focus, .tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn:focus-visible, .tc-wp-tool-root #esg-wrap#esg-wrap input[type="color"].esg-color:focus-visible, .tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range:focus-visible, .tc-wp-tool-root #esg-wrap#esg-wrap input[type="checkbox"].esg-toggle:focus-visible + .esg-toggle-ui{
  outline: 3px solid rgba(6, 182, 212, .28);
  outline-offset: 3px;
  border-color: rgba(6, 182, 212, .8);
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="color"].esg-color{
  height: var(--esg-input-height);
  padding: 5px;
  border: 1px solid var(--esg-border);
  border-radius: 14px;
  background: #fff;
  cursor: pointer;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range{
  -webkit-appearance: none;
  appearance: none;
  height: var(--esg-input-height);
  background: transparent;
  cursor: pointer;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range::-webkit-slider-runnable-track{
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(23, 37, 84, .95), rgba(6, 182, 212, .85));
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range::-moz-range-track{
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(23, 37, 84, .95), rgba(6, 182, 212, .85));
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range::-webkit-slider-thumb{
  -webkit-appearance: none;
  appearance: none;
  width: 24px;
  height: 24px;
  margin-top: -7px;
  border-radius: 50%;
  border: 4px solid #fff;
  background: var(--esg-accent);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .22);
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="range"].esg-range::-moz-range-thumb{
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 4px solid #fff;
  background: var(--esg-accent);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .22);
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toggle-field{
  min-height: var(--esg-input-height);
  grid-template-columns: auto 1fr;
  align-items: center;
  align-content: center;
  padding: 10px 12px;
  border: 1px solid var(--esg-border);
  border-radius: 14px;
  background: #fff;
  cursor: pointer;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="checkbox"].esg-toggle{
  position: absolute;
  opacity: 0;
  pointer-events: none;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toggle-ui{
  width: 48px;
  height: 28px;
  border-radius: 999px;
  background: #dbeafe;
  border: 1px solid rgba(37, 99, 235, .18);
  position: relative;
  transition: background .2s ease, border-color .2s ease;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toggle-ui::after{
  content: "";
  width: 22px;
  height: 22px;
  position: absolute;
  top: 2px;
  left: 2px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 5px 12px rgba(15, 23, 42, .22);
  transition: transform .2s ease;
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="checkbox"].esg-toggle:checked + .esg-toggle-ui{
  background: linear-gradient(135deg, var(--esg-primary), var(--esg-secondary));
  border-color: rgba(6, 182, 212, .55);
}.tc-wp-tool-root #esg-wrap#esg-wrap input[type="checkbox"].esg-toggle:checked + .esg-toggle-ui::after{
  transform: translateX(20px);
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toggle-text{
  color: var(--esg-heading);
  font-weight: 700;
  font-size: .9rem;
}.tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn{
  appearance: none;
  width: 100%;
  min-height: var(--esg-button-height);
  border: 0;
  border-radius: 14px;
  background: var(--esg-button-gradient);
  color: #fff;
  font: inherit;
  font-weight: 800;
  line-height: 1.15;
  padding: 11px 14px;
  cursor: pointer;
  box-shadow: 0 14px 24px rgba(37, 99, 235, .2);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
  touch-action: manipulation;
}.tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn:hover{
  transform: translateY(-2px);
  filter: brightness(1.04);
  box-shadow: 0 18px 30px rgba(37, 99, 235, .26);
}.tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn:active, .tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn.esg-btn-flash{
  transform: scale(.98);
  box-shadow: 0 0 0 4px rgba(6, 182, 212, .18), 0 12px 22px rgba(37, 99, 235, .18);
}.tc-wp-tool-root #esg-wrap#esg-wrap button[type="button"].esg-btn-secondary{
  background: linear-gradient(135deg, #f8fafc, #e0f2fe);
  color: var(--esg-primary);
  border: 1px solid rgba(30, 64, 175, .16);
  box-shadow: 0 10px 22px rgba(15, 23, 42, .08);
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-section-head{
  display: grid;
  gap: 4px;
  justify-items: center;
  text-align: center;
  margin-bottom: 14px;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card-title{
  margin: 0;
  color: var(--esg-heading);
  font-size: clamp(1.05rem, 3vw, 1.35rem);
  line-height: 1.2;
  font-weight: 800;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card-note{
  margin: 0;
  color: var(--esg-muted);
  font-size: .92rem;
  line-height: 1.45;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-canvas-frame{
  width: 100%;
  display: grid;
  justify-items: center;
  padding: 10px;
  border: 1px dashed rgba(37, 99, 235, .28);
  border-radius: 18px;
  background:
    linear-gradient(45deg, rgba(148, 163, 184, .12) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(148, 163, 184, .12) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, rgba(148, 163, 184, .12) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(148, 163, 184, .12) 75%);
  background-size: 22px 22px;
  background-position: 0 0, 0 11px, 11px -11px, -11px 0;
}.tc-wp-tool-root #esg-wrap#esg-wrap canvas.esg-canvas{
  width: 100%;
  max-width: 920px;
  height: 220px;
  border-radius: 14px;
  background: #fff;
  display: block;
  touch-action: none;
  border: 1px solid rgba(30, 64, 175, .12);
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-draw-actions{
  margin-top: 12px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  justify-items: center;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-preview{
  width: 100%;
  min-height: 138px;
  border-radius: 18px;
  border: 1px solid var(--esg-border);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 18px;
  color: var(--esg-primary);
  font-family: "Great Vibes", "Brush Script MT", cursive;
  font-size: clamp(2.2rem, 10vw, 4.5rem);
  line-height: 1.1;
  white-space: nowrap;
  overflow: auto;
  word-break: normal;
  overflow-wrap: normal;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-results-grid{
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  justify-items: center;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-result-card{
  width: 100%;
  min-height: 300px;
  display: grid;
  grid-template-rows: auto 1fr auto;
  gap: 12px;
  background: var(--esg-card-bg);
  border: 1px solid var(--esg-border);
  border-radius: var(--esg-radius);
  box-shadow: 0 16px 42px rgba(15, 23, 42, .1);
  padding: 16px;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-result-label{
  margin: 0;
  text-align: center;
  color: var(--esg-heading);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-result-preview{
  width: 100%;
  height: 142px;
  border-radius: 16px;
  border: 1px solid rgba(30, 64, 175, .12);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 16px;
  color: var(--esg-primary);
  white-space: nowrap;
  overflow: auto;
  word-break: normal;
  overflow-wrap: normal;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-placeholder{
  font-family: Inter, system-ui, sans-serif !important;
  font-size: .92rem !important;
  font-weight: 600 !important;
  font-style: normal !important;
  letter-spacing: 0 !important;
  color: var(--esg-muted) !important;
  line-height: 1.45 !important;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-result-actions{
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-self: end;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toast{
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(.96);
  z-index: 999999;
  opacity: 0;
  pointer-events: none;
  min-width: 180px;
  max-width: calc(100vw - 36px);
  padding: 14px 18px;
  border-radius: 999px;
  background: rgba(15, 23, 42, .94);
  color: #fff;
  text-align: center;
  font-weight: 800;
  box-shadow: 0 24px 60px rgba(15, 23, 42, .34);
  transition: opacity .2s ease, transform .2s ease;
}.tc-wp-tool-root #esg-wrap#esg-wrap .esg-toast.esg-toast-show{
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}@media (min-width: 640px) {.tc-wp-tool-root #esg-wrap#esg-wrap{
    padding: 24px 22px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-control-grid, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-results-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-draw-actions, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-result-actions{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }}@media (min-width: 768px) {.tc-wp-tool-root #esg-wrap#esg-wrap{
    --esg-section-gap: 22px;
    padding: 30px 28px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card{
    padding: 22px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-control-grid{
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }.tc-wp-tool-root #esg-wrap#esg-wrap canvas.esg-canvas{
    height: 240px;
  }}@media (min-width: 1024px) {.tc-wp-tool-root #esg-wrap#esg-wrap{
    --esg-section-gap: 24px;
    padding: 38px 36px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-card{
    padding: 24px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-control-grid, .tc-wp-tool-root #esg-wrap#esg-wrap .esg-results-grid{
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }}@media (min-width: 1200px) {.tc-wp-tool-root #esg-wrap#esg-wrap{
    padding: 44px;
  }.tc-wp-tool-root #esg-wrap#esg-wrap .esg-results-grid{
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }}.tc-wp-tool-root{
  position: relative !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  margin-top: 0 !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  z-index: 0 !important;
}

.tc-wp-tool-root .esg-clear-draw-btn {}
.tc-wp-tool-root .esg-control-card {}
.tc-wp-tool-root .esg-download-draw-btn {}
.tc-wp-tool-root .esg-draw-card {}
.tc-wp-tool-root .esg-preview-card {}
.tc-wp-tool-root .esg-reset-btn {}
.tc-wp-tool-root .esg-size-range {}
.tc-wp-tool-root .esg-size-value {}
.tc-wp-tool-root .esg-stroke-range {}
.tc-wp-tool-root .esg-stroke-value {}
.tc-wp-tool-root .esg-wrap {}