
:root{
  --bg1:#f4f7fb;
  --bg2:#eef3f9;
  --panel:rgba(255,255,255,.88);
  --line:rgba(20,32,55,.08);
  --line-strong:rgba(20,32,55,.14);
  --text:#0f1c2d;
  --muted:#67768a;
  --shadow:0 18px 44px rgba(14,24,42,.08);
  --shadow-hover:0 24px 60px rgba(14,24,42,.14);
  --radius:26px;
  --brand-soft:rgba(31,111,100,.10);
  --gold-soft:rgba(200,168,90,.12);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--ui-font,'Cairo',system-ui,sans-serif);
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(200,168,90,.15), transparent 24%),
    radial-gradient(circle at top left, rgba(31,111,100,.10), transparent 22%),
    linear-gradient(180deg,var(--bg1),var(--bg2));
  -webkit-tap-highlight-color:transparent;
}
button,input,select,textarea{font:inherit}
a{color:inherit}
.pageWrap{max-width:1320px;margin:0 auto;padding:22px;position:relative}
.heroGlow{position:absolute;inset:0 auto auto 50%;width:min(760px,92vw);height:320px;transform:translateX(-50%);background:radial-gradient(circle, rgba(255,255,255,.95) 0%, rgba(255,255,255,.55) 34%, rgba(255,255,255,0) 72%);pointer-events:none;filter:blur(8px)}
.hero{position:relative;z-index:1;max-width:880px;margin:0 auto 18px;text-align:center;padding:10px 0 6px}
.logoArea{display:flex;justify-content:center;margin-bottom:12px}
.logoLink{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;border-radius:26px;background:rgba(255,255,255,.58);border:1px solid rgba(255,255,255,.55);backdrop-filter:blur(16px);box-shadow:var(--shadow)}
.siteLogo{display:block;max-width:100%;height:auto}
.logoFallback{width:92px;height:92px;border-radius:28px;background:linear-gradient(135deg,var(--brand),color-mix(in srgb, var(--brand) 76%, #0c1620));color:#fff;display:grid;place-items:center;font-size:36px;font-weight:800;box-shadow:var(--shadow);margin:0 auto}
h1{margin:10px 0 8px;font-size:clamp(28px,4vw,44px);line-height:1.15}
.welcomeText{margin:0 auto;max-width:760px;color:var(--muted);font-size:16px;line-height:1.95}
.mainGrid{display:grid;grid-template-columns:minmax(360px,.92fr) minmax(0,1.08fr);gap:20px;align-items:start}
.sidebarColumn,.editorColumn{min-width:0}
.sidebarColumn{display:grid;gap:18px}
.card{
  position:relative;overflow:hidden;
  background:var(--panel);
  border:1px solid rgba(255,255,255,.7);
  border-radius:var(--radius);
  backdrop-filter:blur(20px);
  box-shadow:var(--shadow);
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease, background .22s ease;
}
.card::before{content:'';position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.9),rgba(255,255,255,0))}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.sectionCard,.stageCard{padding:18px}
.sectionTitle{font-size:20px;font-weight:800;letter-spacing:-.01em}
.sectionHint{margin-top:4px;color:var(--muted);font-size:14px;line-height:1.85}
.stageHead{display:flex;align-items:center;justify-content:center;text-align:center;margin-bottom:14px}
.downloadBtn,.uploadField,.ghostBtn,.shapeIconBtn,.tplCard,.stickerCard,.textInput,.layerSizeInput{transition:all .18s ease}
.downloadBtn,.uploadField,.ghostBtn,.shapeIconBtn{border:0;cursor:pointer}
.downloadBtn{
  min-width:240px;padding:14px 18px;border-radius:18px;font-weight:800;color:#fff;
  background:linear-gradient(135deg,var(--brand),#143632);
  box-shadow:0 16px 28px rgba(31,111,100,.22), inset 0 1px 0 rgba(255,255,255,.16);
}
.downloadBtn:hover,.uploadField:hover,.ghostBtn:hover,.shapeIconBtn:hover{transform:translateY(-1px)}
.downloadBtn:hover{filter:brightness(1.03)}
.uploadField,.ghostBtn,.shapeIconBtn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:rgba(255,255,255,.8);color:var(--text);
  border:1px solid var(--line);border-radius:16px;padding:11px 14px;font-weight:800;
  box-shadow:0 8px 18px rgba(17,24,39,.04);
}
.uploadField:hover,.ghostBtn:hover,.shapeIconBtn:hover{border-color:rgba(31,111,100,.28);background:#fff;box-shadow:0 14px 24px rgba(17,24,39,.07)}
.ghostBtn.danger{color:#b42318;background:linear-gradient(180deg,#fff,#fff7f6);border-color:#efc4bf}
.iconBtn{width:50px;height:50px;padding:0;font-size:20px}
.uploadFieldBlock{display:flex;width:100%;min-height:52px}
.textInput,.layerSizeInput{
  width:100%;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:18px;
  padding:14px 16px;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.6)
}
.textInput:focus,.layerSizeInput:focus,.toolField input:focus{border-color:rgba(31,111,100,.34);box-shadow:0 0 0 5px rgba(31,111,100,.08)}
.templatesGrid,.stickersGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.tplCard,.stickerCard{
  width:100%;text-align:right;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,250,253,.96));
  border:1px solid var(--line);border-radius:20px;padding:10px;
}
.tplCard:hover,.stickerCard:hover{border-color:rgba(31,111,100,.22);box-shadow:0 18px 30px rgba(15,23,42,.07)}
.tplCard.active{border-color:rgba(31,111,100,.42);box-shadow:0 0 0 4px rgba(31,111,100,.08), 0 18px 30px rgba(15,23,42,.08)}
.tplCard img,.stickerCard img{display:block;width:100%;border-radius:16px;background:#f7f9fc;box-shadow:inset 0 1px 0 rgba(255,255,255,.7)}
.tplCard img{aspect-ratio:4/5;object-fit:cover}
.stickerCard img{aspect-ratio:1/1;object-fit:contain;padding:8px}
.tplCard .name,.stickerCard .name{font-weight:800;margin-top:9px}
.tplCard .small,.stickerCard .small{font-size:12px;color:var(--muted)}
.imageTools{margin-top:12px;padding:12px;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.82),rgba(249,251,253,.92))}
.imageToolsGrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.toolField{display:flex;flex-direction:column;gap:8px;font-size:13px;font-weight:700;color:#475467}
.toolField input{width:100%;border:1px solid var(--line);border-radius:14px;padding:10px 12px;background:#fff;outline:none}
.toolFieldWide{grid-column:1/-1}
.toolFieldWide input[type='range']{padding:0}
.cropToolsBox{margin-top:12px;padding:12px;border-radius:18px;background:linear-gradient(180deg,#fbfcfe,#f6f9fc);border:1px solid rgba(20,32,55,.06)}
.cropToolsTitle{font-size:13px;font-weight:800;color:#445164;text-align:center;margin-bottom:10px}
.cropPad{display:flex;flex-direction:column;align-items:center;gap:8px}
.cropPadRow{display:flex;gap:8px;justify-content:center}
.inlineActions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.slimActions .ghostBtn{flex:1}
.shapeDockWrap{margin-bottom:14px;text-align:center}
.miniShapeTitle{font-size:15px;margin-bottom:10px}
.shapeDock{display:flex;justify-content:center;gap:10px}
.shapeIconBtn{width:54px;height:54px;padding:0;border-radius:18px;font-size:26px;font-weight:700}
.shapeIconBtn.active{background:linear-gradient(180deg,var(--brand-soft),#fff);border-color:rgba(31,111,100,.3);color:var(--brand);box-shadow:0 0 0 4px rgba(31,111,100,.08)}
.canvasOuter{
  background:linear-gradient(180deg,rgba(247,250,253,.9),rgba(240,244,249,.92));
  border:1px dashed rgba(31,111,100,.18);border-radius:26px;padding:18px;min-height:560px;
  display:flex;align-items:center;justify-content:center;
}
.canvasPlaceholder{max-width:460px;text-align:center;color:var(--muted);line-height:2}
.canvasShell{width:100%;display:flex;justify-content:center;align-items:center}
.canvasShell.hidden,.hidden{display:none!important}
#editorCanvas{border-radius:20px;box-shadow:0 26px 48px rgba(15,23,42,.16);background:#fff;max-width:100%;height:auto}
.noticeBox{display:none;margin-top:14px;border-radius:18px;padding:13px 14px;font-size:14px;line-height:1.8}.noticeBox.show{display:block}
.previewFooter{display:flex;justify-content:center;margin-top:16px}
.layersTableWrap{overflow:auto;border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#fbfcfe,#f7fafc);scrollbar-width:thin}
.layersTable{width:100%;border-collapse:collapse;min-width:680px}
.layersTable th,.layersTable td{padding:12px 10px;border-bottom:1px solid rgba(20,32,55,.07);text-align:right;vertical-align:middle;font-size:14px}
.layersTable thead th{background:rgba(255,255,255,.92);font-weight:800;color:#4d5b70;position:sticky;top:0;z-index:1}
.layersTable tbody tr.active{background:rgba(31,111,100,.07)}
.layersTable tbody tr:last-child td{border-bottom:0}
.layerTitle{font-weight:800}.layerSub{font-size:12px;color:var(--muted);margin-top:4px}.layerActions{display:flex;gap:8px;flex-wrap:wrap}.layerSizeInput{width:92px;padding:10px 12px;border-radius:12px}.emptyRow td{text-align:center;color:var(--muted);padding:18px}
.emptyInline{margin-top:12px;color:var(--muted);font-size:14px;text-align:center;padding:12px;border:1px dashed var(--line-strong);border-radius:14px;background:rgba(255,255,255,.7)}
.siteFooter{text-align:center;padding:20px 0 10px;color:var(--muted);font-size:14px}
.devCredit{margin-top:8px;font-weight:700}
.devCredit a{color:var(--brand);text-decoration:none;padding-bottom:2px;border-bottom:1px solid rgba(31,111,100,.22)}
.devCredit a:hover{border-bottom-color:var(--brand)}
@media (min-width:981px){.previewColumn{position:sticky;top:18px}}
@media (max-width:980px){
  .pageWrap{padding:14px}
  .hero{padding-top:4px}
  .mainGrid{grid-template-columns:1fr;gap:14px}
  .sidebarColumn,.editorColumn{display:grid;gap:14px}
  .hero,.sectionTitle,.sectionHint,.stageHead{text-align:center}
  .textInput,.uploadFieldBlock,.downloadBtn{width:100%}
  .shapeDock,.previewFooter,.inlineActions{justify-content:center}
  .flowTemplatesCard{order:1}
  .flowNameCard{order:2}
  .flowImageCard{order:3}
  .flowPngCard{order:4}
  .flowPreviewCard{order:5}
  .flowLayersCard{order:6}
  .canvasOuter{min-height:360px}
}
@media (max-width:640px){
  .pageWrap{padding:10px}
  .hero{margin-bottom:12px}
  h1{font-size:29px}
  .welcomeText{font-size:14px;max-width:100%}
  .sectionCard,.stageCard{padding:14px;border-radius:22px}
  .card:hover{transform:none}
  .sidebarColumn,.editorColumn,.mainGrid{gap:10px}
  .sectionTitle{font-size:18px}
  .sectionHint{font-size:13px}
  .templatesGrid,.stickersGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .tplCard,.stickerCard{text-align:center;padding:8px;border-radius:18px}
  .tplCard .name,.tplCard .small,.stickerCard .name,.stickerCard .small{text-align:center}
  .flowImageCard .sectionTitle,.flowImageCard .sectionHint,.flowTemplatesCard .sectionTitle,.flowNameCard .sectionTitle,.flowPngCard .sectionTitle,.flowLayersCard .sectionTitle,.flowPreviewCard .sectionTitle{text-align:center}
  .textInput{text-align:center;min-height:52px}
  .compactTools{grid-template-columns:1fr 1fr;gap:8px}
  .toolField{font-size:12px}
  .cropToolsBox{padding:10px}
  .iconBtn{width:46px;height:46px}
  .shapeIconBtn{width:50px;height:50px;border-radius:16px}
  .canvasOuter{padding:12px;min-height:270px}
  .canvasShell{overflow:auto;max-width:100%}
  .canvasShell canvas{max-width:100%;height:auto!important}
  .previewFooter{margin-top:12px}
  .downloadBtn{min-width:0;width:100%}
  .layersTable{min-width:560px}
}
@media (hover:none) and (pointer:coarse){
  .uploadField,.ghostBtn,.shapeIconBtn,.downloadBtn{min-height:46px}
}

/* Legendary minimalist refinement */
:root{
  --panel:rgba(255,255,255,.78);
  --line:rgba(20,32,55,.06);
  --line-strong:rgba(20,32,55,.10);
  --shadow:0 16px 40px rgba(12,19,34,.08);
  --shadow-hover:0 24px 58px rgba(12,19,34,.14);
  --radius:24px;
}
body{
  background:
    radial-gradient(circle at 88% 10%, rgba(200,168,90,.18), transparent 20%),
    radial-gradient(circle at 8% 0%, rgba(31,111,100,.12), transparent 22%),
    linear-gradient(180deg,#f7fafc 0%,#eef3f8 100%);
}
.hero{margin-bottom:14px}
.welcomeText{max-width:720px;margin:0 auto;color:#6b7789;font-size:15px}
.mainGrid{gap:18px;align-items:start}
.card{
  border:1px solid rgba(255,255,255,.7);
  background:linear-gradient(180deg,rgba(255,255,255,.88),rgba(255,255,255,.72));
  box-shadow:var(--shadow);
  backdrop-filter:blur(18px);
}
.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-hover)}
.sectionCard,.stageCard{padding:16px}
.sectionTitle{font-size:16px;font-weight:800;letter-spacing:-.2px}
.sectionHint{font-size:12px;color:#7d8898;margin-top:4px}
.flowCard + .flowCard{margin-top:14px}
.compactCard{padding:10px 12px}
.compactToggle{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;
  border:none;background:transparent;padding:4px 2px;color:var(--text);cursor:pointer
}
.compactLabel{font-weight:800;font-size:15px}
.compactValue{font-size:13px;color:#7d8898;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.compactBody{padding-top:10px}
.textInput{
  width:100%;height:50px;border-radius:16px;border:1px solid rgba(20,32,55,.08);
  background:rgba(249,251,253,.96);padding:0 16px;outline:none;transition:.2s border-color,.2s box-shadow,.2s background
}
.textInput:focus{border-color:rgba(31,111,100,.35);box-shadow:0 0 0 4px rgba(31,111,100,.08);background:#fff}
.lineTitle{margin-bottom:2px}
.microHint{margin-bottom:10px}
.imageUploadRow{display:flex;align-items:center;justify-content:flex-start}
.uploadField{
  border:none;background:linear-gradient(135deg,var(--brand),color-mix(in srgb, var(--brand) 75%, #0d1824));
  color:#fff;box-shadow:0 14px 28px rgba(31,111,100,.18);transition:.22s transform,.22s box-shadow,.22s filter
}
.uploadField:hover,.downloadBtn:hover,.ghostBtn:hover,.tplCard:hover,.stickerCard:hover{transform:translateY(-2px)}
.uploadField:hover{box-shadow:0 18px 34px rgba(31,111,100,.24);filter:saturate(1.05)}
.compactUpload{min-width:auto;padding:12px 18px;border-radius:16px;font-size:14px}
.compactImageCard{padding:14px 16px}
.compactImageTools{margin-top:12px;display:grid;gap:12px}
.compactCropBox{padding:10px 12px;border-radius:18px;background:rgba(247,249,252,.9);border:1px solid rgba(20,32,55,.06)}
.cropToolsTitle{font-size:12px;font-weight:700;color:#738094;margin-bottom:10px}
.cropPad{display:grid;justify-content:center;gap:8px}
.cropPadRow{display:flex;gap:8px;justify-content:center}
.iconBtn{width:42px;height:42px;border-radius:14px;padding:0;font-size:18px}
.ghostBtn{
  border:1px solid rgba(20,32,55,.08);background:rgba(255,255,255,.76);color:var(--text);
  border-radius:14px;padding:11px 14px;cursor:pointer;transition:.22s transform,.22s box-shadow,.22s border-color,.22s background;
  box-shadow:0 8px 18px rgba(10,18,34,.04)
}
.ghostBtn:hover{border-color:rgba(31,111,100,.20);box-shadow:0 16px 30px rgba(10,18,34,.08);background:#fff}
.ghostBtn.danger{color:#b42318}
.slimActions{display:flex;gap:8px;flex-wrap:wrap}
.slimActions .ghostBtn{flex:1;min-width:120px}
.tplCard,.stickerCard{
  border-radius:20px;border:1px solid rgba(20,32,55,.07);background:rgba(255,255,255,.72);
  overflow:hidden;transition:.22s transform,.22s box-shadow,.22s border-color;background-clip:padding-box
}
.tplCard:hover,.stickerCard:hover{box-shadow:0 18px 34px rgba(12,19,34,.10);border-color:rgba(31,111,100,.18)}
.tplCard.active{border-color:rgba(31,111,100,.34);box-shadow:0 20px 38px rgba(31,111,100,.12)}
.tplCard img,.stickerCard img{display:block;width:100%;aspect-ratio:1/1;object-fit:cover;background:#f7f9fb}
.tplCard .name,.stickerCard .name{font-size:13px;font-weight:800;padding:10px 12px 2px}
.tplCard .small,.stickerCard .small{font-size:11px;color:#7c8797;padding:0 12px 12px}
.compactStageHead{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.inlineShapeDock{display:flex;align-items:center;gap:8px}
.shapeDock{display:flex;gap:8px;padding:6px;border-radius:16px;background:rgba(247,249,252,.9);border:1px solid rgba(20,32,55,.06)}
.shapeIconBtn{
  width:42px;height:42px;border:none;border-radius:14px;background:transparent;color:#6f7d8d;cursor:pointer;transition:.22s all
}
.shapeIconBtn.active,.shapeIconBtn:hover{background:linear-gradient(135deg,var(--brand),color-mix(in srgb, var(--brand) 80%, #0d1721));color:#fff;box-shadow:0 12px 22px rgba(31,111,100,.22)}
.canvasOuter{border-radius:24px;padding:14px;background:linear-gradient(180deg,rgba(245,248,252,.95),rgba(241,245,250,.9));border:1px solid rgba(20,32,55,.05)}
.canvasShell{display:flex;justify-content:center;align-items:center;overflow:auto;padding:4px}
.canvasShell canvas{border-radius:20px;box-shadow:0 18px 40px rgba(15,24,38,.12)}
.canvasPlaceholder{min-height:240px;border-radius:20px;display:grid;place-items:center;text-align:center;padding:24px;color:#7c8796;border:1px dashed rgba(20,32,55,.10);background:rgba(255,255,255,.62)}
.noticeBox{margin-top:12px}
.downloadBtn{
  width:100%;height:52px;border:none;border-radius:18px;color:#fff;font-weight:800;cursor:pointer;
  background:linear-gradient(135deg,var(--gold),color-mix(in srgb, var(--gold) 74%, #8a6720));box-shadow:0 18px 34px rgba(200,168,90,.24);
  transition:.22s transform,.22s box-shadow,.22s filter
}
.downloadBtn:hover{box-shadow:0 22px 40px rgba(200,168,90,.30);filter:saturate(1.06)}
.previewFooter{margin-top:14px}
.siteFooter{display:grid;gap:10px;justify-items:center;text-align:center;padding:18px 0 8px;color:#768192}
.devCredit a{color:var(--brand);font-weight:800;text-decoration:none}
.devCredit a:hover{text-decoration:underline}
.hidden{display:none !important}

@media (max-width: 920px){
  .pageWrap{padding:16px}
  .mainGrid{grid-template-columns:1fr !important;gap:14px}
  .visitorFlow,.previewColumn{width:100%}
  .visitorFlow{display:grid;gap:12px}
  .flowCard + .flowCard{margin-top:0}
  .flowTemplatesCard{order:1}
  .flowNameCard{order:2}
  .flowImageCard{order:3}
  .flowPngCard{order:4}
  .flowPreviewCard{order:5}
  .sectionCard,.stageCard{padding:14px}
  .hero{padding-top:4px}
  .logoLink{padding:8px 14px;border-radius:22px}
  .welcomeText{font-size:14px}
  .templatesGrid,.stickersGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .compactToggle{padding:2px 0}
  .compactValue{max-width:58vw}
  .imageUploadRow{justify-content:center}
  .compactImageCard,.flowNameCard,.flowTemplatesCard,.flowPngCard,.flowPreviewCard{text-align:center}
  .compactStageHead{align-items:center}
  .compactStageHead .sectionHint{max-width:72vw}
  .shapeDock{margin-inline-start:auto}
  .canvasOuter{padding:10px}
  .previewFooter{padding-top:2px}
}

@media (max-width: 560px){
  .pageWrap{padding:12px}
  .hero{margin-bottom:10px}
  h1{font-size:28px}
  .templatesGrid,.stickersGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .tplCard .name,.stickerCard .name{font-size:12px}
  .tplCard .small,.stickerCard .small{font-size:10px;padding-bottom:10px}
  .compactUpload{width:100%;justify-content:center}
  .compactImageTools{gap:10px}
  .compactCropBox{padding:10px}
  .iconBtn,.shapeIconBtn{width:40px;height:40px}
  .slimActions .ghostBtn{min-width:0;flex:1 1 calc(50% - 4px)}
  .compactStageHead{gap:8px}
  .compactStageHead .sectionTitle{font-size:15px}
  .compactStageHead .sectionHint{font-size:11px}
  .canvasPlaceholder{min-height:200px;padding:18px}
}


/* image zoom + crop layout refresh */
.imageZoomCropWrap{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(230px,.9fr);gap:12px;align-items:stretch;margin-top:4px}
.imageZoomCard,.cropToolsBox{height:100%}
.imageZoomCard{padding:14px 16px;border-radius:18px;background:linear-gradient(180deg,#fbfcfe,#f6f9fc);border:1px solid rgba(20,32,55,.06);display:flex;flex-direction:column;justify-content:center}
.imageZoomHeader{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}
.imageZoomLabel{font-size:15px;font-weight:800;color:#23364a}
.imageZoomValue{font-size:15px;font-weight:800;color:var(--brand)}
.imageZoomSlider{width:100%;margin:0;appearance:none;-webkit-appearance:none;background:transparent}
.imageZoomSlider:focus{outline:none}
.imageZoomSlider::-webkit-slider-runnable-track{height:10px;border-radius:999px;background:linear-gradient(90deg, rgba(31,111,100,.18), rgba(200,168,90,.55));box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.imageZoomSlider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),color-mix(in srgb, var(--gold) 70%, #ffffff));border:4px solid rgba(255,255,255,.95);box-shadow:0 8px 18px rgba(31,111,100,.18);margin-top:-9px}
.imageZoomSlider::-moz-range-track{height:10px;border-radius:999px;background:linear-gradient(90deg, rgba(31,111,100,.18), rgba(200,168,90,.55));box-shadow:inset 0 1px 2px rgba(0,0,0,.08)}
.imageZoomSlider::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),color-mix(in srgb, var(--gold) 70%, #ffffff));border:4px solid rgba(255,255,255,.95);box-shadow:0 8px 18px rgba(31,111,100,.18)}
.cropToolsBox{margin-top:0;display:flex;flex-direction:column;justify-content:center}
.cropToolsTitle{text-align:right;margin-bottom:12px;font-size:15px;font-weight:800;color:#6f7a8c}
.cropPad{gap:10px}
.cropPad > .iconBtn{align-self:center}
.cropPadRow{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;align-items:center}
.cropPadRow .iconBtn:nth-child(1){grid-column:1}
.cropPadRow .iconBtn:nth-child(2){grid-column:2}
.cropPadRow .iconBtn:nth-child(3){grid-column:3}
.iconBtn{width:56px;height:56px;border-radius:18px;font-size:24px;font-weight:800}
.uploadField:hover,.uploadField:focus-visible{color:#fff;background:linear-gradient(135deg,var(--brand),color-mix(in srgb, var(--brand) 75%, #0d1824));border-color:transparent}
.downloadBtn:hover{color:#fff}
.ghostBtn:hover{color:var(--text)}
@media (max-width:980px){.imageZoomCropWrap{grid-template-columns:1fr}.cropToolsTitle{text-align:center}.cropPadRow{justify-items:center}}
@media (max-width:640px){.imageZoomCard{padding:12px 14px}.imageZoomHeader{margin-bottom:10px}.imageZoomLabel,.imageZoomValue{font-size:14px}.imageZoomSlider::-webkit-slider-thumb{width:26px;height:26px;margin-top:-8px}.imageZoomSlider::-moz-range-thumb{width:26px;height:26px}.iconBtn{width:52px;height:52px;border-radius:16px;font-size:22px}}


/* mobile pinch-zoom stabilization */
html,body{
  overscroll-behavior-x:none;
}
.canvasShell,
#editorCanvas,
.canvasShell canvas,
.canvas-container,
.canvas-container canvas{
  touch-action:none;
  -webkit-user-select:none;
  user-select:none;
  -webkit-touch-callout:none;
}
@media (max-width:980px){
  .canvasOuter{overflow:hidden}
  .canvasShell{overflow:auto;-webkit-overflow-scrolling:touch}
}


.templateSearchWrap{display:grid;gap:10px;margin-top:12px}
.templateCategoryChips{display:flex;flex-wrap:wrap;gap:8px}
.templateChip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:8px 12px;font-weight:700;cursor:pointer}
.templateChip.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.tplCard .metaRow{display:flex;justify-content:space-between;gap:8px;align-items:center;margin-top:6px}
.tplBadge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:var(--gold-soft);color:var(--text);font-size:12px;font-weight:800}
.tplStats{font-size:12px;color:var(--muted)}
.advancedPreviewFooter{display:grid;gap:12px}
.exportBar,.shareActions,.siteSocialLinks{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.shareBar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.shareLabel{font-weight:800;color:var(--muted)}
.siteSocialLinks a{width:42px;height:42px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;background:rgba(255,255,255,.8);border:1px solid var(--line);box-shadow:0 8px 18px rgba(17,24,39,.04)}
.siteStatsMini{margin-top:10px;color:var(--muted);font-weight:700}
.safeZoneInfo{font-size:12px;color:var(--muted);margin-top:8px}
@media (max-width:768px){
  .exportBar .ghostBtn,.shareActions .ghostBtn{min-width:48px}
  .shareBar{align-items:flex-start}
}
