*{
margin:0;
padding:0;
box-sizing:border-box;
-webkit-tap-highlight-color:transparent;
}

html{
scroll-behavior:smooth;
}

body{
background:
linear-gradient(
180deg,
#03101d 0%,
#071526 100%
);
font-family:'Syne',sans-serif;
color:#f5f7fb;
line-height:1.7;
overflow-x:hidden;
}

body.sopx-lock{
overflow:hidden;
}

#sopx{
width:100%;
padding:42px 18px 24px;
position:relative;
}

#sopx::before,
#sopx::after{
content:'';
position:absolute;
pointer-events:none;
z-index:0;
}

#sopx::before{
top:-18%;
left:-10%;
width:42%;
height:42%;
background:
radial-gradient(
ellipse,
rgba(72,120,255,.10),
transparent 72%
);
}

#sopx::after{
bottom:-15%;
right:-8%;
width:40%;
height:40%;
background:
radial-gradient(
ellipse,
rgba(245,197,24,.07),
transparent 72%
);
}

.sopx-wrap{
position:relative;
z-index:2;
width:100%;
max-width:1040px;
margin:0 auto;
}

/* =========================================
HEADER
========================================= */

.sopx-header{
position:relative;
overflow:hidden;
background:
linear-gradient(
145deg,
rgba(10,22,40,.98),
rgba(4,12,24,.99)
);
border:
1px solid rgba(255,255,255,.06);
border-radius:40px;
padding:56px 46px;
margin-bottom:34px;
box-shadow:
0 28px 70px rgba(0,0,0,.38);
}

.sopx-header::before{
content:'';
position:absolute;
top:-22%;
right:-10%;
width:340px;
height:340px;
background:
radial-gradient(
circle,
rgba(72,120,255,.18),
transparent 72%
);
pointer-events:none;
}

.sopx-header::after{
content:'';
position:absolute;
bottom:-30%;
left:-10%;
width:320px;
height:320px;
background:
radial-gradient(
circle,
rgba(245,197,24,.08),
transparent 72%
);
pointer-events:none;
}

.sopx-badge{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:11px 24px;
border-radius:999px;
background:
rgba(72,120,255,.12);
border:
1px solid rgba(88,138,255,.24);
font-size:13px;
font-weight:700;
letter-spacing:.6px;
color:#84acff;
margin-bottom:30px;
backdrop-filter:blur(8px);
}

.sopx-title{
font-family:
'Cormorant Garamond',
serif;
font-size:90px;
line-height:.92;
font-weight:700;
letter-spacing:-2px;
margin-bottom:28px;
color:#ffffff;
max-width:820px;
}

.sopx-title span{
display:block;
color:#5c92ff;
}

.sopx-sub{
font-size:21px;
line-height:2;
color:
rgba(255,255,255,.72);
max-width:760px;
margin-bottom:34px;
}

.sopx-hero-grid{
display:grid;
grid-template-columns:
repeat(3,minmax(0,1fr));
gap:18px;
margin-top:12px;
}

.sopx-hero-card{
background:
rgba(255,255,255,.04);
border:
1px solid rgba(255,255,255,.06);
border-radius:24px;
padding:24px;
backdrop-filter:blur(10px);
transition:.25s ease;
}

.sopx-hero-card:hover{
transform:
translateY(-3px);
border:
1px solid rgba(92,138,255,.22);
}

.sopx-hero-top{
display:flex;
align-items:center;
gap:14px;
margin-bottom:14px;
}

.sopx-hero-icon{
width:46px;
height:46px;
border-radius:16px;
display:flex;
align-items:center;
justify-content:center;
background:
linear-gradient(
135deg,
rgba(72,120,255,.20),
rgba(72,120,255,.06)
);
border:
1px solid rgba(92,138,255,.18);
font-size:20px;
color:#8cb0ff;
flex-shrink:0;
}

.sopx-hero-title{
font-size:17px;
font-weight:800;
line-height:1.4;
color:#ffffff;
}

.sopx-hero-text{
font-size:14px;
line-height:1.9;
color:
rgba(255,255,255,.62);
}

/* =========================================
PROGRESS
========================================= */

.sopx-progress{
display:grid;
grid-template-columns:
repeat(4,1fr);
gap:16px;
margin-bottom:36px;
}

.sopx-step{
position:relative;
overflow:hidden;
padding:18px 16px;
border-radius:20px;
background:
rgba(255,255,255,.03);
border:
1px solid rgba(255,255,255,.06);
text-align:center;
font-size:14px;
font-weight:700;
letter-spacing:.3px;
color:
rgba(255,255,255,.40);
transition:.25s ease;
}

