/* ===== CSS VARIABLES ===== */
:root {
  --bg:    #f4f6fb;
  --bg2:   #ffffff;
  --bg3:   #edf0f7;
  --border: rgba(0,0,0,0.09);
  --text:  #111827;
  --text2: #6b7280;
  --accent: #e63757;
  --accent2:#7c3aed;
  --gold:  #f59e0b;
  --green: #10b981;
  --radius:16px;
  --shadow:0 2px 16px rgba(0,0,0,0.08);
  --font-head:'Syne',sans-serif;
  --font-body:'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:15px;line-height:1.6;overflow-x:hidden}
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}

/* ===== HEADER ===== */
#mainHeader{position:fixed;top:0;left:0;right:0;z-index:1000;background:rgba(255,255,255,0.93);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);height:64px;box-shadow:0 1px 12px rgba(0,0,0,0.06)}
.header-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-family:var(--font-head);font-size:22px;font-weight:800}
.logo-icon{font-size:24px;color:var(--accent)}
.desktop-nav{display:flex;gap:4px}
.nav-link{text-decoration:none;color:var(--text2);font-size:14px;font-weight:500;padding:8px 14px;border-radius:8px;transition:all .2s}
.nav-link:hover,.nav-link.active{color:var(--text);background:rgba(0,0,0,0.05)}
.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}

/* ===== MOBILE NAV ===== */
.mobile-nav-overlay{display:none;position:fixed;inset:0;z-index:1100;background:rgba(0,0,0,0.3);backdrop-filter:blur(4px)}
.mobile-nav{position:fixed;top:0;right:-280px;z-index:1200;width:260px;height:100vh;background:var(--bg2);border-left:1px solid var(--border);padding:80px 24px 40px;display:flex;flex-direction:column;gap:8px;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,0.1)}
.mobile-nav.open{right:0}
.mobile-nav-overlay.open{display:block}
.mobile-nav-close{position:absolute;top:20px;right:20px;background:none;border:none;color:var(--text2);font-size:20px;cursor:pointer}
.mob-link{display:block;text-decoration:none;color:var(--text);font-size:16px;font-weight:500;padding:12px 16px;border-radius:10px;transition:background .2s}
.mob-link:hover{background:rgba(0,0,0,0.04)}

/* ===== SECTIONS ===== */
.section{display:none;padding-top:64px;min-height:100vh}
.section.active{display:block}
.section-content{max-width:1200px;margin:0 auto;padding:60px 24px}
.section-heading{font-family:var(--font-head);font-size:clamp(28px,5vw,48px);font-weight:800;margin-bottom:12px;text-align:center}
.accent{color:var(--accent)}
.section-sub{text-align:center;color:var(--text2);margin-bottom:48px;font-size:16px}

