.snt-wrap{max-width:1100px;margin:20px auto;font-family:Arial,sans-serif}.snt-card{background:#f8f9ff;border:1px solid #dfe4ff;border-radius:24px;padding:22px;margin-bottom:18px}.snt-row{display:flex;gap:18px;flex-wrap:wrap}.snt-col{flex:1;min-width:280px}.snt-col label{display:block;font-weight:700;margin-bottom:8px;color:#24318f}.snt-col input[type=file],.snt-col select,.snt-apply-row textarea{width:100%;border:1px solid #ccd3ff;border-radius:16px;padding:12px;font-size:16px;background:#fff}.snt-note{color:#666}.snt-actions{display:flex;gap:18px;align-items:center;margin:16px 0}.snt-btn{background:#2f43ff;color:#fff;border:none;border-radius:16px;padding:16px 26px;font-weight:700;cursor:pointer;box-shadow:0 8px 20px rgba(47,67,255,.25)}.snt-status{flex:1;background:#f4ede1;border:1px solid #e6d8b8;border-radius:14px;padding:14px;min-height:22px}.snt-status .ok{color:#2b347f}.snt-status .bad{color:#a12626}.snt-preview{position:relative;min-height:180px;background:#fff;border-radius:18px;overflow:hidden;border:1px solid #dfe4ff}#snt-preview{max-width:100%;display:none}#snt-face-box{position:absolute;border:2px dashed #ff5d92;border-radius:18px;display:none;pointer-events:none}.snt-filters{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:14px}.snt-chip{background:#fff;color:#24318f;border:1px solid #cad2ff;border-radius:999px;padding:14px 22px;font-weight:700;cursor:pointer}.snt-chip.active{background:#2f43ff;color:#fff;box-shadow:0 8px 20px rgba(47,67,255,.25)}.snt-suggest-box{background:#fff;border:1px solid #cad2ff;border-radius:16px;padding:14px;margin-bottom:14px}.snt-library{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.snt-style-card{background:#fff;border:2px solid #e4e8ff;border-radius:18px;padding:10px;cursor:pointer;transition:.15s}.snt-style-card.active{border-color:#2f43ff;box-shadow:0 8px 20px rgba(47,67,255,.18)}.snt-style-card.best::before{content:'AI gợi ý';display:inline-block;background:#2f43ff;color:#fff;border-radius:999px;padding:4px 10px;font-size:12px;margin-bottom:8px}.snt-style-card img{width:100%;height:160px;object-fit:cover;border-radius:14px;background:#f0f3ff}.snt-style-name{font-weight:700;color:#24318f;margin-top:8px}.snt-style-meta{font-size:13px;color:#666;margin-top:4px}.snt-apply-row{display:grid;grid-template-columns:1fr auto;gap:16px;margin-top:16px}.snt-result-empty{background:#fff;border:1px dashed #cad2ff;border-radius:16px;padding:24px;color:#666}.snt-compare{display:grid;grid-template-columns:1fr 1fr;gap:18px}.snt-compare img{width:100%;border-radius:16px;border:1px solid #dfe4ff;background:#fff}.snt-cap{font-weight:700;color:#24318f;margin-bottom:8px}.snt-result-note{margin-top:14px;background:#fff;border:1px solid #cad2ff;border-radius:14px;padding:14px}.snt-admin-grid{display:grid;grid-template-columns:380px 1fr;gap:18px}.snt-admin-card{background:#fff;border:1px solid #dcdcde;border-radius:16px;padding:18px;box-shadow:0 1px 2px rgba(0,0,0,.04)}@media(max-width:1100px){.snt-admin-grid{grid-template-columns:1fr}}@media(max-width:768px){.snt-apply-row,.snt-compare{grid-template-columns:1fr}}
.snt-result-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.snt-btn-link{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}

.snt-result-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}.snt-btn-link{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}