.sopx-step.active{
background:
linear-gradient(
135deg,
rgba(67,117,255,.18),
rgba(67,117,255,.05)
);
border:
1px solid rgba(88,138,255,.35);
color:#ffffff;
box-shadow:
0 12px 30px rgba(67,117,255,.16);
}

.sopx-step.active::before{
content:'';
position:absolute;
inset:0;
background:
linear-gradient(
90deg,
transparent,
rgba(255,255,255,.06),
transparent
);
}

/* =========================================
PANELS
========================================= */

.sopx-panel,
.sopx-resultbox{
position:relative;
overflow:hidden;
background:
linear-gradient(
180deg,
rgba(7,20,38,.98),
rgba(4,14,28,.99)
);
border:
1px solid rgba(255,255,255,.06);
border-radius:38px;
padding:48px 40px;
box-shadow:
0 20px 60px rgba(0,0,0,.30);
animation:sopFade .28s ease;
}

@keyframes sopFade{
from{
opacity:0;
transform:translateY(10px);
}
to{
opacity:1;
transform:none;
}
}

.sopx-h{
font-family:
'Cormorant Garamond',
serif;
font-size:66px;
line-height:1;
font-weight:700;
margin-bottom:18px;
color:#ffffff;
letter-spacing:-1px;
}

.sopx-p{
font-size:18px;
line-height:2;
color:
rgba(255,255,255,.68);
margin-bottom:38px;
max-width:760px;
}

/* =========================================
GRID
========================================= */

.sopx-grid{
display:grid;
grid-template-columns:
repeat(2,minmax(0,1fr));
gap:26px;
margin-bottom:38px;
}

.sopx-field{
position:relative;
}

.sopx-lbl{
display:block;
margin-bottom:12px;
font-size:14px;
font-weight:700;
letter-spacing:.4px;
color:#ffffff;
}

/* =========================================
INPUTS
========================================= */

.sopx-inp,
.sopx-select,
.sopx-textarea{
width:100%;
border-radius:20px;
border:
1px solid rgba(255,255,255,.08);
background:
rgba(255,255,255,.04);
font-family:'Syne',sans-serif;
color:#ffffff;
outline:none;
transition:.22s ease;
appearance:none;
}

.sopx-inp,
.sopx-select{
height:68px;
padding:0 22px;
font-size:16px;
}

.sopx-textarea{
min-height:320px;
padding:24px;
font-size:15px;
line-height:2;
resize:vertical;
}

.sopx-inp::placeholder,
.sopx-textarea::placeholder{
color:
rgba(255,255,255,.32);
}

.sopx-select option{
background:#071423;
color:#ffffff;
}

.sopx-inp:focus,
.sopx-select:focus,
.sopx-textarea:focus{
border:
1px solid rgba(92,138,255,.45);
background:
rgba(255,255,255,.06);
box-shadow:
0 0 0 4px rgba(92,138,255,.12);
}

.sopx-error{
border:
1px solid rgba(255,95,95,.7)!important;
background:
rgba(255,70,70,.06)!important;
box-shadow:
0 0 0 4px rgba(255,70,70,.08)!important;
}

.sopx-error-text{
margin-top:8px;
font-size:13px;
line-height:1.7;
color:#ffaaaa;
font-weight:600;
display:flex;
align-items:flex-start;
gap:6px;
}

/* =========================================
UPLOAD ZONE
========================================= */

.sopx-upload{
position:relative;
overflow:hidden;
border-radius:28px;
border:
2px dashed rgba(92,138,255,.22);
background:
linear-gradient(
180deg,
rgba(255,255,255,.03),
rgba(255,255,255,.02)
);
padding:42px 28px;
text-align:center;
cursor:pointer;
transition:.24s ease;
margin-bottom:28px;
}

.sopx-upload:hover{
border:
2px dashed rgba(92,138,255,.42);
background:
linear-gradient(
180deg,
rgba(72,120,255,.08),
rgba(255,255,255,.03)
);
}

.sopx-upload.active{
border:
2px solid rgba(92,138,255,.45);
background:
linear-gradient(
180deg,
rgba(72,120,255,.12),
rgba(255,255,255,.04)
);
box-shadow:
0 18px 42px rgba(72,120,255,.14);
}

.sopx-upload-icon{
width:78px;
height:78px;
border-radius:24px;
margin:0 auto 22px;
display:flex;
align-items:center;
justify-content:center;
background:
linear-gradient(
135deg,
rgba(72,120,255,.18),
rgba(72,120,255,.05)
);
border:
1px solid rgba(92,138,255,.18);
font-size:34px;
color:#89b0ff;
}