/* ===== HERO ===== */
.hero{min-height:calc(100vh - 64px);display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;max-width:1200px;margin:0 auto;padding:80px 24px 60px;position:relative}
.hero-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.07}
.s1{width:600px;height:600px;background:var(--accent);top:-200px;right:-100px}
.s2{width:400px;height:400px;background:var(--accent2);bottom:0;left:-100px}
.s3{width:300px;height:300px;background:var(--gold);top:50%;left:40%}
.hero-content{grid-column:1;z-index:1}
.hero-badge{display:inline-block;background:rgba(230,55,87,0.08);border:1px solid rgba(230,55,87,0.25);color:var(--accent);font-size:13px;font-weight:600;padding:6px 16px;border-radius:100px;margin-bottom:24px}
.hero-title{font-family:var(--font-head);font-size:clamp(36px,6vw,68px);font-weight:800;line-height:1.1;margin-bottom:20px}
.hero-title em{font-style:normal;color:var(--accent)}
.hero-sub{color:var(--text2);font-size:17px;margin-bottom:36px;max-width:500px}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap}
.hero-cards-showcase{grid-column:2;z-index:1;display:flex;gap:16px;justify-content:center;align-items:flex-start;flex-wrap:wrap}
.showcase-card{width:120px;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;font-size:10px;box-shadow:0 20px 40px rgba(0,0,0,0.12);animation:float 3s ease-in-out infinite}
.showcase-card.sc2{margin-top:30px;animation-delay:.5s}
.showcase-card.sc3{margin-top:15px;animation-delay:1s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.sc-top{padding:10px 8px 8px;text-align:center}
.sc-logo-area{width:24px;height:24px;background:rgba(255,255,255,0.2);border-radius:50%;margin:0 auto 6px}
.sc-org{color:#fff;font-size:7px;font-weight:700;letter-spacing:.5px}
.sc-photo{width:36px;height:36px;background:#ddd;border-radius:50%;margin:10px auto 8px}
.sc-name{text-align:center;font-weight:600;color:var(--text);padding:0 8px;font-size:9px}
.sc-role{text-align:center;color:var(--text2);padding:2px 8px;font-size:8px}
.sc-bottom{background:var(--bg3);text-align:center;padding:6px;font-size:8px;color:var(--text2);margin-top:8px}

/* ===== BUTTONS ===== */
.btn-primary{background:var(--accent);color:#fff;border:none;padding:13px 28px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s;box-shadow:0 4px 20px rgba(230,55,87,0.3)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(230,55,87,0.4)}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border);padding:13px 28px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.btn-ghost:hover{border-color:rgba(0,0,0,0.2);background:rgba(0,0,0,0.03)}

/* ===== STATS BAR ===== */
.stats-bar{display:flex;justify-content:center;background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stat{display:flex;flex-direction:column;align-items:center;padding:28px 40px;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--accent)}
.stat-label{font-size:13px;color:var(--text2);margin-top:2px}

/* ===== CATEGORIES ===== */
.categories-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}
.cat-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:28px 20px;text-align:center;cursor:pointer;transition:all .25s;box-shadow:var(--shadow)}
.cat-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:0 12px 32px rgba(230,55,87,0.12)}
.cat-icon{font-size:32px;margin-bottom:12px}
.cat-name{font-family:var(--font-head);font-weight:700;font-size:15px;margin-bottom:4px}
.cat-count{font-size:12px;color:var(--text2)}

/* ===== FEATURED / HOME TEMPLATES ===== */
.home-templates-section{padding:60px 24px;max-width:1200px;margin:0 auto}
.home-templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px;margin-bottom:40px}
.view-more-wrap{text-align:center}
.btn-view-more{display:inline-flex;align-items:center;gap:8px;background:var(--bg2);color:var(--text);border:1.5px solid var(--border);padding:13px 32px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s;box-shadow:var(--shadow)}
.btn-view-more:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);box-shadow:0 8px 24px rgba(230,55,87,0.12)}
.btn-view-more .arrow{font-size:18px;transition:transform .2s}
.btn-view-more:hover .arrow{transform:translateX(4px)}