.snt-col input[type=text]{width:100%;border:1px solid #ccd3ff;border-radius:16px;padding:12px;font-size:16px;background:#fff}


.snt-wait-box{
text-align:center;
padding:40px 20px;
}

.snt-wait-text{
color:#d90000;
font-weight:800;
font-size:18px;
line-height:1.6;
margin-top:15px;
}

.snt-spinner{
width:50px;
height:50px;
border:6px solid #e5e5e5;
border-top:6px solid #2f43ff;
border-radius:50%;
margin:0 auto;
animation:sntspin 1s linear infinite;
}

@keyframes sntspin{
0%{transform:rotate(0deg)}
100%{transform:rotate(360deg)}
}

.snt-badge-manual{
display:inline-block;
background:#ff7a00;
color:#fff;
border-radius:999px;
padding:4px 10px;
font-size:12px;
font-weight:700;
margin-bottom:8px;
}

#snt-apply.snt-btn{
background:#d90000 !important;
color:#ffffff !important;
border:none !important;
}
#snt-apply.snt-btn:hover{
background:#b80000 !important;
color:#ffffff !important;
}

.snt-global-footer{
margin-top:30px;
padding:14px 18px;
background:#f3f5fb;
border:1px solid #d8def5;
border-radius:12px;
text-align:center;
font-size:14px;
line-height:1.6;
color:#333;
}
.snt-global-footer a{
color:#2f43ff;
font-weight:600;
text-decoration:none;
}

.snt-global-footer a{
transition:all .2s ease;
}
.snt-global-footer a:hover{
color:#d90000;
text-decoration:underline;
}
}


.snt-global-footer{
margin-top:24px;
padding:14px 18px;
background:#f3f5fb;
border:1px solid #d8def5;
border-radius:12px;
text-align:center;
font-size:14px;
line-height:1.6;
color:#333;
}
.snt-global-footer-inline{
position:relative;
width:100%;
box-sizing:border-box;
}
.snt-footer-logo{
display:inline-block;
padding:6px 12px;
margin-bottom:8px;
border-radius:999px;
background:#2f43ff;
color:#fff;
font-weight:700;
font-size:13px;
letter-spacing:.3px;
}
.snt-footer-text{
font-size:14px;
line-height:1.6;
}
.snt-global-footer a{
color:#2f43ff;
font-weight:600;
text-decoration:none;
transition:all .2s ease;
}
.snt-global-footer a:hover{
color:#d90000;
text-decoration:underline;
}

.snt-ai-guide-box{
display:flex;
gap:12px;
align-items:flex-start;
margin-top:14px;
padding:14px 16px;
background:#fff2f2;
border:1px solid #ffcccc;
border-left:5px solid #d90000;
border-radius:14px;
box-shadow:0 4px 14px rgba(217,0,0,0.06);
}
.snt-ai-guide-icon{
font-size:22px;
line-height:1;
margin-top:2px;
}
.snt-ai-guide-content{
flex:1;
}
.snt-ai-guide-title{
font-weight:800;
color:#d90000;
font-size:15px;
margin-bottom:4px;
letter-spacing:.2px;
}
.snt-ai-guide-text{
font-weight:700;
color:#d90000;
line-height:1.65;
font-size:15px;
}