.sopx-upload-title{
font-size:24px;
font-weight:800;
line-height:1.4;
color:#ffffff;
margin-bottom:14px;
}

.sopx-upload-text{
font-size:15px;
line-height:1.9;
color:
rgba(255,255,255,.62);
max-width:620px;
margin:0 auto 22px;
}

.sopx-upload-meta{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:10px 18px;
border-radius:999px;
background:
rgba(255,255,255,.05);
border:
1px solid rgba(255,255,255,.08);
font-size:12px;
font-weight:700;
letter-spacing:.4px;
color:#9dbdff;
}

.sopx-hidden-file{
display:none;
}

/* =========================================
TEXTAREA AREA
========================================= */

.sopx-editor-wrap{
position:relative;
}

.sopx-editor-top{
display:flex;
align-items:center;
justify-content:space-between;
gap:18px;
margin-bottom:18px;
flex-wrap:wrap;
}

.sopx-editor-label{
font-size:16px;
font-weight:800;
color:#ffffff;
}

.sopx-editor-stats{
display:flex;
align-items:center;
gap:12px;
flex-wrap:wrap;
}

.sopx-stat{
display:inline-flex;
align-items:center;
justify-content:center;
padding:10px 16px;
border-radius:999px;
background:
rgba(255,255,255,.04);
border:
1px solid rgba(255,255,255,.06);
font-size:12px;
font-weight:700;
letter-spacing:.4px;
color:#8eb3ff;
}

.sopx-editor-note{
margin-top:16px;
padding:18px 20px;
border-radius:20px;
background:
rgba(255,255,255,.03);
border:
1px solid rgba(255,255,255,.06);
font-size:14px;
line-height:1.9;
color:
rgba(255,255,255,.66);
}

.sopx-editor-note strong{
color:#ffd76a;
}

/* =========================================
BUTTONS
========================================= */

.sopx-actions{
display:flex;
flex-wrap:wrap;
gap:16px;
margin-top:18px;
}

.sopx-btn{
position:relative;
overflow:hidden;
border:none;
outline:none;
cursor:pointer;
min-height:60px;
padding:0 30px;
border-radius:20px;
font-family:'Syne',sans-serif;
font-size:15px;
font-weight:800;
transition:.22s ease;
display:inline-flex;
align-items:center;
justify-content:center;
text-align:center;
letter-spacing:.2px;
}

.sopx-btn::before{
content:'';
position:absolute;
top:0;
left:-120%;
width:100%;
height:100%;
background:
linear-gradient(
90deg,
transparent,
rgba(255,255,255,.18),
transparent
);
transition:left .7s ease;
}

.sopx-btn:hover::before{
left:120%;
}

.sopx-next,
.sopx-submit,
.sopx-send,
.sopx-restart{
background:
linear-gradient(
135deg,
#4d86ff,
#2d67ff
);
color:#ffffff;
box-shadow:
0 16px 38px rgba(54,110,255,.24);
}

.sopx-next:hover,
.sopx-submit:hover,
.sopx-send:hover,
.sopx-restart:hover{
transform:
translateY(-2px);
box-shadow:
0 22px 42px rgba(54,110,255,.30);
}

.sopx-gold{
background:
linear-gradient(
135deg,
#f5c518,
#ffdc67
);
color:#07101d;
box-shadow:
0 16px 38px rgba(245,197,24,.20);
}

.sopx-gold:hover{
transform:
translateY(-2px);
box-shadow:
0 22px 42px rgba(245,197,24,.28);
}

.sopx-back{
background:
rgba(255,255,255,.05);
border:
1px solid rgba(255,255,255,.08);
color:#ffffff;
}

.sopx-back:hover{
background:
rgba(255,255,255,.07);
}

/* =========================================
ANALYSIS CARDS
========================================= */

.sopx-cardgrid{
display:grid;
grid-template-columns:
repeat(2,minmax(0,1fr));
gap:22px;
margin-bottom:34px;
}

.sopx-card{
position:relative;
overflow:hidden;
background:
rgba(255,255,255,.03);
border:
1px solid rgba(255,255,255,.06);
border-radius:28px;
padding:28px;
transition:.22s ease;
}

.sopx-card:hover{
transform:
translateY(-3px);
border:
1px solid rgba(92,138,255,.22);
}

.sopx-card-top{
display:flex;
align-items:flex-start;
gap:16px;
margin-bottom:18px;
}

.sopx-card-icon{
width:50px;
height:50px;
border-radius:18px;
display:flex;
align-items:center;
justify-content:center;
background:
linear-gradient(
135deg,
rgba(72,120,255,.16),
rgba(72,120,255,.05)
);
border:
1px solid rgba(92,138,255,.18);
font-size:20px;
color:#8cb0ff;
flex-shrink:0;
}