/* ===== GALLERY TEMPLATES ===== */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:36px;justify-content:center}
.filter-btn{background:var(--bg2);border:1px solid var(--border);color:var(--text2);padding:8px 18px;border-radius:100px;font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.filter-btn:hover,.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:20px}
.tpl-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .25s;box-shadow:var(--shadow)}
.tpl-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,0.13)}
.tpl-preview{height:190px;display:flex;align-items:center;justify-content:center;padding:16px;position:relative;overflow:hidden}
.tpl-preview.lsv{height:148px}
.tpl-info{padding:14px 16px;border-top:1px solid var(--border)}
.tpl-name{font-weight:600;font-size:14px;margin-bottom:6px;color:var(--text)}
.tpl-meta{display:flex;justify-content:space-between;align-items:center}
.tpl-orient{font-size:11px;font-weight:600;padding:3px 10px;border-radius:100px}
.tpl-orient.landscape{background:rgba(124,58,237,0.1);color:#7c3aed}
.tpl-orient.portrait{background:rgba(16,185,129,0.1);color:#059669}
.tpl-edit-btn{background:var(--accent);color:#fff;border:none;padding:6px 16px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.tpl-edit-btn:hover{background:#c92d49}

/* ===== EDITOR ===== */
.editor-layout{display:grid;grid-template-columns:340px 1fr;height:calc(100vh - 64px);overflow:hidden}
.editor-panel{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.panel-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.panel-header h3{font-family:var(--font-head);font-size:16px;font-weight:700}
.side-toggle{display:flex;background:var(--bg3);border-radius:8px;padding:3px}
.side-btn{background:none;border:none;color:var(--text2);padding:6px 16px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.side-btn.active{background:var(--accent);color:#fff}
.form-scroll{overflow-y:auto;flex:1;padding:16px 20px}
.form-section{margin-bottom:22px}
.form-section-title{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--text2);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.form-group{margin-bottom:12px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text2);margin-bottom:5px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg3);border:1px solid var(--border);color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px;font-family:var(--font-body);transition:border-color .2s;resize:vertical}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}
.color-row{display:flex;gap:8px;align-items:center}
.color-row input[type=color]{width:44px;height:36px;border:none;border-radius:6px;cursor:pointer;padding:2px;background:var(--bg3)}
.upload-area{background:var(--bg3);border:2px dashed var(--border);border-radius:10px;padding:14px;text-align:center;cursor:pointer;transition:all .2s;min-height:56px;display:flex;align-items:center;justify-content:center}
.upload-area.large{min-height:80px}
.upload-area:hover{border-color:var(--accent)}
.upload-placeholder{color:var(--text2);font-size:12px}
.upload-thumbnail{max-height:56px;max-width:100%;border-radius:6px}
.download-section{padding:14px 0 6px;display:flex;flex-direction:column;gap:10px;border-top:1px solid var(--border);margin-top:8px}
.btn-download{background:var(--green);color:#fff;border:none;padding:13px;width:100%;border-radius:10px;font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font-body);transition:all .2s;box-shadow:0 4px 20px rgba(16,185,129,0.3)}
.btn-download:hover{background:#059669;transform:translateY(-1px)}
.btn-reset{background:transparent;color:var(--text2);border:1px solid var(--border);padding:10px;width:100%;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--font-body);transition:all .2s}
.btn-reset:hover{border-color:rgba(0,0,0,0.2);color:var(--text)}

/* ===== PREVIEW PANEL ===== */
.preview-panel{display:flex;flex-direction:column;background:#dde1ee;overflow:hidden}
.preview-header{padding:14px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--bg2)}
.preview-header h3{font-family:var(--font-head);font-size:14px;font-weight:700;color:var(--text2)}
.zoom-controls{display:flex;gap:8px;align-items:center}
.zoom-controls button{width:28px;height:28px;background:var(--bg3);border:1px solid var(--border);color:var(--text);border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.zoom-controls button:hover{background:rgba(0,0,0,0.08)}
#zoomLabel{font-size:13px;color:var(--text2);min-width:40px;text-align:center}
.preview-canvas-wrap{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:40px}

/* ===== EDITOR CARD WRAPPER ===== */
#editorCardWrap{transform-origin:center center;transition:transform .2s}

/* ===========================
   FULL-SIZE EDITOR CARD DESIGNS
   Each .ec-X class renders at ~204×324px (portrait) or 324×204px (landscape)
   =========================== */

/* --- EC1: Classic Corporate --- */
.ec1{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.25);font-family:var(--font-body);display:flex;flex-direction:column}
.ec1 .ec-top{padding:16px 12px 10px;display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}
.ec1 .ec-logo-circle{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.ec1 .ec-logo-circle img{width:100%;height:100%;object-fit:contain}
.ec1 .ec-org{color:#fff;font-size:7.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;text-align:center}
.ec1 .ec-photo-wrap{display:flex;justify-content:center;padding:10px 0 6px;flex-shrink:0}
.ec1 .ec-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ec1 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec1 .ec-name{text-align:center;font-size:11px;font-weight:700;padding:0 10px;font-family:var(--font-head)}
.ec1 .ec-role{text-align:center;font-size:8px;padding:2px 10px 8px}
.ec1 .ec-info{padding:0 12px;flex:1}
.ec1 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,0.07);padding:4px 0;font-size:7.5px}
.ec1 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px}
.ec1 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec1 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec1 .ec-sig{display:flex;flex-direction:column;align-items:center}
.ec1 .ec-sig-line{font-size:12px;letter-spacing:2px}
.ec1 .ec-sig-lbl{font-size:5.5px;letter-spacing:.5px;margin-top:2px;opacity:.6}
.ec1 .ec-bc{width:54px;height:18px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.6) 0,rgba(255,255,255,.6) 1px,transparent 1px,transparent 3px)}
.ec1 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;opacity:.5;margin-top:2px}