.snt-hero-title{
display:flex;
align-items:center;
justify-content:center;
gap:12px;
padding:16px 22px;
margin-bottom:18px;
background:linear-gradient(180deg,#ff2a2a 0%, #d90000 100%);
color:#fff;
font-weight:800;
font-size:22px;
line-height:1.35;
text-align:center;
border-radius:18px;
box-shadow:0 10px 0 #a80000, 0 18px 30px rgba(217,0,0,0.25);
text-transform:uppercase;
letter-spacing:.4px;
}
.snt-hero-icon{
font-size:28px;
line-height:1;
filter:drop-shadow(0 2px 2px rgba(0,0,0,0.18));
}
.snt-hero-text{
display:inline-block;
}
@media (max-width: 768px){
  .snt-hero-title{
    font-size:17px;
    padding:14px 16px;
    border-radius:16px;
  }
  .snt-hero-icon{
    font-size:24px;
  }
}


/* ===== Responsive UI polish ===== */
.snt-wrap{
width:min(100%, 1180px);
padding:0 14px;
box-sizing:border-box;
}
.snt-card{
border-radius:22px;
padding:20px;
}
.snt-row{
align-items:flex-start;
}
.snt-col{
min-width:0;
}
.snt-col input[type=file],
.snt-col input[type=text],
.snt-col select,
.snt-apply-row textarea{
box-sizing:border-box;
font-size:16px;
}
.snt-col input[type=file]{
background:#fff;
}
.snt-preview{
display:flex;
align-items:center;
justify-content:center;
padding:12px;
min-height:240px;
}
#snt-preview{
width:100%;
height:auto;
max-height:620px;
object-fit:contain;
border-radius:16px;
}
.snt-filters{
gap:10px;
}
.snt-chip{
padding:12px 18px;
font-size:14px;
white-space:normal;
text-align:center;
line-height:1.35;
}
.snt-library{
grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
gap:14px;
}
.snt-style-card{
border-radius:18px;
padding:10px;
overflow:hidden;
}
.snt-style-card img{
height:180px;
object-fit:cover;
}
.snt-style-name{
font-size:15px;
line-height:1.35;
min-height:40px;
}
.snt-style-meta{
line-height:1.45;
}
.snt-suggest-box,
.snt-result-note,
.snt-result-empty{
word-break:break-word;
}
.snt-apply-row{
align-items:start;
}
.snt-result-actions{
align-items:stretch;
}
.snt-result-actions .snt-btn{
flex:1 1 220px;
min-height:54px;
font-size:15px;
text-align:center;
}
.snt-compare{
align-items:start;
}
.snt-compare img{
max-height:560px;
object-fit:contain;
}
.snt-global-footer-inline{
margin-bottom:8px;
}
.snt-global-footer{
word-break:break-word;
}
@media (max-width: 1024px){
  .snt-wrap{
    width:min(100%, 980px);
    padding:0 12px;
  }
  .snt-card{
    padding:18px;
    border-radius:20px;
  }
  .snt-library{
    grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  }
  .snt-style-card img{
    height:170px;
  }
}
@media (max-width: 768px){
  .snt-wrap{
    padding:0 10px;
  }
  .snt-card{
    padding:16px;
    border-radius:18px;
    margin-bottom:14px;
  }
  .snt-row{
    gap:12px;
  }
  .snt-col{
    flex:1 1 100%;
    min-width:100%;
  }
  .snt-actions{
    flex-direction:column;
    align-items:stretch;
    gap:12px;
  }
  .snt-btn{
    width:100%;
    min-height:52px;
    font-size:16px;
    padding:14px 18px;
  }
  .snt-preview{
    min-height:180px;
    padding:10px;
  }
  #snt-preview{
    max-height:420px;
  }
  .snt-filters{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:10px;
  }
  .snt-chip{
    width:100%;
    min-height:48px;
    padding:10px 12px;
    font-size:13px;
  }
  .snt-library{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  .snt-style-card{
    padding:8px;
    border-radius:16px;
  }
  .snt-style-card img{
    height:145px;
    border-radius:12px;
  }
  .snt-style-name{
    font-size:14px;
    min-height:38px;
  }
  .snt-style-meta{
    font-size:12px;
  }
  .snt-apply-row{
    grid-template-columns:1fr;
    gap:12px;
  }
  .snt-compare{
    grid-template-columns:1fr;
    gap:14px;
  }
  .snt-result-actions{
    flex-direction:column;
  }
  .snt-result-actions .snt-btn{
    width:100%;
    flex:none;
  }
  .snt-hero-title{
    margin-bottom:14px;
  }
  .snt-wait-text,
  .snt-ai-guide-text{
    font-size:14px;
  }
  .snt-global-footer{
    font-size:13px;
    padding:12px 14px;
  }
}
@media (max-width: 480px){
  .snt-wrap{
    padding:0 8px;
  }
  .snt-card{
    padding:14px;
    border-radius:16px;
  }
  .snt-hero-title{
    gap:8px;
    font-size:15px;
    padding:12px 14px;
    box-shadow:0 8px 0 #a80000, 0 14px 24px rgba(217,0,0,0.18);
  }
  .snt-hero-icon{
    font-size:22px;
  }
  .snt-preview{
    min-height:150px;
  }
  #snt-preview{
    max-height:320px;
  }
  .snt-filters{
    grid-template-columns:1fr;
  }
  .snt-library{
    grid-template-columns:1fr 1fr;
    gap:10px;
  }
  .snt-style-card img{
    height:125px;
  }
  .snt-wait-box{
    padding:28px 10px;
  }
  .snt-wait-text{
    font-size:13px;
  }
  .snt-global-footer{
    font-size:12px;
    line-height:1.5;
  }
}
/* Improve touch targets */
.snt-chip,
.snt-style-card,
.snt-btn,
#snt-pick-media{
-webkit-tap-highlight-color: transparent;
touch-action: manipulation;
}