.sopx-card-title{
font-size:20px;
font-weight:800;
line-height:1.4;
color:#ffffff;
margin-bottom:8px;
}

.sopx-card-text{
font-size:14px;
line-height:1.9;
color:
rgba(255,255,255,.64);
}

/* =========================================
SCORE BARS
========================================= */

.sopx-bars{
display:flex;
flex-direction:column;
gap:18px;
margin-bottom:36px;
}

.sopx-bar{
width:100%;
}

.sopx-bar-row{
display:flex;
align-items:center;
justify-content:space-between;
gap:16px;
margin-bottom:10px;
}

.sopx-bar-label{
font-size:14px;
font-weight:700;
color:#ffffff;
}

.sopx-bar-score{
font-size:13px;
font-weight:700;
color:#8eb3ff;
}

.sopx-bar-bg{
height:14px;
border-radius:999px;
overflow:hidden;
background:
rgba(255,255,255,.05);
}

.sopx-bar-fill{
height:100%;
border-radius:999px;
background:
linear-gradient(
90deg,
#4c88ff,
#78a8ff
);
box-shadow:
0 0 18px rgba(76,136,255,.28);
}

/* =========================================
RESULT HEADER
========================================= */

.sopx-scoreline{
display:flex;
align-items:center;
gap:22px;
margin-bottom:34px;
flex-wrap:wrap;
}

.sopx-circle{
position:relative;
width:108px;
height:108px;
border-radius:50%;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
background:
rgba(255,255,255,.03);
border:4px solid;
box-shadow:
0 14px 30px rgba(0,0,0,.22);
flex-shrink:0;
overflow:hidden;
}

.sopx-circle::before{
content:'';
position:absolute;
inset:0;
background:
linear-gradient(
180deg,
rgba(255,255,255,.08),
transparent
);
pointer-events:none;
}

.sopx-circle.high{
border-color:#35d17f;
}

.sopx-circle.mid{
border-color:#f5c518;
}

.sopx-circle.low{
border-color:#ff6464;
}

.sopx-num{
font-size:34px;
font-weight:800;
line-height:1;
position:relative;
z-index:2;
}

.sopx-subnum{
font-size:11px;
margin-top:5px;
opacity:.65;
position:relative;
z-index:2;
}

.sopx-scorecontent{
flex:1;
min-width:240px;
}

.sopx-status{
font-size:34px;
font-weight:800;
line-height:1.2;
margin-bottom:12px;
}

.sopx-status.high{
color:#35d17f;
}

.sopx-status.mid{
color:#f5c518;
}

.sopx-status.low{
color:#ff7070;
}

.sopx-advice{
font-size:17px;
line-height:1.9;
color:
rgba(255,255,255,.72);
max-width:760px;
}

/* =========================================
WEAK SENTENCE SYSTEM
========================================= */

.sopx-weak-wrap{
display:flex;
flex-direction:column;
gap:24px;
margin-bottom:38px;
}

.sopx-weak-card{
position:relative;
overflow:hidden;
border-radius:30px;
padding:30px;
background:
linear-gradient(
180deg,
rgba(255,255,255,.03),
rgba(255,255,255,.02)
);
border:
1px solid rgba(255,255,255,.06);
}

.sopx-weak-card::before{
content:'';
position:absolute;
top:0;
left:0;
width:4px;
height:100%;
background:
linear-gradient(
180deg,
#ff6b6b,
#f5c518
);
}

.sopx-weak-label{
display:inline-flex;
align-items:center;
justify-content:center;
padding:9px 16px;
border-radius:999px;
background:
rgba(255,107,107,.10);
border:
1px solid rgba(255,107,107,.18);
font-size:12px;
font-weight:800;
letter-spacing:.4px;
color:#ffb0b0;
margin-bottom:18px;
}

.sopx-weak-text{
font-size:18px;
line-height:2;
color:#ffffff;
margin-bottom:24px;
font-weight:600;
}

.sopx-better{
padding:22px;
border-radius:22px;
background:
linear-gradient(
135deg,
rgba(52,209,127,.10),
rgba(52,209,127,.03)
);
border:
1px solid rgba(52,209,127,.18);
}

.sopx-better-title{
font-size:14px;
font-weight:800;
letter-spacing:.4px;
color:#8ff0b8;
margin-bottom:12px;
}

.sopx-better-text{
font-size:15px;
line-height:1.9;
color:
rgba(255,255,255,.74);
}

/* =========================================
RISK + RECOMMENDATION
========================================= */