/* --- EC2: Diagonal Slash --- */
.ec2{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.22);font-family:var(--font-body);background:#fff;position:relative;display:flex;flex-direction:column}
.ec2 .ec-slash{position:absolute;top:0;left:0;right:0;height:80px;z-index:0}
.ec2 .ec-content{position:relative;z-index:1;display:flex;flex-direction:column;flex:1}
.ec2 .ec-org-tag{font-size:7px;font-weight:700;color:#fff;text-align:right;padding:10px 14px 0;letter-spacing:.5px;text-transform:uppercase}
.ec2 .ec-photo-wrap{display:flex;justify-content:center;margin-top:14px;flex-shrink:0}
.ec2 .ec-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;border:3px solid #fff;box-shadow:0 4px 16px rgba(0,0,0,0.2);display:flex;align-items:center;justify-content:center}
.ec2 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec2 .ec-name{text-align:center;font-size:11px;font-weight:700;padding:8px 10px 2px;font-family:var(--font-head)}
.ec2 .ec-role{text-align:center;font-size:8px;font-weight:600;padding:0 10px 8px}
.ec2 .ec-info{padding:0 14px;flex:1}
.ec2 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,0.07);padding:4px 0;font-size:7.5px;color:#444}
.ec2 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:#bbb}
.ec2 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec2 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec2 .ec-sig-line{font-size:11px;letter-spacing:2px;opacity:.45}
.ec2 .ec-sig-lbl{font-size:5.5px;opacity:.5;letter-spacing:.5px;margin-top:2px}
.ec2 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.6) 0,rgba(255,255,255,.6) 1px,transparent 1px,transparent 3px)}
.ec2 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;opacity:.45;margin-top:2px}