.snt-analyze-loading-box{
position:fixed;
left:50%;
top:50%;
transform:translate(-50%,-50%);
z-index:99999;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
gap:14px;
padding:24px 22px;
width:min(88vw, 420px);
background:#ffffff;
border:2px solid #00b050;
border-radius:18px;
box-shadow:0 14px 34px rgba(0,0,0,0.18);
text-align:center;
}





.snt-analyze-spinner{
width:38px;
height:38px;
border:4px solid #e6e6e6;
border-top:4px solid #00b050;
border-radius:50%;
animation:sntspin 1s linear infinite;
}






.snt-analyze-loading-text{
font-size:18px;
font-weight:900;
color:#d90000;
line-height:1.5;
text-align:center;
letter-spacing:.3px;
}




.snt-analyze-loading-box::before{
content:"";
position:fixed;
inset:0;
z-index:-1;
background:rgba(255,255,255,0.18);
backdrop-filter:blur(1px);
}
@media (max-width: 768px){
  .snt-analyze-loading-box{
    width:min(90vw, 360px);
    padding:20px 16px;
    border-radius:16px;
  }
  .snt-analyze-loading-text{
    font-size:16px;
  }
  .snt-analyze-spinner{
    width:34px;
    height:34px;
  }
}
@media (max-width: 480px){
  .snt-analyze-loading-box{
    width:min(92vw, 320px);
    padding:18px 14px;
    border-radius:14px;
  }
  .snt-analyze-loading-text{
    font-size:15px;
    line-height:1.45;
  }
  .snt-analyze-spinner{
    width:30px;
    height:30px;
  }
}

.snt-suggest-title{
text-align:center;
font-weight:900;
font-size:20px;
color:#0b3ea8;
letter-spacing:.5px;
margin:10px 0 12px 0;
text-transform:uppercase;
}
@media (max-width:768px){
  .snt-suggest-title{
    font-size:18px;
    margin:8px 0 10px 0;
  }
}

.snt-suggest-title-wrap{
display:flex;
align-items:center;
justify-content:center;
gap:14px;
margin:10px 0 14px 0;
}
.snt-suggest-line{
flex:1;
height:2px;
max-width:180px;
background:linear-gradient(90deg, rgba(11,62,168,0) 0%, rgba(11,62,168,.75) 50%, rgba(11,62,168,0) 100%);
border-radius:999px;
}
.snt-suggest-title{
display:flex;
align-items:center;
justify-content:center;
gap:10px;
text-align:center;
font-weight:900;
font-size:20px;
color:#0b3ea8;
letter-spacing:.5px;
text-transform:uppercase;
white-space:normal;
}
.snt-suggest-icon{
font-size:21px;
line-height:1;
filter:drop-shadow(0 2px 2px rgba(0,0,0,.08));
}
.snt-suggest-text{
display:inline-block;
}
@media (max-width:768px){
  .snt-suggest-title-wrap{
    gap:8px;
    margin:8px 0 12px 0;
  }
  .snt-suggest-line{
    max-width:70px;
  }
  .snt-suggest-title{
    font-size:17px;
    gap:8px;
  }
  .snt-suggest-icon{
    font-size:18px;
  }
}
@media (max-width:480px){
  .snt-suggest-line{
    display:none;
  }
  .snt-suggest-title{
    font-size:16px;
    line-height:1.4;
  }
}