.sopx-list{
display:flex;
flex-direction:column;
gap:16px;
padding-left:22px;
margin-bottom:38px;
}

.sopx-list li{
font-size:15px;
line-height:1.9;
color:
rgba(255,255,255,.76);
}

.sopx-risk li{
color:#ffb3b3;
}

.sopx-successbox{
padding:24px;
border-radius:24px;
background:
linear-gradient(
135deg,
rgba(52,209,127,.10),
rgba(52,209,127,.04)
);
border:
1px solid rgba(52,209,127,.22);
color:#8ff0b8;
font-size:15px;
line-height:1.9;
margin-bottom:36px;
font-weight:600;
}

/* =========================================
LOADING SCREEN
========================================= */

.sopx-loading{
position:relative;
overflow:hidden;
border-radius:34px;
padding:54px 36px;
background:
linear-gradient(
180deg,
rgba(7,20,38,.98),
rgba(4,14,28,.99)
);
border:
1px solid rgba(255,255,255,.06);
text-align:center;
}

.sopx-loader{
width:86px;
height:86px;
border-radius:50%;
margin:0 auto 26px;
border:
4px solid rgba(255,255,255,.08);
border-top:
4px solid #5b8eff;
animation:sopSpin 1s linear infinite;
}

@keyframes sopSpin{
to{
transform:rotate(360deg);
}
}

.sopx-loading-title{
font-size:32px;
font-weight:800;
line-height:1.3;
color:#ffffff;
margin-bottom:16px;
}

.sopx-loading-text{
font-size:16px;
line-height:2;
color:
rgba(255,255,255,.66);
max-width:680px;
margin:0 auto;
}

/* =========================================
SOP CTA BLOCK
========================================= */

.sopx-sop-help{
margin:42px 0 34px;
}

.sopx-sop-warning{
position:relative;
overflow:hidden;
border-radius:32px;
padding:34px 32px;
background:
linear-gradient(
145deg,
rgba(17,12,8,.96),
rgba(8,8,12,.98)
);
border:
1px solid rgba(245,197,24,.12);
box-shadow:
0 20px 50px rgba(0,0,0,.34);
}

.sopx-sop-warning::before{
content:'';
position:absolute;
top:-40%;
right:-10%;
width:280px;
height:280px;
background:
radial-gradient(
circle,
rgba(245,197,24,.10),
transparent 72%
);
pointer-events:none;
}

.sopx-sop-icon{
width:58px;
height:58px;
border-radius:18px;
display:flex;
align-items:center;
justify-content:center;
background:
linear-gradient(
135deg,
rgba(245,197,24,.18),
rgba(245,197,24,.06)
);
border:
1px solid rgba(245,197,24,.18);
font-size:26px;
color:#ffd76a;
margin-bottom:20px;
}

.sopx-sop-copy h3{
font-size:32px;
line-height:1.3;
font-weight:800;
color:#f8d36a;
margin-bottom:18px;
max-width:720px;
}

.sopx-sop-copy p{
font-size:16px;
line-height:2;
color:
rgba(255,255,255,.72);
max-width:760px;
margin-bottom:28px;
}

.sopx-sop-btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:12px;
min-height:62px;
padding:0 30px;
border-radius:18px;
text-decoration:none;
font-size:15px;
font-weight:800;
letter-spacing:.3px;
color:#07101d;
background:
linear-gradient(
135deg,
#f5c518,
#ffdb58
);
box-shadow:
0 18px 40px rgba(245,197,24,.22);
transition:.22s ease;
}

.sopx-sop-btn:hover{
transform:
translateY(-2px);
box-shadow:
0 22px 44px rgba(245,197,24,.28);
}

/* =========================================
MESSAGE STATES
========================================= */

.sopx-msg{
margin-top:18px;
font-size:14px;
line-height:1.8;
}

.sopx-msg.success{
color:#8ff0b8;
}

.sopx-msg.fail{
color:#ffaaaa;
}

.sopx-msg.loading{
color:#8eb3ff;
}

/* =========================================
FOOTER
========================================= */

.sopx-footer{
text-align:center;
padding:40px 10px 0;
font-size:13px;
line-height:1.9;
color:
rgba(255,255,255,.42);
}

.sopx-footer a{
color:#84acff;
text-decoration:none;
}

/* =========================================
RESPONSIVE
========================================= */

@media(max-width:900px){

.sopx-title{
font-size:68px;
}

.sopx-h{
font-size:54px;
}

.sopx-hero-grid,
.sopx-cardgrid{
grid-template-columns:1fr;
}

}