/* --- EC3: Dark Glassmorphism --- */
.ec3{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.5);font-family:var(--font-body);display:flex;flex-direction:column}
.ec3 .ec-top-bar{padding:12px 14px 6px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec3 .ec-org{font-size:7px;font-weight:700;color:rgba(255,255,255,.75);letter-spacing:.5px;text-transform:uppercase}
.ec3 .ec-dot{width:9px;height:9px;border-radius:50%}
.ec3 .ec-photo-wrap{text-align:center;padding:6px 0 4px;flex-shrink:0}
.ec3 .ec-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid currentColor;margin:0 auto;display:flex;align-items:center;justify-content:center}
.ec3 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec3 .ec-name{text-align:center;font-size:11px;font-weight:700;color:#fff;padding:8px 10px 2px;font-family:var(--font-head)}
.ec3 .ec-role{text-align:center;font-size:8px;padding:0 10px 8px}
.ec3 .ec-divider{height:1px;margin:0 14px 8px}
.ec3 .ec-info{padding:0 14px;flex:1}
.ec3 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.07);padding:4px 0;font-size:7.5px}
.ec3 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;opacity:.45}
.ec3 .ec-val{font-weight:500;max-width:60%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;opacity:.85}
.ec3 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:rgba(0,0,0,.3)}
.ec3 .ec-sig-line{font-size:11px;letter-spacing:2px;opacity:.3;color:#fff}
.ec3 .ec-sig-lbl{font-size:5.5px;opacity:.3;margin-top:2px;color:#fff;letter-spacing:.5px}
.ec3 .ec-bc{width:54px;height:16px}
.ec3 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;opacity:.35;color:#fff;margin-top:2px}

/* --- EC4: Medical Side Strip --- */
.ec4{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.2);font-family:var(--font-body);display:flex;background:#fff}
.ec4 .ec-strip{width:18px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px}
.ec4 .ec-strip-icon{color:rgba(255,255,255,.7);font-size:12px;writing-mode:vertical-rl;letter-spacing:3px}
.ec4 .ec-main{flex:1;display:flex;flex-direction:column}
.ec4 .ec-head{padding:8px 10px 6px;flex-shrink:0}
.ec4 .ec-org{font-size:7px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.ec4 .ec-body{padding:8px 10px;flex:1;display:flex;flex-direction:column}
.ec4 .ec-photo{width:52px;height:52px;border-radius:50%;overflow:hidden;border:2px solid currentColor;margin-bottom:8px;display:flex;align-items:center;justify-content:center}
.ec4 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec4 .ec-name{font-size:10px;font-weight:700;margin-bottom:2px;font-family:var(--font-head)}
.ec4 .ec-role{font-size:7.5px;font-weight:600;margin-bottom:8px}
.ec4 .ec-info{flex:1}
.ec4 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.06);padding:3px 0;font-size:7px}
.ec4 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6px;color:#ccc}
.ec4 .ec-val{font-weight:500;max-width:60%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#444}
.ec4 .ec-foot{padding:6px 10px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec4 .ec-sig-line{font-size:10px;letter-spacing:2px;opacity:.45}
.ec4 .ec-sig-lbl{font-size:5px;opacity:.45;margin-top:2px;letter-spacing:.4px}
.ec4 .ec-bc{width:48px;height:14px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.55) 0,rgba(255,255,255,.55) 1px,transparent 1px,transparent 3px)}
.ec4 .ec-bc-num{font-size:5px;letter-spacing:.8px;text-align:center;opacity:.45;margin-top:1px}

/* --- EC5: University Crest --- */
.ec5{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.25);font-family:var(--font-body);display:flex;flex-direction:column}
.ec5 .ec-top{padding:12px 10px 8px;text-align:center;flex-shrink:0}
.ec5 .ec-crest{width:28px;height:28px;border-radius:50%;margin:0 auto 6px;display:flex;align-items:center;justify-content:center;font-size:14px;overflow:hidden}
.ec5 .ec-crest img{width:100%;height:100%;object-fit:contain}
.ec5 .ec-org{color:#fff;font-size:7px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.ec5 .ec-suborg{color:rgba(255,255,255,.55);font-size:5.5px;margin-top:2px}
.ec5 .ec-stripe{height:4px;flex-shrink:0}
.ec5 .ec-body{background:#fff;padding:8px 12px;flex:1;display:flex;flex-direction:column}
.ec5 .ec-photo{width:56px;height:56px;border-radius:6px;overflow:hidden;border:1.5px solid currentColor;margin:0 auto 8px;display:flex;align-items:center;justify-content:center}
.ec5 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec5 .ec-name{text-align:center;font-size:10.5px;font-weight:700;font-family:var(--font-head)}
.ec5 .ec-role{text-align:center;font-size:7.5px;color:#888;margin-bottom:8px}
.ec5 .ec-info{border-top:1px solid #eee;padding-top:6px;flex:1}
.ec5 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid #f5f5f5;padding:3.5px 0;font-size:7.5px;color:#555}
.ec5 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:#bbb}
.ec5 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec5 .ec-foot{padding:7px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec5 .ec-sig-line{font-size:11px;letter-spacing:2px;opacity:.4}
.ec5 .ec-sig-lbl{font-size:5px;opacity:.4;letter-spacing:.5px;margin-top:2px}
.ec5 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.6) 0,rgba(255,255,255,.6) 1px,transparent 1px,transparent 3px)}
.ec5 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;opacity:.45;margin-top:2px}

/* --- EC6: VIP Gold Luxury --- */
.ec6{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.6);font-family:var(--font-body);display:flex;flex-direction:column;background:#0d0d0d}
.ec6 .ec-top{padding:14px 12px 10px;text-align:center;border-bottom:1px solid rgba(212,175,55,0.25);flex-shrink:0}
.ec6 .ec-stars{color:#d4af37;font-size:11px;letter-spacing:3px;display:block;margin-bottom:4px}
.ec6 .ec-org{color:#d4af37;font-size:7px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase}
.ec6 .ec-logo-img{max-width:28px;max-height:28px;object-fit:contain;margin:0 auto 4px;display:block;display:none}
.ec6 .ec-photo-wrap{display:flex;justify-content:center;padding:12px 0 8px;flex-shrink:0}
.ec6 .ec-photo{width:72px;height:72px;border-radius:50%;overflow:hidden;border:2px solid #d4af37;box-shadow:0 0 14px rgba(212,175,55,0.4);display:flex;align-items:center;justify-content:center}
.ec6 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec6 .ec-name{text-align:center;font-size:11px;font-weight:700;color:#f5f5f5;padding:0 10px 2px;font-family:var(--font-head)}
.ec6 .ec-role{text-align:center;font-size:8px;font-weight:600;color:#d4af37;padding:0 10px 8px}
.ec6 .ec-info{padding:0 14px;flex:1;border-top:1px solid rgba(212,175,55,.18)}
.ec6 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05);padding:4px 0;font-size:7.5px}
.ec6 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:rgba(212,175,55,.55)}
.ec6 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgba(255,255,255,.7)}
.ec6 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:rgba(0,0,0,.4);border-top:1px solid rgba(212,175,55,.2)}
.ec6 .ec-sig-line{font-size:11px;letter-spacing:2px;color:rgba(212,175,55,.4)}
.ec6 .ec-sig-lbl{font-size:5.5px;color:rgba(212,175,55,.4);margin-top:2px;letter-spacing:.5px}
.ec6 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(212,175,55,.45) 0,rgba(212,175,55,.45) 1px,transparent 1px,transparent 3px)}
.ec6 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;color:rgba(212,175,55,.45);margin-top:2px}