/* Upload label and centered analyze overlay */
.snt-upload-wrap{
position:relative;
display:block;
}
.snt-upload-wrap input[type=file]{
position:relative;
z-index:2;
opacity:0;
width:100%;
height:48px;
cursor:pointer;
}
.snt-upload-fake-label{
position:absolute;
left:12px;
top:50%;
transform:translateY(-50%);
z-index:1;
display:inline-flex;
align-items:center;
justify-content:center;
padding:8px 14px;
border:1px solid #bfc9ff;
border-radius:10px;
background:#fff;
color:#111;
font-weight:600;
pointer-events:none;
}
.snt-analyze-overlay{
position:fixed;
inset:0;
z-index:99998;
display:flex;
align-items:center;
justify-content:center;
background:rgba(255,255,255,0.22);
backdrop-filter:blur(2px);
padding:16px;
box-sizing:border-box;
}
.snt-analyze-overlay-card{
width:min(1100px, 96vw);
background:#ffffff;
border:2px solid #dfe4ff;
border-radius:24px;
padding:24px 20px;
box-shadow:0 18px 40px rgba(0,0,0,.16);
}
.snt-overlay-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:18px;
margin-bottom:20px;
}
.snt-overlay-field label{
display:block;
font-weight:800;
font-size:15px;
color:#1c33a3;
margin-bottom:10px;
}
.snt-overlay-field input{
width:100%;
box-sizing:border-box;
padding:14px 16px;
border:1px solid #bfc9ff;
border-radius:16px;
font-size:16px;
background:#fff;
}
.snt-analyze-overlay-btn{
display:block;
margin:0 auto;
border:none;
border-radius:20px;
background:linear-gradient(180deg,#3a49ff 0%, #2436df 100%);
color:#fff;
font-weight:800;
font-size:24px;
padding:22px 34px;
box-shadow:0 14px 34px rgba(36,54,223,.28);
cursor:pointer;
}
.snt-analyze-overlay-btn:hover{
transform:translateY(-1px);
}
@media (max-width:900px){
  .snt-overlay-grid{
    grid-template-columns:1fr;
    gap:14px;
  }
  .snt-analyze-overlay-card{
    width:min(94vw, 700px);
    padding:18px 16px;
    border-radius:20px;
  }
}
@media (max-width:768px){
  .snt-analyze-overlay-btn{
    width:100%;
    font-size:20px;
    padding:18px 20px;
    border-radius:18px;
  }
}

.snt-result-actions .snt-btn{
white-space:normal;
line-height:1.35;
padding:14px 16px;
}


/* Final title and waiting message refinements */
.snt-card h3{
text-align:center;
font-weight:900;
color:#0b3ea8;
text-transform:uppercase;
letter-spacing:.4px;
}


/* top refresh link style */




/* floating refresh button */
.snt-refresh-float{
position:fixed;
right:18px;
bottom:18px;
z-index:9999;
}
#snt-refresh-float-btn{
width:54px;
height:54px;
border-radius:50%;
border:none;
background:#0b8f2f;
color:#fff;
font-size:26px;
cursor:pointer;
box-shadow:0 8px 20px rgba(0,0,0,0.2);
transition:transform .2s;
}
#snt-refresh-float-btn:hover{
transform:scale(1.1);
}
#snt-refresh-float-btn:hover::after{
content:"Làm mới trang";
position:absolute;
right:70px;
top:50%;
transform:translateY(-50%);
background:#0b8f2f;
color:#fff;
padding:6px 10px;
border-radius:6px;
font-size:12px;
white-space:nowrap;
}


/* small refresh link style like UI toolbar */
.snt-refresh-top{
display:flex;
justify-content:flex-end;
margin-bottom:8px;
}

#snt-refresh-top-btn{
background:none;
border:none;
color:#c40000;
font-size:13px;
font-weight:500;
cursor:pointer;
padding:0;
text-transform:none;
border-bottom:1px solid #c40000;
transition:all .18s ease;
}

#snt-refresh-top-btn:hover{
letter-spacing:.3px;
border-bottom:2px solid #c40000;
}


.snt-wrap{will-change:opacity;}


.snt-analyze-overlay-card{
position:relative;
}
.snt-overlay-close-btn{
position:absolute;
top:10px;
right:10px;
border:none;
background:#d90000;
color:#fff;
font-size:12px;
font-weight:700;
padding:6px 10px;
border-radius:8px;
cursor:pointer;
line-height:1;
box-shadow:0 4px 10px rgba(0,0,0,0.14);
transition:all .18s ease;
}
.snt-overlay-close-btn:hover{
background:#b80000;
transform:translateY(-1px);
}
@media (max-width:768px){
  .snt-overlay-close-btn{
    top:8px;
    right:8px;
    font-size:11px;
    padding:5px 9px;
  }
}