@media(max-width:768px){

#sopx{
padding-top:24px;
padding-left:14px;
padding-right:14px;
padding-bottom:0!important;
}

.sopx-header,
.sopx-panel,
.sopx-resultbox{
padding:32px 24px;
border-radius:28px;
}

.sopx-title{
font-size:56px;
line-height:.96;
}

.sopx-h{
font-size:44px;
}

.sopx-sub{
font-size:18px;
line-height:1.9;
}

.sopx-grid{
grid-template-columns:1fr;
gap:18px;
}

.sopx-progress{
grid-template-columns:1fr;
}

.sopx-actions{
flex-direction:column;
}

.sopx-btn,
.sopx-sop-btn{
width:100%;
}

.sopx-scoreline{
flex-direction:column;
align-items:flex-start;
}

.sopx-circle{
width:96px;
height:96px;
}

.sopx-num{
font-size:30px;
}

.sopx-status{
font-size:28px;
}

.sopx-loading-title{
font-size:26px;
}

}

@media(max-width:480px){

.sopx-title{
font-size:46px;
}

.sopx-h{
font-size:38px;
}

.sopx-sub{
font-size:16px;
line-height:1.8;
}

.sopx-weak-text{
font-size:16px;
}

.sopx-sop-copy h3{
font-size:24px;
}

.sopx-loading-title{
font-size:22px;
}

}


/* =========================================
SAFARI + OVERFLOW FIXES
========================================= */

#sopx{
overflow:visible!important;
}

.sopx-header,
.sopx-panel,
.sopx-resultbox{
overflow:visible!important;
}

.sopx-header::before,
.sopx-header::after{
pointer-events:none;
z-index:0;
}

.sopx-header > *,
.sopx-panel > *,
.sopx-resultbox > *{
position:relative;
z-index:2;
}

/* =========================================
TYPOGRAPHY FIXES
========================================= */

.sopx-title{
line-height:1.02!important;
padding-bottom:10px;
}

.sopx-h{
line-height:1.08!important;
padding-bottom:8px;
}

.sopx-mini{
display:block;
font-size:15px;
font-weight:800;
letter-spacing:.4px;
line-height:1.6;
margin-top:38px;
margin-bottom:22px;
color:#7ea8ff;
text-transform:none;
}

/* =========================================
UPLOAD SYSTEM
========================================= */

.sopx-upload-wrap{
position:relative;
overflow:hidden;
border-radius:30px;
padding:28px;
background:
linear-gradient(
180deg,
rgba(255,255,255,.03),
rgba(255,255,255,.02)
);
border:
1px solid rgba(255,255,255,.07);
margin-bottom:34px;
}

.sopx-upload-top{
display:flex;
align-items:center;
justify-content:space-between;
gap:18px;
flex-wrap:wrap;
margin-bottom:22px;
}

.sopx-upload-badge{
display:inline-flex;
align-items:center;
justify-content:center;
padding:11px 18px;
border-radius:999px;
background:
rgba(72,120,255,.10);
border:
1px solid rgba(88,138,255,.18);
font-size:13px;
font-weight:700;
letter-spacing:.4px;
color:#8cb0ff;
}

.sopx-upload-stats{
display:flex;
align-items:center;
gap:12px;
flex-wrap:wrap;
}

.sopx-helper{
margin-top:20px;
display:flex;
flex-direction:column;
gap:14px;
}

.sopx-helper-item{
padding-left:2px;
font-size:14px;
line-height:1.9;
color:
rgba(255,255,255,.72);
}

/* =========================================
COUNTRY NOTE
========================================= */

.sopx-country-note{
margin-top:34px;
padding:28px;
border-radius:28px;
background:
linear-gradient(
135deg,
rgba(72,120,255,.08),
rgba(72,120,255,.03)
);
border:
1px solid rgba(88,138,255,.18);
}

.sopx-country-title{
font-size:16px;
font-weight:800;
line-height:1.5;
color:#8db3ff;
margin-bottom:14px;
}

.sopx-country-text{
font-size:15px;
line-height:2;
color:
rgba(255,255,255,.76);
}

/* =========================================
WARNING BOX
========================================= */

.sopx-warning-box{
position:relative;
overflow:hidden;
margin-top:34px;
margin-bottom:38px;
padding:32px;
border-radius:30px;
background:
linear-gradient(
145deg,
rgba(30,12,12,.96),
rgba(10,10,14,.98)
);
border:
1px solid rgba(255,107,107,.16);
box-shadow:
0 18px 50px rgba(0,0,0,.28);
}

.sopx-warning-box::before{
content:'';
position:absolute;
top:-40%;
right:-10%;
width:260px;
height:260px;
background:
radial-gradient(
circle,
rgba(255,107,107,.10),
transparent 72%
);
pointer-events:none;
}