/* --- EC7: Security / Military --- */
.ec7{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.5);font-family:var(--font-body);display:flex;flex-direction:column;background:#1c2310}
.ec7 .ec-top{padding:10px 12px;display:flex;align-items:center;gap:8px;border-bottom:2px solid #a5b87a;flex-shrink:0}
.ec7 .ec-shield{font-size:18px}
.ec7 .ec-org{font-size:7px;font-weight:700;color:#a5b87a;letter-spacing:.5px;text-transform:uppercase;line-height:1.4}
.ec7 .ec-photo-wrap{display:flex;justify-content:center;padding:10px 0 6px;flex-shrink:0}
.ec7 .ec-photo{width:64px;height:64px;border-radius:4px;overflow:hidden;border:2px solid #a5b87a;display:flex;align-items:center;justify-content:center}
.ec7 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec7 .ec-name{text-align:center;font-size:11px;font-weight:700;color:#e8e8d0;padding:0 10px 2px;font-family:var(--font-head)}
.ec7 .ec-role{text-align:center;font-size:8px;font-weight:600;color:#a5b87a;padding:0 10px 8px}
.ec7 .ec-info{padding:0 12px;flex:1;border-top:1px solid rgba(165,184,122,.2)}
.ec7 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.05);padding:4px 0;font-size:7.5px}
.ec7 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:rgba(165,184,122,.5)}
.ec7 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgba(255,255,255,.65)}
.ec7 .ec-foot{padding:7px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:#2d3a1e}
.ec7 .ec-sig-line{font-size:11px;letter-spacing:2px;color:rgba(165,184,122,.4)}
.ec7 .ec-sig-lbl{font-size:5.5px;color:rgba(165,184,122,.4);margin-top:2px;letter-spacing:.5px}
.ec7 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(165,184,122,.5) 0,rgba(165,184,122,.5) 1px,transparent 1px,transparent 3px)}
.ec7 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;color:rgba(165,184,122,.45);margin-top:2px}

/* --- EC8: Tech Purple Gradient --- */
.ec8{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(124,58,237,0.4);font-family:var(--font-body);display:flex;flex-direction:column;background:#0f0a1e}
.ec8 .ec-top{padding:14px 12px 10px;text-align:center;flex-shrink:0}
.ec8 .ec-hex{font-size:18px;display:block;margin-bottom:4px}
.ec8 .ec-org{color:rgba(255,255,255,.88);font-size:7px;font-weight:700;letter-spacing:.8px;text-transform:uppercase}
.ec8 .ec-photo-wrap{display:flex;justify-content:center;padding:10px 0 6px;flex-shrink:0}
.ec8 .ec-photo{width:68px;height:68px;border-radius:10px;overflow:hidden;border:2px solid #a855f7;display:flex;align-items:center;justify-content:center}
.ec8 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec8 .ec-name{text-align:center;font-size:11px;font-weight:700;color:#fff;padding:0 10px 2px;font-family:var(--font-head)}
.ec8 .ec-role{text-align:center;font-size:8px;color:#c084fc;font-weight:600;padding:0 10px 8px}
.ec8 .ec-info{padding:0 12px;flex:1;border-top:1px solid rgba(168,85,247,.2)}
.ec8 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.06);padding:4px 0;font-size:7.5px}
.ec8 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:rgba(192,132,252,.5)}
.ec8 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:rgba(255,255,255,.75)}
.ec8 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec8 .ec-sig-line{font-size:11px;letter-spacing:2px;color:rgba(255,255,255,.35)}
.ec8 .ec-sig-lbl{font-size:5.5px;color:rgba(255,255,255,.3);margin-top:2px;letter-spacing:.5px}
.ec8 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.4) 0,rgba(255,255,255,.4) 1px,transparent 1px,transparent 3px)}
.ec8 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;color:rgba(255,255,255,.35);margin-top:2px}

/* --- EC9: Green Nature / NGO --- */
.ec9{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.2);font-family:var(--font-body);display:flex;flex-direction:column;background:#f0fff8}
.ec9 .ec-top{padding:14px 12px 10px;text-align:center;flex-shrink:0}
.ec9 .ec-leaf{font-size:18px;display:block;margin-bottom:4px}
.ec9 .ec-org{font-size:7px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.ec9 .ec-photo-wrap{display:flex;justify-content:center;padding:10px 0 6px;flex-shrink:0}
.ec9 .ec-photo{width:68px;height:68px;border-radius:50%;overflow:hidden;border:2.5px solid #10b981;display:flex;align-items:center;justify-content:center}
.ec9 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec9 .ec-name{text-align:center;font-size:11px;font-weight:700;padding:0 10px 2px;font-family:var(--font-head)}
.ec9 .ec-role{text-align:center;font-size:8px;font-weight:600;padding:0 10px 8px}
.ec9 .ec-info{padding:0 12px;flex:1;border-top:1px solid #d1fae5}
.ec9 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid #ecfdf5;padding:4px 0;font-size:7.5px}
.ec9 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:#6ee7b7}
.ec9 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec9 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec9 .ec-sig-line{font-size:11px;letter-spacing:2px}
.ec9 .ec-sig-lbl{font-size:5.5px;margin-top:2px;letter-spacing:.5px;opacity:.5}
.ec9 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.6) 0,rgba(255,255,255,.6) 1px,transparent 1px,transparent 3px)}
.ec9 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;margin-top:2px;opacity:.45}