/* centered create-now overlay on strict baseline */
.snt-create-now-overlay{
position:fixed;
inset:0;
display:none;
align-items:center;
justify-content:center;
z-index:99996;
pointer-events:none;
}
.snt-create-now-overlay.is-active{
display:flex;
}
.snt-create-now-btn{
pointer-events:auto;
position:relative;
width:128px;
height:128px;
border:none;
border-radius:50%;
background:transparent;
cursor:pointer;
padding:0;
outline:none;
}
.snt-create-now-ring{
position:absolute;
inset:0;
border-radius:50%;
background:radial-gradient(circle at 30% 30%, #5d6bff 0%, #3146ff 55%, #2236d8 100%);
box-shadow:0 14px 34px rgba(36,54,223,.30);
animation:sntCreateRipple 2s ease-out infinite;
}
.snt-create-now-core{
position:absolute;
inset:14px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
text-align:center;
padding:14px;
background:linear-gradient(180deg,#4153ff 0%, #2436df 100%);
color:#fff;
font-weight:900;
font-size:16px;
line-height:1.2;
letter-spacing:.2px;
box-shadow:0 8px 0 #16228d, 0 16px 30px rgba(36,54,223,.22);
transition:transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.snt-create-now-btn:hover .snt-create-now-core{
transform:scale(1.04);
filter:brightness(1.05);
box-shadow:0 10px 0 #16228d, 0 18px 32px rgba(36,54,223,.28);
}
.snt-create-now-btn:active .snt-create-now-core{
transform:scale(.98);
}
@keyframes sntCreateRipple{
  0%{ box-shadow:0 0 0 0 rgba(58,73,255,.34), 0 14px 34px rgba(36,54,223,.24); }
  70%{ box-shadow:0 0 0 26px rgba(58,73,255,0), 0 14px 34px rgba(36,54,223,.24); }
  100%{ box-shadow:0 0 0 0 rgba(58,73,255,0), 0 14px 34px rgba(36,54,223,.24); }
}
@media (max-width:768px){
  .snt-create-now-btn{
    width:112px;
    height:112px;
  }
  .snt-create-now-core{
    inset:12px;
    font-size:14px;
    padding:12px;
  }
}


.snt-style-thumb-wrap{position:relative;border-radius:14px;overflow:hidden}
.snt-style-hover-actions{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:14px;background:rgba(12,19,70,.56);opacity:0;visibility:hidden;transition:all .22s ease}
.snt-style-card:hover .snt-style-hover-actions,.snt-style-card:focus-within .snt-style-hover-actions,.snt-style-card.active .snt-style-hover-actions{opacity:1;visibility:visible}
.snt-style-action{width:min(100%, 170px);border:none;border-radius:12px;padding:11px 14px;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 8px 20px rgba(0,0,0,.18)}
.snt-style-preview-btn{background:#ffffff;color:#24318f}
.snt-style-choose-btn{background:#d90000;color:#fff}
.snt-style-action:hover{transform:translateY(-1px)}
.snt-style-preview-modal{position:fixed;inset:0;z-index:99998;background:rgba(0,0,0,.74);display:none;align-items:center;justify-content:center;padding:20px}
.snt-style-preview-modal.is-active{display:flex}
.snt-style-preview-dialog{position:relative;width:min(92vw, 720px);max-height:92vh;background:#fff;border-radius:24px;padding:18px 18px 14px;box-shadow:0 20px 60px rgba(0,0,0,.28);display:flex;flex-direction:column;align-items:center}
.snt-style-preview-close{position:absolute;top:10px;right:10px;width:42px;height:42px;border:none;border-radius:999px;background:#d90000;color:#fff;font-size:28px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.snt-style-preview-image{width:100%;max-height:76vh;object-fit:contain;border-radius:18px;background:#f5f7ff}
.snt-style-preview-name{margin-top:12px;font-size:18px;font-weight:800;color:#24318f;text-align:center}
body.snt-preview-open{overflow:hidden}
@media (max-width: 768px){
  .snt-style-hover-actions{opacity:1;visibility:visible;position:static;inset:auto;background:transparent;padding:12px 0 0}
  .snt-style-action{width:100%}
  .snt-style-preview-dialog{width:min(96vw, 560px);padding:14px 14px 12px;border-radius:20px}
  .snt-style-preview-close{top:8px;right:8px;width:38px;height:38px;font-size:24px}
}