.sopx-warning-title{
font-size:24px;
line-height:1.5;
font-weight:800;
color:#ffb3b3;
margin-bottom:16px;
position:relative;
z-index:2;
}

.sopx-warning-text{
font-size:15px;
line-height:2;
color:
rgba(255,255,255,.74);
margin-bottom:26px;
max-width:760px;
position:relative;
z-index:2;
}

.sopx-warning-btn{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
min-height:60px;
padding:0 28px;
border-radius:18px;
background:
linear-gradient(
135deg,
#f5c518,
#ffdc67
);
color:#07101d;
font-size:15px;
font-weight:800;
text-decoration:none;
box-shadow:
0 16px 36px rgba(245,197,24,.22);
transition:.22s ease;
position:relative;
z-index:2;
}

.sopx-warning-btn:hover{
transform:translateY(-2px);
}

/* =========================================
TAGS
========================================= */

.sopx-tags{
display:flex;
flex-wrap:wrap;
gap:12px;
margin-bottom:38px;
}

.sopx-tag{
display:inline-flex;
align-items:center;
justify-content:center;
padding:10px 16px;
border-radius:999px;
background:
rgba(255,255,255,.04);
border:
1px solid rgba(255,255,255,.08);
font-size:13px;
font-weight:700;
line-height:1.4;
color:#ffd27a;
}

/* =========================================
IMPROVEMENT PLAN
========================================= */

.sopx-plan{
display:flex;
flex-direction:column;
gap:18px;
margin-bottom:42px;
}

.sopx-planrow{
display:flex;
align-items:flex-start;
gap:18px;
padding:22px;
border-radius:24px;
background:
rgba(255,255,255,.03);
border:
1px solid rgba(255,255,255,.06);
transition:.22s ease;
}

.sopx-planrow:hover{
transform:translateY(-2px);
border:
1px solid rgba(92,138,255,.16);
}

.sopx-day{
min-width:86px;
padding:12px 16px;
border-radius:16px;
background:
linear-gradient(
135deg,
rgba(72,120,255,.16),
rgba(72,120,255,.05)
);
border:
1px solid rgba(92,138,255,.16);
font-size:13px;
font-weight:800;
letter-spacing:.3px;
color:#8cb0ff;
text-align:center;
flex-shrink:0;
}

.sopx-task{
font-size:15px;
line-height:1.9;
color:
rgba(255,255,255,.76);
padding-top:2px;
}

/* =========================================
RETRY SECTION
========================================= */

.sopx-retry{
margin-top:42px;
padding:34px 30px;
border-radius:30px;
background:
linear-gradient(
135deg,
rgba(72,120,255,.08),
rgba(72,120,255,.03)
);
border:
1px solid rgba(88,138,255,.16);
margin-bottom:12px;
}

.sopx-retry-title{
font-size:30px;
line-height:1.3;
font-weight:800;
color:#ffffff;
margin-bottom:16px;
}

.sopx-retry-text{
font-size:15px;
line-height:2;
color:
rgba(255,255,255,.72);
max-width:760px;
margin-bottom:28px;
}

/* =========================================
INLINE LINK
========================================= */

.sopx-inline-link{
display:inline-flex;
align-items:center;
justify-content:center;
gap:10px;
padding:12px 18px;
border-radius:14px;
background:
rgba(72,120,255,.10);
border:
1px solid rgba(92,138,255,.18);
color:#9dc0ff!important;
font-size:14px;
font-weight:700;
text-decoration:none!important;
transition:.22s ease;
}

.sopx-inline-link:hover{
transform:translateY(-2px);
background:
rgba(72,120,255,.16);
}

/* =========================================
BETTER BUTTON SPACING
========================================= */

.sopx-actions{
margin-top:30px!important;
padding-top:10px;
}

.sopx-btn{
min-height:64px;
padding:0 34px;
}

/* =========================================
RESULT SECTION SPACING
========================================= */

.sopx-bars,
.sopx-list,
.sopx-risk,
.sopx-tags,
.sopx-plan{
margin-top:10px;
}

.sopx-list li{
padding-left:4px;
line-height:2;
}

/* =========================================
MOBILE FIXES
========================================= */

@media(max-width:768px){

.sopx-planrow{
flex-direction:column;
}

.sopx-day{
min-width:100%;
}

.sopx-retry-title{
font-size:24px;
}

.sopx-warning-title{
font-size:21px;
}

.sopx-upload-wrap{
padding:22px;
}

.sopx-title{
font-size:58px;
line-height:1.04!important;
}

.sopx-h{
font-size:44px;
line-height:1.1!important;
}

}