/* --- EC10: Minimalist Flat --- */
.ec10{width:204px;height:324px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.18);font-family:var(--font-body);display:flex;flex-direction:column;background:#fff}
.ec10 .ec-accent-bar{height:5px;flex-shrink:0}
.ec10 .ec-top{padding:10px 12px 8px;display:flex;justify-content:space-between;align-items:flex-start;flex-shrink:0}
.ec10 .ec-org-col .ec-org{font-size:7.5px;font-weight:700;color:#111;text-transform:uppercase;letter-spacing:.5px}
.ec10 .ec-org-col .ec-sub{font-size:5.5px;color:#aaa}
.ec10 .ec-id-badge{border-radius:5px;padding:3px 7px;font-size:7px;font-weight:700}
.ec10 .ec-divider{height:1px;background:#f0f0f0;margin:0 12px 8px;flex-shrink:0}
.ec10 .ec-body{padding:4px 12px 8px;display:flex;gap:10px;align-items:flex-start;flex-shrink:0}
.ec10 .ec-photo{width:52px;height:62px;border-radius:6px;overflow:hidden;border:1.5px solid currentColor;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.ec10 .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec10 .ec-info-col .ec-name{font-size:9px;font-weight:700;color:#111;margin-bottom:2px;font-family:var(--font-head)}
.ec10 .ec-info-col .ec-role{font-size:7px;font-weight:600;margin-bottom:6px}
.ec10 .ec-info-col .ec-detail{font-size:6.5px;color:#777;padding:2px 0;border-bottom:1px solid #f5f5f5}
.ec10 .ec-info-area{padding:0 12px;flex:1}
.ec10 .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid #f5f5f5;padding:4px 0;font-size:7.5px;color:#555}
.ec10 .ec-lbl{font-weight:600;text-transform:uppercase;font-size:6.5px;color:#ccc}
.ec10 .ec-val{font-weight:500;max-width:58%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec10 .ec-foot{padding:8px 12px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:#111}
.ec10 .ec-sig-line{font-size:11px;letter-spacing:2px;color:rgba(255,255,255,.4)}
.ec10 .ec-sig-lbl{font-size:5.5px;color:rgba(255,255,255,.35);margin-top:2px;letter-spacing:.5px}
.ec10 .ec-bc{width:54px;height:16px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.55) 0,rgba(255,255,255,.55) 1px,transparent 1px,transparent 3px)}
.ec10 .ec-bc-num{font-size:5.5px;letter-spacing:1px;text-align:center;color:rgba(255,255,255,.4);margin-top:2px}

/* --- EC-LS: Landscape (two-column) --- */
.ec-ls{width:324px;height:204px;border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,0.25);font-family:var(--font-body);display:flex;flex-direction:row}
.ec-ls .ec-left{width:110px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:14px 8px}
.ec-ls .ec-left .ec-logo{max-width:28px;max-height:28px;object-fit:contain;border-radius:3px}
.ec-ls .ec-left .ec-photo{width:64px;height:64px;border-radius:50%;overflow:hidden;border:2.5px solid;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ec-ls .ec-left .ec-photo img{width:100%;height:100%;object-fit:cover}
.ec-ls .ec-left .ec-org{font-size:6px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;text-align:center;line-height:1.4;color:#fff;word-break:break-word}
.ec-ls .ec-right{flex:1;display:flex;flex-direction:column;min-width:0;background:#fff}
.ec-ls .ec-right .ec-name{font-family:var(--font-head);font-size:12px;font-weight:800;padding:16px 14px 2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#111}
.ec-ls .ec-right .ec-role{font-size:8.5px;padding:0 14px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#666}
.ec-ls .ec-right .ec-divider{height:2px;margin:0 14px 7px;border-radius:2px;flex-shrink:0}
.ec-ls .ec-right .ec-info{padding:0 14px;flex:1;overflow:hidden}
.ec-ls .ec-right .ec-row{display:flex;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.06);padding:3.5px 0;font-size:7.5px}
.ec-ls .ec-right .ec-lbl{color:#aaa;font-weight:700;text-transform:uppercase;font-size:6.5px;flex-shrink:0}
.ec-ls .ec-right .ec-val{color:#222;font-weight:500;max-width:60%;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ec-ls .ec-right .ec-foot{padding:8px 14px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.ec-ls .ec-right .ec-sig-line{font-size:10px;letter-spacing:2px;opacity:.4}
.ec-ls .ec-right .ec-sig-lbl{font-size:5px;opacity:.4;margin-top:2px;letter-spacing:.5px}
.ec-ls .ec-right .ec-bc{width:48px;height:14px;background:repeating-linear-gradient(90deg,rgba(255,255,255,.55) 0,rgba(255,255,255,.55) 1px,transparent 1px,transparent 3px)}
.ec-ls .ec-right .ec-bc-num{font-size:5px;letter-spacing:.8px;text-align:right;opacity:.45;margin-top:1px}

/* dark right panel variant */
.ec-ls.dark-right .ec-right{background:rgba(255,255,255,.06)}
.ec-ls.dark-right .ec-right .ec-name{color:#f0f0f5}
.ec-ls.dark-right .ec-right .ec-role{color:#9090a8}
.ec-ls.dark-right .ec-right .ec-val{color:rgba(255,255,255,.8)}
.ec-ls.dark-right .ec-right .ec-lbl{color:rgba(255,255,255,.3)}
.ec-ls.dark-right .ec-right .ec-row{border-color:rgba(255,255,255,.08)}

/* ===== HOW IT WORKS ===== */
.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:60px}
.step-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:32px 28px;position:relative;transition:all .25s;box-shadow:var(--shadow)}
.step-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,0,0,0.1)}
.step-num{font-family:var(--font-head);font-size:56px;font-weight:800;color:rgba(0,0,0,0.04);position:absolute;top:16px;right:20px;line-height:1}
.step-icon{font-size:36px;margin-bottom:16px}
.step-card h3{font-family:var(--font-head);font-size:20px;font-weight:700;margin-bottom:10px}
.step-card p{color:var(--text2);font-size:14px;line-height:1.7}
.features-list{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.features-list h3{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:20px}
.feat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.feat-item{font-size:14px;color:var(--text2)}

/* ===== CONTACT ===== */
.contact-grid{display:grid;grid-template-columns:1fr 2fr;gap:40px}
.contact-item{display:flex;gap:16px;align-items:flex-start;margin-bottom:24px}
.ci-icon{font-size:24px}
.contact-item strong{display:block;margin-bottom:4px}
.contact-item p{color:var(--text2);font-size:14px}
.contact-form{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}

/* ===== FOOTER ===== */
.footer{background:var(--bg2);border-top:1px solid var(--border);padding:40px 24px;text-align:center}
.footer-logo{font-family:var(--font-head);font-size:24px;font-weight:800;color:var(--accent);margin-bottom:12px}
.footer p{color:var(--text2);font-size:14px}

/* ===== TOAST ===== */
.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--bg2);border:1px solid var(--border);color:var(--text);padding:12px 24px;border-radius:100px;font-size:14px;font-weight:600;z-index:9999;transition:transform .3s;pointer-events:none;box-shadow:0 8px 30px rgba(0,0,0,0.15)}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.success{border-color:var(--green);color:var(--green)}
.toast.error{border-color:var(--accent);color:var(--accent)}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .desktop-nav{display:none}
  .hamburger{display:flex}
  .hero{grid-template-columns:1fr;gap:40px}
  .hero-cards-showcase{grid-column:1;order:-1}
  .editor-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:auto}
  .editor-panel{max-height:500px}
  .preview-canvas-wrap{min-height:500px}
  .contact-grid{grid-template-columns:1fr}
  .stats-bar{flex-wrap:wrap}
  .stat{padding:20px;flex:1 1 50%}
  .home-templates-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
}
@media(max-width:600px){
  .hero{padding:60px 16px 40px}
  .hero-cards-showcase{gap:10px}
  .showcase-card{width:95px}
  .templates-grid{grid-template-columns:repeat(2,1fr)}
  .tpl-preview{height:150px}
  .stats-bar{flex-direction:row}
  .stat{flex:1 1 50%}
  .home-templates-grid{grid-template-columns:repeat(2,1fr)}
  .home-templates-section{padding:40px 16px}
}