:root{
  --bg:#070b14;
  --bg-2:#0c1220;
  --panel:#0f1627;
  --panel-2:#131d31;
  --line:#24314a;
  --text:#ffffff;
  --muted:#b7c3dc;
  --primary:#e11d2e;
  --accent:#ff4d5a;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,Arial,sans-serif;background:linear-gradient(180deg,var(--bg),#0b1020);color:var(--text)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea,select{font:inherit}
.container{width:min(1240px,92%);margin:0 auto}
.muted{color:var(--muted)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:14px;padding:12px 16px;font-weight:800;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff}
.btn-secondary{background:rgba(255,255,255,.05);border:1px solid var(--line);color:#fff}
.btn-danger{background:#8b1220;color:#fff}
.notice{padding:12px 14px;border-radius:14px;background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.26);display:none}
.alert{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.22);padding:12px 14px;border-radius:14px}

.site-header{position:sticky;top:0;z-index:40;background:rgba(5,7,13,.84);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}
.site-nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:14px;font-weight:900;font-size:20px;letter-spacing:.01em}
.brand img{width:48px;height:48px;object-fit:cover;border-radius:8px;background:#000}
.menu-toggle{display:none}
.menu{display:flex;align-items:center;gap:18px}
.menu a{color:#eef2ff;font-weight:600}
.menu a:hover{color:var(--accent)}
.admin-btn{border:1px solid var(--primary);padding:10px 16px;border-radius:12px;color:#fff;background:rgba(225,29,46,.08)}

.hero{min-height:86vh;display:grid;place-items:center;position:relative;overflow:hidden;background:#0f111a}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.42),rgba(0,0,0,.72))}
.hero__content{position:relative;text-align:center;max-width:980px;padding:80px 0}
.hero__content h1{font-size:clamp(48px,7vw,84px);line-height:1.02;margin:0 0 18px;text-shadow:0 5px 0 rgba(0,0,0,.45)}
.hero__content p{font-size:clamp(20px,2.2vw,34px);color:#dce4f6;margin:0 auto}

.section{padding:88px 0}
.section--dark{background:linear-gradient(180deg,#0a0e18,#0c1120)}
.section-title{text-align:center;margin:0 0 12px;font-size:clamp(34px,5vw,60px)}
.section-subtitle{text-align:center;color:var(--muted);max-width:820px;margin:0 auto 40px;font-size:clamp(18px,2vw,28px)}

.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.service-card{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.1);border-radius:18px;padding:26px}
.service-icon{width:62px;height:62px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;font-size:26px;margin-bottom:16px}
.service-card h3{font-size:22px;margin:0 0 12px}.service-card p{color:var(--muted);line-height:1.7;margin:0}

.filter-bar{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:28px}
.chip{padding:10px 16px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:rgba(255,255,255,.03);cursor:pointer;color:#fff}
.chip.active{background:linear-gradient(135deg,var(--primary),var(--accent));border-color:transparent}
.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.project-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);border-radius:20px;overflow:hidden;display:flex;flex-direction:column}
.project-card img{width:100%;height:290px;object-fit:cover;background:#10131d}
.project-card__body{padding:18px}
.project-card__meta{display:flex;justify-content:space-between;gap:12px;color:#b8c2da;font-size:14px;margin-bottom:10px}
.project-card h3{font-size:26px;margin:0 0 10px}.project-card p{color:var(--muted);margin:0 0 18px;line-height:1.7}

.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.contact-card,.form-card,.admin-card,.client-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:22px;padding:24px}
.info-list{display:grid;gap:14px}.info-row{display:flex;gap:12px;align-items:flex-start}.info-row__icon{color:var(--accent);font-size:22px;min-width:24px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card input,.form-card textarea,.admin-form input,.admin-form textarea,.admin-form select,.client-form input{width:100%;padding:14px 16px;border-radius:14px;border:1px solid var(--line);background:#0c1425;color:#fff}
.form-card textarea{min-height:170px;grid-column:1/-1}
.form-card button,.client-form button{border:none;border-radius:14px;padding:14px 18px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800}

.footer{border-top:1px solid rgba(255,255,255,.08);padding:42px 0;background:#05060a}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:28px}.footer h4{font-size:18px;margin:0 0 18px}.footer p,.footer li,.footer a{color:var(--muted);line-height:1.8}.footer ul{list-style:none;padding:0;margin:0}

.project-view{padding:56px 0 96px}
.project-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;margin-bottom:24px}
.project-mainimg{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.08)} .project-mainimg img{width:100%;height:620px;object-fit:cover}
.project-summary{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:24px;padding:26px}
.project-summary h1{font-size:48px;margin:0 0 12px}.project-summary p{color:var(--muted);line-height:1.8}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.gallery-grid img{width:100%;height:240px;object-fit:cover;border-radius:18px;border:1px solid rgba(255,255,255,.08)}

.admin-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{background:#0c1220;border-right:1px solid var(--line);padding:22px}
.sidebar nav{display:grid;gap:10px}.sidebar a{padding:12px 14px;border-radius:14px;border:1px solid transparent;background:transparent;color:#c6d0e8;text-align:left;cursor:pointer}
.sidebar a.active,.sidebar a:hover{background:rgba(225,29,46,.14);border-color:rgba(225,29,46,.3);color:#fff}
.content{padding:28px}
.page{display:grid;gap:20px}
.stats-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:16px}
.stat{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:18px;padding:20px}.stat b{display:block;font-size:30px;margin-top:8px}
.admin-form{display:grid;gap:16px}.admin-form .grid2,.admin-form .grid3,.admin-form .grid4,.admin-form .grid5{display:grid;gap:16px}.admin-form .grid2{grid-template-columns:repeat(2,1fr)}.admin-form .grid3{grid-template-columns:repeat(3,1fr)}.admin-form .grid4{grid-template-columns:repeat(4,1fr)}.admin-form .grid5{grid-template-columns:repeat(5,1fr)}
.toolbar{display:flex;justify-content:space-between;gap:16px;align-items:center}.btnrow{display:flex;gap:10px;flex-wrap:wrap}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}.table td{color:#c6d0e8}
.preview-pane{background:#fff;color:#111;border-radius:16px;padding:20px;min-height:300px;overflow:auto}
.preview-stage{background:radial-gradient(circle at top,#1a2440,#0a1020);border:1px solid var(--line);border-radius:24px;padding:24px;overflow:auto;min-height:720px}
.preview-paper{margin:0 auto;background:#fff;color:#111;border-radius:12px;box-shadow:0 24px 60px rgba(0,0,0,.35);transform-origin:top center;transition:.2s;padding:38px;min-height:920px}
.preview-paper.letter{width:816px;min-height:1056px}.preview-paper.a4{width:794px;min-height:1123px}.preview-paper.legal{width:816px;min-height:1344px}
.preview-paper.landscape.letter{width:1056px;min-height:816px}.preview-paper.landscape.a4{width:1123px;min-height:794px}.preview-paper.landscape.legal{width:1344px;min-height:816px}
.preview-paper.dark-doc{background:#111827;color:#f3f4f6}
.preview-email{background:#fff;color:#111;border-radius:18px;box-shadow:0 18px 40px rgba(0,0,0,.28);padding:24px;min-height:520px}

.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top right,rgba(225,29,46,.16),transparent 35%),linear-gradient(180deg,#08101f,#0b1020)}
.login-card{width:min(460px,100%);display:grid;gap:14px;background:rgba(17,24,39,.92);padding:28px;border-radius:24px;border:1px solid var(--line)}
.quote-layout{display:grid;grid-template-columns:1.45fr .95fr;gap:18px}.quote-item{border:1px solid var(--line);border-radius:18px;padding:14px;background:#101521}
.client-wrap{padding:32px 0}.client-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:18px}.client-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.client-gallery img{width:100%;height:180px;object-fit:cover;border-radius:16px}

.designer-shell{display:grid;grid-template-columns:290px 1fr;gap:22px;align-items:start}
.designer-side{position:sticky;top:18px}
.designer-nav{display:grid;gap:14px}
.designer-tab{padding:18px 20px;border-radius:18px;border:1px solid var(--line);background:linear-gradient(180deg,#0b1327,#0a1221);font-weight:800;cursor:pointer;color:#eef2ff}
.designer-tab.active{background:linear-gradient(135deg,rgba(225,29,46,.18),rgba(79,124,255,.22));border-color:#5b7fff;box-shadow:0 0 0 1px rgba(91,127,255,.25) inset}
.designer-card{background:linear-gradient(180deg,var(--panel),var(--panel-2));border:1px solid var(--line);border-radius:24px;padding:22px}
.designer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.preset-grid{display:grid;grid-template-columns:repeat(4,minmax(180px,1fr));gap:16px}
.preset-card{border:1px solid var(--line);border-radius:22px;padding:14px;background:linear-gradient(180deg,#0b1326,#0a1120);cursor:pointer;transition:.2s}
.preset-card:hover{transform:translateY(-1px);border-color:#4f7cff}
.preset-card.active{border-color:#4f7cff;box-shadow:0 0 0 2px rgba(79,124,255,.2) inset}
.preset-thumb{height:128px;border-radius:16px;background:linear-gradient(180deg,#dfe8f5,#cfd8e5);padding:10px;display:grid;gap:8px}
.preset-thumb.dark{background:linear-gradient(180deg,#162035,#0f1729)}
.preset-line{height:12px;border-radius:999px;background:#b7c2d3}
.preset-line.dark{background:#3a4863}
.preset-blocks{display:grid;grid-template-columns:2fr 1fr 1fr;gap:8px}
.preset-box{height:50px;border-radius:10px;background:#bcc7d8}.preset-box.dark{background:#37445d}
.tab-panel{display:none}.tab-panel.active{display:block}
.designer-controls{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:16px}
.designer-controls label,.designer-field label{display:block;font-size:14px;color:#cad4ea;margin-bottom:8px}
.designer-field textarea{min-height:120px}
.block-list{display:grid;gap:10px}.block-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:16px;border:1px solid var(--line);background:#0c1425;cursor:grab}
.compare-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.compare-card{border:1px solid var(--line);border-radius:22px;padding:14px;background:#0b1222}
.preview-toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}.preview-toolbar .group{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.zoom-chip{padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#0c1425;color:#fff;cursor:pointer}.zoom-chip.active{border-color:#4f7cff;background:rgba(79,124,255,.18)}
.logo-uploader{display:grid;grid-template-columns:88px 1fr;gap:14px;align-items:center}.logo-box{width:88px;height:88px;border-radius:16px;border:1px dashed #39507d;background:#0c1425;display:grid;place-items:center;overflow:hidden}
.logo-box img{width:100%;height:100%;object-fit:contain}.preset-save-list{display:flex;gap:10px;flex-wrap:wrap}.preset-pill{padding:10px 14px;border-radius:999px;background:#0c1425;border:1px solid var(--line);cursor:pointer}
.toggle-row{display:flex;gap:12px;flex-wrap:wrap}.toggle-card{padding:12px 14px;border:1px solid var(--line);border-radius:14px;background:#0c1425;display:flex;align-items:center;gap:8px}.mini-muted{font-size:12px;color:#9fb0d4}
.designer-footer-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}

@media (max-width:1200px){
  .designer-shell,.designer-grid,.compare-grid,.preset-grid,.client-grid,.project-hero,.contact-wrap,.quote-layout{grid-template-columns:1fr}
  .designer-controls,.services-grid,.portfolio-grid,.gallery-grid,.footer-grid,.stats-grid{grid-template-columns:1fr 1fr}
  .designer-side{position:relative;top:auto}
}
@media (max-width:900px){
  .admin-shell{grid-template-columns:1fr}
  .sidebar{padding:14px}
  .site-nav{flex-wrap:wrap}
  .menu-toggle{display:inline-flex}
  .menu{display:none;width:100%;flex-direction:column;align-items:flex-start;padding-top:12px}
  .menu.open{display:flex}
  .hero__content h1{font-size:44px}
}
@media (max-width:700px){
  .services-grid,.portfolio-grid,.gallery-grid,.footer-grid,.stats-grid,.form-grid,.client-gallery,.designer-controls,.admin-form .grid2,.admin-form .grid3,.admin-form .grid4,.admin-form .grid5{grid-template-columns:1fr}
  .content{padding:16px}
  .hero{min-height:72vh}
  .project-mainimg img{height:320px}
  .preview-paper.letter,.preview-paper.a4,.preview-paper.legal,.preview-paper.landscape.letter,.preview-paper.landscape.a4,.preview-paper.landscape.legal{width:100%;min-height:auto}
}

/* ===== V7.1 TEMPLATE EDITOR LAYOUT FIX ===== */
.templates-shell{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start;}
.templates-main{display:grid;grid-template-columns:1fr 420px;gap:24px;}
.builder-panel{background:#0e1626;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.06);}
.preview-panel{background:#0e1626;border-radius:12px;padding:20px;border:1px solid rgba(255,255,255,.06);position:sticky;top:20px;}
.preview-paper{width:100%;max-width:380px;margin:auto;box-shadow:0 20px 60px rgba(0,0,0,.5);border-radius:8px;overflow:hidden;}
@media (max-width:1200px){.templates-main{grid-template-columns:1fr;}.preview-panel{position:relative;}}
.block-item{display:flex;justify-content:space-between;align-items:center;padding:12px 14px;border-radius:10px;background:#111b2f;margin-bottom:10px;border:1px solid rgba(255,255,255,.05);}


/* ===== V10 ULTRA STABLE TEMPLATE FIX ===== */
.templates-shell{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:28px;
  align-items:start;
  width:100%;
}
.templates-main{
  display:grid;
  grid-template-columns:minmax(480px,1fr) minmax(360px,420px);
  gap:28px;
  align-items:start;
}
.builder-panel,
.preview-panel{
  min-width:0;
}
.preview-panel{
  position:sticky;
  top:18px;
}
.templates-main .preview-stage{
  min-height:340px;
}
.templates-main .preview-paper{
  width:100%;
  max-width:100%;
  margin:0 auto;
  box-sizing:border-box;
}
.block-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
.block-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 16px;
  border-radius:12px;
  background:#111c33;
  margin-bottom:12px;
  border:1px solid rgba(255,255,255,.05);
}
@media (max-width:1280px){
  .templates-main{grid-template-columns:1fr}
  .preview-panel{position:relative;top:auto}
}
@media (max-width:900px){
  .templates-shell{grid-template-columns:1fr}
}


/* V11 SAAS PROFESSIONAL */
.templates-main .preview-paper{
  background:#fff;
  box-shadow:0 40px 120px rgba(0,0,0,.55);
  border-radius:10px;
}
.stats-grid .stat b{font-size:28px}


/* ===== V11.2 SUPER UX TEMPLATE EDITOR ===== */

.templates-main{
display:grid;
grid-template-columns:240px 1fr 420px;
gap:28px;
align-items:start;
max-width:1700px;
margin:auto;
padding:20px;
}

.templates-sidebar{
background:rgba(15,22,40,.85);
border-radius:14px;
padding:18px;
display:flex;
flex-direction:column;
gap:12px;
position:sticky;
top:20px;
height:fit-content;
}

.templates-editor{
display:flex;
flex-direction:column;
gap:26px;
}

.editor-card{
background:rgba(20,30,55,.75);
border-radius:16px;
padding:24px;
border:1px solid rgba(255,255,255,.05);
}

.editor-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:16px;
}

.templates-preview{
background:rgba(15,22,40,.85);
border-radius:16px;
padding:20px;
position:sticky;
top:20px;
}

.preview-paper{
background:white;
border-radius:10px;
box-shadow:0 35px 90px rgba(0,0,0,.45);
padding:24px;
transform:scale(.95);
transform-origin:top center;
}

.template-presets{
display:flex;
gap:20px;
flex-wrap:wrap;
}

.template-card{
width:180px;
background:rgba(255,255,255,.04);
border-radius:12px;
padding:12px;
cursor:pointer;
transition:.25s;
}

.template-card:hover{
transform:translateY(-3px);
box-shadow:0 10px 30px rgba(0,0,0,.45);
}

.editor-toolbar{
display:flex;
justify-content:space-between;
align-items:center;
margin-bottom:20px;
}

/* responsive */

@media(max-width:1400px){

.templates-main{
grid-template-columns:220px 1fr;
}

.templates-preview{
grid-column:span 2;
}

}

@media(max-width:900px){

.templates-main{
grid-template-columns:1fr;
}

.templates-sidebar{
flex-direction:row;
flex-wrap:wrap;
}

}


/* ===== V11.3 TEMPLATE EDITOR LAYOUT ===== */

/* top menu editor */

.templates-sidebar{
width:100%;
display:flex;
justify-content:center;
gap:18px;
flex-wrap:wrap;
background:rgba(15,22,40,.9);
padding:18px;
border-radius:12px;
margin-bottom:24px;
position:relative;
}

.templates-sidebar button{
min-width:140px;
text-align:center;
}

/* main layout */

.templates-main{
display:grid;
grid-template-columns:1fr 420px;
gap:30px;
max-width:1700px;
margin:auto;
padding:10px 20px 40px 20px;
}

.templates-editor{
display:flex;
flex-direction:column;
gap:22px;
}

/* editor cards */

.editor-card{
background:rgba(20,30,55,.8);
border-radius:16px;
padding:26px;
border:1px solid rgba(255,255,255,.06);
}

/* preview area */

.templates-preview{
background:rgba(15,22,40,.9);
border-radius:16px;
padding:22px;
height:fit-content;
position:sticky;
top:20px;
}

/* preview pdf */

.preview-paper{
background:#fff;
border-radius:10px;
box-shadow:0 40px 120px rgba(0,0,0,.55);
padding:28px;
transform:scale(.95);
transform-origin:top center;
}

/* template presets */

.template-presets{
display:flex;
gap:18px;
flex-wrap:wrap;
}

.template-card{
width:180px;
border-radius:12px;
background:rgba(255,255,255,.05);
padding:12px;
transition:.25s;
cursor:pointer;
}

.template-card:hover{
transform:translateY(-4px);
box-shadow:0 20px 40px rgba(0,0,0,.45);
}

/* responsive */

@media(max-width:1200px){

.templates-main{
grid-template-columns:1fr;
}

.templates-preview{
position:relative;
}

}


/* ===== V12 ULTRA BUILDER TEMPLATE MODULE ===== */

/* TOP MENU EDITOR */

.templates-sidebar{
width:100%;
display:flex;
justify-content:center;
align-items:center;
gap:30px;
flex-wrap:wrap;
padding:18px 10px;
background:rgba(10,15,30,.95);
border-radius:14px;
margin-bottom:28px;
box-shadow:0 10px 40px rgba(0,0,0,.35);
}

.templates-sidebar button{
background:transparent;
border:1px solid rgba(255,255,255,.08);
padding:12px 18px;
border-radius:10px;
font-weight:600;
transition:.25s;
}

.templates-sidebar button:hover{
background:rgba(255,255,255,.06);
transform:translateY(-2px);
}

/* MAIN LAYOUT */

.templates-main{
display:grid;
grid-template-columns:1fr 420px;
gap:34px;
max-width:1700px;
margin:auto;
padding:10px 24px 40px;
}

/* EDITOR AREA */

.templates-editor{
display:flex;
flex-direction:column;
gap:24px;
}

/* CARDS */

.editor-card{
background:rgba(18,25,45,.85);
border-radius:16px;
padding:26px;
border:1px solid rgba(255,255,255,.05);
box-shadow:0 10px 40px rgba(0,0,0,.35);
}

/* GRID CONFIG */

.editor-grid{
display:grid;
grid-template-columns:repeat(3,1fr);
gap:18px;
}

/* TEMPLATE PRESETS */

.template-presets{
display:flex;
gap:20px;
flex-wrap:wrap;
}

.template-card{
width:180px;
background:rgba(255,255,255,.05);
border-radius:12px;
padding:14px;
transition:.25s;
cursor:pointer;
}

.template-card:hover{
transform:translateY(-4px);
box-shadow:0 20px 50px rgba(0,0,0,.45);
}

/* PREVIEW AREA */

.templates-preview{
background:rgba(12,18,35,.95);
border-radius:16px;
padding:24px;
position:sticky;
top:20px;
height:fit-content;
}

/* PDF SHEET */

.preview-paper{
background:#ffffff;
border-radius:10px;
box-shadow:0 45px 120px rgba(0,0,0,.55);
padding:30px;
transform:scale(.94);
transform-origin:top center;
}

/* BUILDER ZOOM */

.preview-controls{
display:flex;
gap:10px;
justify-content:center;
margin-bottom:12px;
}

.preview-controls button{
border:none;
padding:8px 14px;
border-radius:8px;
background:#1f2a48;
color:#fff;
cursor:pointer;
}

/* RESPONSIVE */

@media(max-width:1200px){

.templates-main{
grid-template-columns:1fr;
}

.templates-preview{
position:relative;
}

}



/* ===== V13 VISUAL DESIGNER PRO ===== */
.templates-shell{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  width:100%;
}

.templates-sidebar{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:14px;
  flex-wrap:wrap;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(10,15,30,.98),rgba(16,24,44,.96));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 18px 50px rgba(0,0,0,.28);
}

.templates-sidebar button{
  min-width:140px;
  padding:13px 16px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
  color:#fff;
  font-weight:700;
  transition:.22s ease;
}

.templates-sidebar button:hover{
  background:rgba(255,255,255,.06);
  transform:translateY(-2px);
}

.templates-main{
  display:grid;
  grid-template-columns:minmax(720px,1fr) 430px;
  gap:24px;
  align-items:start;
  max-width:1750px;
  width:100%;
  margin:0 auto;
}

.templates-editor{
  display:grid;
  gap:20px;
}

.editor-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}

.editor-toolbar__title{
  display:grid;
  gap:4px;
}

.editor-toolbar__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.editor-card{
  background:linear-gradient(180deg,rgba(17,24,39,.96),rgba(18,27,49,.94));
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:24px;
  box-shadow:0 14px 38px rgba(0,0,0,.24);
}

.editor-card h3{
  margin-top:0;
  margin-bottom:16px;
}

.editor-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(180px,1fr));
  gap:16px;
}

.editor-grid--2{
  grid-template-columns:repeat(2,minmax(180px,1fr));
}

.editor-grid label{
  display:block;
  margin-bottom:8px;
  color:#c6d2ea;
  font-size:14px;
}

.editor-grid input,
.editor-grid select,
.editor-grid textarea,
.editor-card input,
.editor-card select,
.editor-card textarea{
  width:100%;
  padding:13px 14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:#0a1120;
  color:#fff;
}

.editor-card textarea{
  min-height:120px;
}

.template-presets{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.template-card{
  width:190px;
  border-radius:16px;
  padding:14px;
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.06);
  cursor:pointer;
  transition:.22s ease;
}

.template-card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 38px rgba(0,0,0,.28);
}

.template-card.active{
  border-color:rgba(255,80,100,.55);
  box-shadow:0 0 0 1px rgba(255,80,100,.18) inset, 0 18px 38px rgba(0,0,0,.28);
}

.builder-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}

.block-list{
  display:grid;
  gap:12px;
}

.block-item{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  border-radius:14px;
  padding:14px 16px;
  background:#10192d;
  border:1px solid rgba(255,255,255,.06);
}

.block-item__left{
  display:flex;
  align-items:center;
  gap:12px;
}

.block-handle{
  opacity:.65;
  font-size:18px;
  cursor:grab;
}

.block-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.block-actions button{
  min-width:42px;
  height:42px;
  border-radius:10px;
}

.templates-preview{
  position:sticky;
  top:18px;
  display:grid;
  gap:16px;
  padding:20px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(12,18,35,.98),rgba(11,17,32,.95));
  border:1px solid rgba(255,255,255,.06);
  box-shadow:0 18px 50px rgba(0,0,0,.28);
}

.preview-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.preview-toolbar__left,
.preview-toolbar__right{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}

.preview-zoom{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
}

.preview-stage{
  background:
    radial-gradient(circle at top, rgba(70,90,140,.32), transparent 42%),
    linear-gradient(180deg,#0d1528,#0a1020);
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:18px;
  overflow:auto;
  min-height:380px;
}

.preview-paper{
  background:#fff;
  border-radius:10px;
  box-shadow:0 35px 95px rgba(0,0,0,.46);
  padding:28px;
  width:100%;
  max-width:100%;
  transform-origin:top center;
}

.preview-email-shell{
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 20px 48px rgba(0,0,0,.30);
}

.designer-mini-toolbar{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}

.designer-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  color:#d8e2f6;
  font-size:13px;
}

@media (max-width:1400px){
  .templates-main{
    grid-template-columns:1fr;
  }
  .templates-preview{
    position:relative;
    top:auto;
  }
}

@media (max-width:980px){
  .editor-grid,
  .editor-grid--2,
  .builder-split{
    grid-template-columns:1fr;
  }
}

@media (max-width:700px){
  .templates-sidebar{
    justify-content:flex-start;
  }
  .templates-sidebar button{
    min-width:unset;
    flex:1 1 140px;
  }
}


/* ===== V14 AI DOCUMENT BUILDER ===== */

/* editor menu fixed */

.templates-sidebar{
position:sticky;
top:0;
z-index:60;
background:linear-gradient(180deg,#0c1326,#0a1120);
padding:16px;
border-bottom:1px solid rgba(255,255,255,.06);
}

/* canvas builder */

.ai-builder-canvas{
display:grid;
grid-template-columns:repeat(12,1fr);
gap:12px;
background:rgba(255,255,255,.02);
border:1px dashed rgba(255,255,255,.08);
border-radius:16px;
padding:24px;
min-height:460px;
position:relative;
}

/* snap grid */

.ai-builder-canvas::before{
content:'';
position:absolute;
inset:0;
background-image:
linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
background-size:40px 40px;
pointer-events:none;
}

/* builder blocks */

.ai-block{
background:#121b33;
border:1px solid rgba(255,255,255,.08);
border-radius:12px;
padding:14px;
cursor:move;
grid-column:span 4;
position:relative;
}

/* resize corner */

.ai-block::after{
content:'';
width:14px;
height:14px;
background:#ff2b4d;
position:absolute;
right:5px;
bottom:5px;
border-radius:3px;
cursor:nwse-resize;
}

/* component palette */

.ai-components{
display:flex;
gap:12px;
flex-wrap:wrap;
margin-bottom:18px;
}

.ai-component{
background:#111a30;
border:1px solid rgba(255,255,255,.08);
padding:10px 14px;
border-radius:10px;
cursor:pointer;
}

.ai-component:hover{
background:#162347;
}

/* multipage preview */

.preview-pages{
display:flex;
flex-direction:column;
gap:30px;
}

.preview-paper{
page-break-after:always;
}

/* toolbar */

.ai-builder-toolbar{
display:flex;
justify-content:space-between;
gap:10px;
margin-bottom:12px;
flex-wrap:wrap;
}



/* ===== V15 AI ERP DESIGNER ===== */
.ai-designer-shell{
  display:grid;
  grid-template-columns:minmax(760px,1fr) 440px;
  gap:24px;
  width:100%;
}
.ai-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:18px;
}
.ai-toolbar__left,.ai-toolbar__right{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}
.ai-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.06);
  color:#dbe7ff;
  font-size:13px;
}
.ai-layout-cards{
  display:grid;
  gap:20px;
}
.ai-config-card{
  background:linear-gradient(180deg,rgba(18,26,47,.97),rgba(15,22,39,.95));
  border:1px solid rgba(255,255,255,.06);
  border-radius:18px;
  padding:22px;
  box-shadow:0 16px 44px rgba(0,0,0,.25);
}
.ai-config-card h3{
  margin:0 0 14px;
}
.ai-builder-canvas{
  min-height:520px;
}
.ai-components{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.ai-component{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:10px;
  background:#111a30;
  border:1px solid rgba(255,255,255,.08);
}
.ai-component strong{
  font-size:13px;
}
.ai-block{
  box-shadow:0 10px 24px rgba(0,0,0,.22);
}
.ai-preview-panel{
  position:sticky;
  top:18px;
  display:grid;
  gap:16px;
  padding:20px;
  border-radius:18px;
  background:linear-gradient(180deg,rgba(12,18,35,.98),rgba(11,17,32,.95));
  border:1px solid rgba(255,255,255,.06);
}
.ai-page-stack{
  display:grid;
  gap:24px;
}
.ai-page-label{
  font-size:12px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#c9d6ef;
  margin-bottom:10px;
}
.ai-preview-paper{
  background:#fff;
  color:#111;
  border-radius:10px;
  box-shadow:0 40px 120px rgba(0,0,0,.55);
  padding:28px;
  min-height:760px;
}
.ai-style-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(140px,1fr));
  gap:14px;
}
.ai-style-grid input,
.ai-style-grid select,
.ai-style-grid textarea{
  width:100%;
  padding:12px 13px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.08);
  background:#0a1120;
  color:#fff;
}
.ai-style-grid label{
  display:block;
  margin-bottom:8px;
  color:#cad7f0;
  font-size:14px;
}
.ai-builder-footer{
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width:1450px){
  .ai-designer-shell{grid-template-columns:1fr}
  .ai-preview-panel{position:relative;top:auto}
}
@media (max-width:980px){
  .ai-style-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:700px){
  .ai-style-grid{grid-template-columns:1fr}
}