@media(max-width:480px){

.sopx-title{
font-size:48px;
}

.sopx-h{
font-size:38px;
}

.sopx-warning-box,
.sopx-country-note,
.sopx-retry{
padding:24px;
}

.sopx-warning-title{
font-size:19px;
line-height:1.6;
}

.sopx-retry-title{
font-size:22px;
}

.sopx-task,
.sopx-warning-text,
.sopx-country-text{
font-size:14px;
line-height:1.9;
}

}


/* =========================================
SAFE iPHONE BOTTOM SPACE FIX
========================================= */

#sopx{
padding-bottom:12px!important;
}

.sopx-footer{
padding-bottom:0!important;
margin-bottom:0!important;
}

body{
overflow-x:hidden;
}

@media(max-width:768px){

#sopx{
padding-bottom:2px!important;
}

}














/* =========================================
FINAL FULL-HEIGHT MOBILE FIX (MUST BE LAST IN style.css)
========================================= */

html, body {
    height: 100%;
    min-height: 100dvh;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
}

#sopx {
    width: 100%;
    min-height: 100dvh;
    padding: 42px 18px 20px !important;
    position: relative;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
}

.sopx-wrap {
    flex: 1;
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1040px;
    margin: 0 auto;
}

.sopx-footer {
    margin-top: auto !important;
    padding: 40px 10px 30px !important;
}

.sopx-result,
.sopx-resultbox {
    flex: 1;
    display: flex;
    flex-direction: column;
}

/* Mobile Optimization */
@media (max-width: 768px) {
    #sopx {
        padding: 24px 14px 16px !important;
    }
    
    .sopx-footer {
        padding-bottom: 40px !important;
    }
}

/* Extra Safety */
body.sopx-lock,
#sopx::after,
.sopx-header::after {
    display: none !important;
}







/* =========================================
PREMIUM GLOBAL TOOL FOOTER
========================================= */

.gsgx-tool-footer{
margin-top:90px;
padding:55px 22px 46px;
background:
linear-gradient(
180deg,
rgba(255,255,255,.03),
rgba(255,255,255,.015)
);
border-top:
1px solid rgba(255,255,255,.07);
position:relative;
overflow:hidden;
}

.gsgx-tool-footer::before{
content:'';
position:absolute;
top:-120px;
right:-120px;
width:260px;
height:260px;
background:
radial-gradient(
circle,
rgba(245,197,24,.08),
transparent 72%
);
pointer-events:none;
}

.gsgx-tool-footer-inner{
width:100%;
max-width:1120px;
margin:0 auto;
position:relative;
z-index:2;
}

.gsgx-tool-brand h3{
font-size:1.45rem;
line-height:1.2;
font-weight:800;
letter-spacing:-0.5px;
color:#ffffff;
margin-bottom:18px;
}

.gsgx-tool-brand p{
max-width:820px;
font-size:1rem;
line-height:1.95;
color:#c9d4df;
}

.gsgx-tool-footer-links{
display:flex;
flex-wrap:wrap;
gap:14px;
margin-top:34px;
}

.gsgx-tool-footer-links a{
display:inline-flex;
align-items:center;
justify-content:center;
padding:13px 18px;
border-radius:14px;
background:
rgba(255,255,255,.05);
border:
1px solid rgba(255,255,255,.08);
text-decoration:none;
font-size:.9rem;
font-weight:700;
letter-spacing:.01em;
color:#f5f7fb;
transition:
all .28s ease;
backdrop-filter:blur(8px);
}

.gsgx-tool-footer-links a:hover{
transform:
translateY(-2px);
background:
rgba(212,175,55,.10);
border-color:
rgba(212,175,55,.30);
color:#f5c518;
}

.gsgx-tool-footer-copy{
margin-top:30px;
padding-top:22px;
border-top:
1px solid rgba(255,255,255,.06);
font-size:.84rem;
line-height:1.8;
color:#8ea0b5;
}

/* =========================================
MOBILE
========================================= */

@media(max-width:768px){

.gsgx-tool-footer{
margin-top:70px;
padding:42px 20px 40px;
}

.gsgx-tool-brand h3{
font-size:1.2rem;
margin-bottom:16px;
}

.gsgx-tool-brand p{
font-size:.93rem;
line-height:1.9;
}

.gsgx-tool-footer-links{
flex-direction:column;
gap:12px;
}

.gsgx-tool-footer-links a{
width:100%;
padding:15px 18px;
font-size:.92rem;
}

.gsgx-tool-footer-copy{
font-size:.8rem;
line-height:1.7;
}

}