:root {
  --bg:#080c12; --surface:#0e1420; --surface2:#141c2e;
  --accent:#00c8e0; --accent2:#7c3aed; --accent3:#f59e0b;
  --text:#e2e8f0; --muted:#64748b; --border:rgba(0,200,224,0.15);
  --card-bg:rgba(14,20,32,.75); --hero-bg:#080c12;
  --sk-fill:#00c8e0; --toggle-bg:rgba(14,20,32,.85);
}
body.light {
  --bg:#f5f7fa; --surface:#ffffff; --surface2:#edf0f5;
  --accent:#0069a8; --accent2:#5b21b6; --accent3:#b45309;
  --text:#111827; --muted:#4b5563; --border:rgba(0,105,168,0.2);
  --card-bg:rgba(255,255,255,.88); --hero-bg:#e8edf5;
  --sk-fill:#0069a8; --toggle-bg:rgba(255,255,255,.92);
}

/* ── Light mode targeted overrides ── */
body.light { background:var(--bg); color:var(--text); }

/* Hero */
body.light .hero-bg-wrap { background:var(--hero-bg); }
body.light .hero-bg-wrap::before { background:radial-gradient(ellipse at 70% 50%,rgba(91,33,182,.05),transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(0,105,168,.04),transparent 50%); }
body.light .hero-name    { color:#111827; }
body.light .hero-name span{ color:var(--accent); text-shadow:0 0 24px rgba(0,105,168,.2); }
body.light .badge        { background:rgba(0,105,168,.07); border-color:rgba(0,105,168,.25); }
body.light .hero-desc strong { color:#111827; }

/* Cursor */
body.light #cur           { background:var(--accent); mix-blend-mode:multiply; }
body.light #cur-ring      { border-color:rgba(0,105,168,.5); }

/* Avatar */
body.light .avatar-ring  { border-color:rgba(0,105,168,.45); }
body.light .avatar-ring2 { border-color:rgba(0,105,168,.15); }
body.light .avatar-dot   { background:var(--accent); border-color:var(--bg); }

/* Discipline buttons */
body.light .disc-btn               { background:rgba(255,255,255,.9); border-color:rgba(0,105,168,.18); }
body.light .disc-btn .dn           { color:#111827; }
body.light .disc-btn .ds           { color:#4b5563; }
body.light .disc-btn:hover,
body.light .disc-btn.active        { background:rgba(0,105,168,.08); border-color:rgba(0,105,168,.4); box-shadow:0 0 20px rgba(0,105,168,.1); }

/* Panel */
body.light .panel-bg  { background:rgba(200,210,225,.92); }
body.light .panel-box { background:#ffffff; }
body.light .panel-close { color:#4b5563; border-color:rgba(0,105,168,.2); }
body.light .panel-close:hover { color:var(--accent); border-color:var(--accent); }
body.light .p-desc        { color:#374151; }
body.light .p-desc strong { color:#111827; }
body.light .pstep         { background:#f0f4f8; }
body.light .pstep::after  { background:#f0f4f8; }
body.light .ps-d          { color:#4b5563; }
body.light .pcard         { background:#f5f7fa; }
body.light .pc-desc       { color:#4b5563; }
body.light .pill          { color:#4b5563; border-color:rgba(0,105,168,.2); }
body.light .pill.hi       { color:var(--accent); border-color:rgba(0,105,168,.4); background:rgba(0,105,168,.07); }

/* Experience */
body.light .exp-sec       { background:#edf1f8; }
body.light .tl-co         { color:#4b5563; }
body.light .tl-role       { color:#111827; }
body.light .tl-pts li     { color:#374151; }
body.light .tl-date::after{ background:#ffffff; }

/* Skills */
body.light .sk-sec  { background:#f5f7fa; }
body.light .sk-cell { background:#ffffff; border-color:rgba(0,105,168,.15); }
body.light .sk-cell:hover { background:#edf1f8; border-color:rgba(0,105,168,.3); }
body.light .sk-lbl  { color:#4b5563; }
body.light .sk-name { color:#111827; }
body.light .sk-fill { background:var(--accent); box-shadow:0 0 6px rgba(0,105,168,.35); }
body.light .sk-bg   { background:rgba(0,105,168,.12); }

/* Footer */
body.light footer    { border-top-color:rgba(0,105,168,.15); background:#edf1f8; }
body.light .ft-name  { color:#111827; }
body.light .ft-links a { color:#4b5563; }
body.light .ft-links a:hover { color:var(--accent); }
body.light .ft-copy  { color:#4b5563; }

/* AI Balloon */
body.light .av-balloon      { background:rgba(255,255,255,.98); border-color:rgba(0,105,168,.35); color:#111827; }
body.light .av-balloon::before { border-top-color:rgba(255,255,255,.98); }
body.light .av-balloon::after  { border-top-color:rgba(0,105,168,.35); }
body.light .av-balloon-tag  { color:var(--accent); }
body.light .av-balloon-text { color:#1f2937; }
body.light .av-chat-input   { background:rgba(0,105,168,.05); border-color:rgba(0,105,168,.25); color:#111827; }
body.light .av-chat-btn     { background:var(--accent); color:#fff; }

/* Scrollbar */
body.light ::-webkit-scrollbar-thumb { background:var(--accent); }

/* Parallax icons — slightly darker in light mode */
body.light .px-icon { filter:brightness(0.55) saturate(1.2); }

/* Section headers */
body.light .sec-num  { color:var(--accent); }
body.light .sec-h2   { color:#111827; }

/* Timeline dots */
body.light .tl-date  { color:var(--accent); border-color:rgba(0,105,168,.25); }

/* Toggle button */
#theme-toggle{
  position:fixed;top:18px;right:22px;z-index:10000;
  width:52px;height:28px;border-radius:14px;
  border:1.5px solid var(--border);
  background:var(--toggle-bg);
  cursor:pointer;
  backdrop-filter:blur(10px);
  transition:background .35s,border-color .35s;
  display:flex;align-items:center;padding:3px;
}
#theme-toggle-knob{
  width:20px;height:20px;border-radius:50%;
  background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;line-height:1;
  transition:transform .35s cubic-bezier(.4,0,.2,1),background .35s;
  transform:translateX(0);
  box-shadow:0 1px 6px rgba(0,0,0,.25);
}
body.light #theme-toggle-knob { transform:translateX(24px); background:var(--accent); }
body.light #theme-toggle { border-color:rgba(0,105,168,.3); }

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--text);font-family:'Space Mono',monospace;overflow:hidden;cursor:none;}

#cur{position:fixed;width:10px;height:10px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%) scale(1);mix-blend-mode:screen;opacity:0;transition:transform .2s,opacity .3s;left:-50px;top:-50px;}
#cur-ring{position:fixed;width:36px;height:36px;border:1.5px solid rgba(0,229,255,.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:0;transition:width .25s,height .25s,border-color .25s,opacity .3s;left:-50px;top:-50px;}

/* ── CONTENT MAX-WIDTH WRAPPER ──
   .wrap centres content to 1300px max.
   Sections stay width:100% so backgrounds always fill the screen.
   The parallax layer, hero gradient and section backgrounds are
   unaffected — only text/content is constrained.                 */
.wrap{width:100%;max-width:1300px;margin-left:auto;margin-right:auto;padding-left:80px;padding-right:80px;box-sizing:border-box;}
.exp-sec .wrap,.sk-sec .wrap{padding-top:80px;padding-bottom:80px;}
.contact-sec.open .wrap{padding-top:80px;padding-bottom:80px;}
@media(max-width:1100px){.wrap{padding-left:48px;padding-right:48px;}}
@media(max-width:700px){.wrap{padding-left:24px;padding-right:24px;}}

/* Hero: full-bleed wrapper holds bg, inner section is max-width constrained */
.hero-bg-wrap{width:100%;background:var(--bg);position:relative;isolation:auto;}
.hero-bg-wrap::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(124,58,237,.08),transparent 60%),radial-gradient(ellipse at 20% 80%,rgba(0,229,255,.06),transparent 50%);pointer-events:none;z-index:0;}
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden;max-width:1300px;margin-left:auto;margin-right:auto;width:100%;}

.hero-left{padding:80px 60px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:2;}
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);padding:6px 14px;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);width:fit-content;margin-bottom:40px;background:rgba(0,229,255,.04);}
.badge::before{content:'';width:6px;height:6px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:.4;transform:scale(1.5);}}
.hero-name{font-family:'Montserrat',sans-serif;font-size:clamp(48px,7vw,88px);font-weight:800;line-height:.9;letter-spacing:-.03em;color:#fff;margin-bottom:8px;}
.hero-name span{display:block;color:var(--accent);text-shadow:0 0 40px rgba(0,229,255,.4);}
.hero-title{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:20px;margin-bottom:32px;}
.hero-desc{font-size:13px;line-height:1.8;color:var(--muted);max-width:480px;margin-bottom:48px;}
.hero-desc strong{color:var(--text);}
.stats{display:flex;gap:40px;margin-bottom:48px;}
.stat{display:flex;flex-direction:column;gap:4px;}
.stat-n{font-family:'Montserrat',sans-serif;font-size:36px;font-weight:800;color:var(--accent);line-height:1;}
.stat-l{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.contacts{display:flex;flex-direction:column;gap:8px;}
.ci{font-size:11px;color:var(--muted);}
.ci a{color:var(--accent);text-decoration:none;}

/* ── AVATAR ── */
.avatar-wrap{position:relative;width:120px;height:120px;flex-shrink:0;margin-bottom:28px;cursor:pointer;}
.avatar-ring{position:absolute;inset:-5px;border-radius:50%;border:1.5px solid rgba(0,229,255,.55);animation:avspin 8s linear infinite;transition:border-color .3s,box-shadow .3s;}
.avatar-ring2{position:absolute;inset:-12px;border-radius:50%;border:1px dashed rgba(0,229,255,.18);animation:avspin 14s linear infinite reverse;transition:border-color .3s;}
.avatar-wrap:hover .avatar-ring{border-color:rgba(0,229,255,1);box-shadow:0 0 18px rgba(0,200,224,.55);}
.avatar-wrap:hover .avatar-ring2{border-color:rgba(0,229,255,.45);}
@keyframes avspin{to{transform:rotate(360deg);}}
#face-cv{width:120px;height:120px;border-radius:50%;display:block;}
.avatar-dot{position:absolute;bottom:5px;right:5px;width:11px;height:11px;background:#00e5ff;border-radius:50%;border:2px solid var(--bg);animation:pulse 2s infinite;}
/* ── PARALLAX LAYER ── */
#parallax-layer{position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden;}
.px-icon{position:absolute;font-size:18px;opacity:0;animation:pxFloat linear infinite;}
@keyframes pxFloat{
  0%  {transform:translateY(0) rotate(0deg) scale(1);   opacity:0;}
  8%  {opacity:0.18;}
  92% {opacity:0.12;}
  100%{transform:translateY(-105vh) rotate(360deg) scale(0.6); opacity:0;}
}
/* Fade-in on scroll for timeline items */
.tl-date,.tl-body{opacity:0;transform:translateY(22px);transition:opacity .6s ease,transform .6s ease;}
.tl-date.visible,.tl-body.visible{opacity:1;transform:translateY(0);}
/* Skill cell pop-in */
.sk-cell{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease,background .3s,border-color .3s,border-color .3s;}
.sk-cell.visible{opacity:1;transform:translateY(0);}

/* ── AVATAR CHATBOT BALLOON ── */
.avatar-wrap{position:relative;}
.av-balloon-wrap{position:absolute;bottom:135px;left:calc(50% + 18px);transform:translateX(-50%);z-index:20;width:230px;pointer-events:none;}


.av-balloon{background:rgba(6,14,26,.97);border:1px solid rgba(0,229,255,.45);padding:11px 13px 10px;font-size:11px;line-height:1.55;color:var(--text);position:relative;border-radius:4px 4px 4px 0;box-shadow:0 0 22px rgba(0,229,255,.15),0 4px 20px rgba(0,0,0,.5);opacity:0;transform:translateY(-6px) scale(.97);transition:opacity .3s,transform .3s;}
.av-balloon.show{opacity:1;transform:translateY(0) scale(1);}
/* tail pointing down toward avatar head */
.av-balloon::after{content:'';position:absolute;bottom:-8px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid rgba(0,229,255,.45);}
.av-balloon::before{content:'';position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:7px solid rgba(6,14,26,.97);z-index:1;}
.av-balloon::after,
.av-balloon::before{
  left:60%;
  transform:translateX(-50%);
}
.av-balloon-tag{font-size:9px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:5px;display:flex;align-items:center;gap:5px;}
.av-balloon-tag::before{content:'';width:5px;height:5px;background:var(--accent);border-radius:50%;animation:pulse 2s infinite;flex-shrink:0;}
.av-balloon-text{color:rgba(200,220,240,.9);}
.av-balloon-text strong{color:#fff;}
.av-chat-input-row{display:flex;gap:5px;margin-top:8px;pointer-events:all;}
.av-chat-input{flex:1;background:rgba(0,229,255,.05);border:1px solid rgba(0,229,255,.2);color:var(--text);font-family:'Space Mono',monospace;font-size:10px;padding:5px 7px;outline:none;min-width:0;border-radius:2px;}
.av-chat-input::placeholder{color:var(--muted);}
.av-chat-btn{background:var(--accent);border:none;color:#000;font-family:'Space Mono',monospace;font-size:9px;font-weight:700;padding:5px 8px;cursor:none;letter-spacing:.06em;white-space:nowrap;border-radius:2px;}
.av-chat-btn:hover{background:#fff;}
.av-typing{display:inline-flex;gap:3px;align-items:center;height:14px;}
.av-typing span{width:4px;height:4px;background:var(--accent);border-radius:50%;animation:avdot 1.1s infinite;}
.av-typing span:nth-child(2){animation-delay:.2s;}
.av-typing span:nth-child(3){animation-delay:.4s;}

@media(max-width:900px){

  /* ===============================
     BUBBLE POSITION (RIGHT SIDE)
  =============================== */
  .avatar-wrap{
    position:relative;   /* anchor */
  }

  .av-balloon-wrap {
    position: absolute;
    top: -26%;
    left: 100%;
    transform: translate(0%, 50%);
    margin-left: 26px;
    width: 190px;
  }

  /* ===============================
     BUBBLE BOX
  =============================== */
 .av-balloon{
    overflow:visible;
  }

  .av-balloon::after{
    content:'';
    position:absolute;

    left:0;
    top:50%;

    transform:translate(-100%, -50%); /* 👈 THIS is the real positioning */

    border-top:8px solid transparent;
    border-bottom:8px solid transparent;
    border-right:8px solid rgba(0,229,255,.45);
  }

  .av-balloon::before{
    content:'';
    position:absolute;

    left:0;
    top:50%;

    transform:translate(-85%, -50%); /* inner fill slightly inside */

    border-top:7px solid transparent;
    border-bottom:7px solid transparent;
    border-right:7px solid rgba(6,14,26,.97);
  }

}

.avatar-wrap{
  position:relative;
}
@keyframes avdot{0%,80%,100%{transform:scale(.5);opacity:.4;}40%{transform:scale(1);opacity:1;}}

.hero-right{position:relative;display:flex;align-items:center;justify-content:center;padding:40px;}
#bg-cv{position:absolute;inset:0;width:100%;height:100%;}
.disc-list{position:relative;z-index:10;display:flex;flex-direction:column;gap:10px;width:100%;max-width:420px;}
.disc-btn{background:rgba(14,20,32,.75);border:1px solid var(--border);padding:16px 22px;cursor:none;transition:all .3s;text-align:left;display:flex;align-items:center;gap:14px;backdrop-filter:blur(10px);position:relative;overflow:hidden;}
.disc-btn::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--accent);transform:scaleY(0);transition:transform .3s;transform-origin:bottom;}
.disc-btn:hover::before,.disc-btn.active::before{transform:scaleY(1);}
.disc-btn:hover,.disc-btn.active{border-color:rgba(0,229,255,.4);background:rgba(0,229,255,.06);box-shadow:0 0 28px rgba(0,229,255,.1);}
.di{font-size:20px;width:36px;text-align:center;flex-shrink:0;line-height:1;display:flex;align-items:center;justify-content:center;}
.dn{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;color:#fff;margin-bottom:2px;}
.ds{font-size:10px;color:var(--muted);letter-spacing:.06em;}
.da{color:var(--accent);font-size:11px;margin-left:auto;opacity:0;transition:opacity .3s,transform .3s;transform:translateX(-6px);}
.disc-btn:hover .da,.disc-btn.active .da{opacity:1;transform:translateX(0);}

.panel{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s;}
.panel.open{opacity:1;pointer-events:all;}
.panel-bg{position:absolute;inset:0;background:rgba(6,10,16,.93);backdrop-filter:blur(14px);}
.panel-box{position:relative;z-index:2;width:min(860px,92vw);max-height:88vh;overflow-y:auto;background:var(--surface);border:1px solid var(--border);padding:52px;transform:translateY(28px);transition:transform .35s ease;scrollbar-width:thin;scrollbar-color:var(--accent) transparent;}
.panel.open .panel-box{transform:translateY(0);}
.panel-close{position:absolute;top:22px;right:22px;background:none;border:1px solid var(--border);color:var(--muted);font-family:'Space Mono',monospace;font-size:10px;padding:7px 13px;cursor:none;transition:all .2s;letter-spacing:.1em;}
.panel-close:hover{color:var(--accent);border-color:var(--accent);}
.p-tag{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:14px;}
.p-title{font-family:'Montserrat',sans-serif;font-size:40px;font-weight:800;color:#fff;margin-bottom:6px;line-height:1;}
.p-sub{font-size:11px;color:var(--muted);margin-bottom:36px;letter-spacing:.04em;}
.p-canvas{width:100%;height:260px;border:1px solid var(--border);margin-bottom:36px;overflow:hidden;}
.p-canvas canvas{display:block;width:100%;height:100%;}
.sec-title{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:18px;padding-bottom:9px;border-bottom:1px solid var(--border);}
.p-desc{font-size:13px;line-height:1.9;color:var(--muted);margin-bottom:32px;}
.p-desc strong{color:var(--text);}
.proc{display:flex;gap:0;margin-bottom:32px;overflow-x:auto;padding-bottom:6px;}
.pstep{flex:1;min-width:110px;padding:18px 14px;background:var(--surface2);border:1px solid var(--border);border-right:none;position:relative;}
.pstep:last-child{border-right:1px solid var(--border);}
.pstep:hover{background:rgba(0,229,255,.04);}
.pstep::after{content:'→';position:absolute;right:-11px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:11px;z-index:2;background:var(--surface2);padding:1px 2px;}
.pstep:last-child::after{display:none;}
.ps-n{font-size:9px;letter-spacing:.15em;color:var(--accent);text-transform:uppercase;margin-bottom:6px;}
.ps-name{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;color:#fff;margin-bottom:5px;}
.ps-d{font-size:10px;color:var(--muted);line-height:1.55;}
.pills{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:32px;}
.pill{font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border:1px solid var(--border);color:var(--muted);}
.pill.hi{border-color:rgba(0,229,255,.4);color:var(--accent);background:rgba(0,229,255,.06);}
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.pcard{background:var(--surface2);border:1px solid var(--border);padding:18px;}
.pc-lbl{font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent3);margin-bottom:7px;}
.pc-name{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;color:#fff;margin-bottom:5px;}
.pc-desc{font-size:11px;color:var(--muted);line-height:1.55;}

/* ── PRINT BUTTON ── */
#print-btn{
  position:fixed;bottom:24px;right:22px;z-index:10000;
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--accent);border:none;
  cursor:pointer;
  transition:background .2s,transform .15s,box-shadow .2s;
  box-shadow:0 4px 16px rgba(0,0,0,.3);
  title:'Print CV';
}
#print-btn:hover{background:#fff;transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.35);}
#print-btn svg{width:17px;height:17px;}

/* ── PRINT LAYOUT ── */
#print-cv{display:none;}
.no-print{display:block;}

@media print{
  html,body{margin:0;padding:0;background:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact;color-adjust:exact;}
  @page{size:A4;margin:0;}

  /* Hide ALL screen elements */
  body > *{display:none!important;}

  /* Show ONLY print CV */
  #print-cv{
    display:block!important;
    position:static!important;
    width:100%;
    font-family:'Montserrat',Arial,sans-serif;
    font-size:9pt;line-height:1.5;
    color:#222;background:#fff;
  }
  #print-cv *{display:revert;}

  /* Page breaks */
  #print-cv .p1{page-break-after:always;break-after:page;}

  /* Top name block — white background, large text */
  #print-cv .p1-top {
    padding: 10mm 14mm 6mm;
    border-bottom: 1.5pt solid #ccc;
  }
  #print-cv .p1-name { font-size:28pt; font-weight:900; color:#111; line-height:1; letter-spacing:-.02em; margin-bottom:3pt; }
  #print-cv .p1-title { font-size:9pt; color:#555; letter-spacing:.04em; }

  /* Dark grey info bar */
  #print-cv .p1-hero {
    background:#3a3a3a; color:#fff;
    padding: 8mm 14mm;
    display: grid;
    grid-template-columns: 32mm 1fr 1fr;
    gap: 0 10mm;
    align-items: start;
  }
  #print-cv .p1-photo {
    width:28mm; height:28mm; border-radius:50%;
    background:#666; border:2pt solid #888;
    overflow:hidden; display:flex; align-items:center; justify-content:center;
  }
  #print-cv .p1-photo img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
  #print-cv .p1-addr { font-size:7.5pt; color:#bbb; margin-top:5pt; line-height:1.5; }
  #print-cv .p1-dob  { font-size:7.5pt; color:#bbb; margin-top:3pt; }

  /* Contact / Follow columns */
  #print-cv .p1-col-title { font-size:8pt; font-weight:700; color:#fff; letter-spacing:.08em; margin-bottom:5pt; }
  #print-cv .p1-ci { display:flex; align-items:center; gap:5pt; margin-bottom:5pt; font-size:8pt; color:#ddd; }
  #print-cv .p1-ci-icon { font-size:9pt; }

  /* Body: Skills | Profile */
  #print-cv .p1-body {
    padding: 10mm 14mm 8mm;
    display: grid;
    grid-template-columns: 68mm 1fr;
    gap: 0 14mm;
    align-items: start;
  }

  /* ══ PAGE 2 ══════════════════════════════════════════════ */
  #print-cv .p2 { page-break-before:always; break-before:page; }
  #print-cv .p2-body {
    padding: 10mm 14mm 8mm;
    display: grid;
    grid-template-columns: 68mm 1fr;
    gap: 0 14mm;
    align-items: start;
  }

  /* ══ SHARED SECTION TITLES ════════════════════════════════ */
  #print-cv .psec-title {
    font-size: 7.5pt; font-weight:700; letter-spacing:.18em; text-transform:uppercase;
    color: #222; border-bottom: 1pt solid #bbb;
    padding-bottom: 2pt; margin-top: 12pt; margin-bottom: 6pt;
  }
  #print-cv .pleft .psec-title:first-child,
  #print-cv .p2-left .psec-title:first-child { margin-top:0; }

  /* ══ SKILL BARS (dot at end of fill percentage) ════════ */
  #print-cv .pskill-row { margin-bottom:7pt; page-break-inside:avoid; }
  #print-cv .pskill-name { font-size:7.5pt; color:#555; margin-bottom:2.5pt; letter-spacing:.04em; text-transform:uppercase; }
  #print-cv .pskill-track {
    position:relative;
    height:1.5pt;
    background:#ddd;
    margin-right:5pt;
  }
  #print-cv .pskill-fill {
    position:absolute;
    top:0; left:0;
    height:1.5pt;
    background:#555;
    overflow:visible;
  }
  #print-cv .pskill-dot {
    position:absolute;
    right:-4.5pt;
    top:50%;
    transform:translateY(-50%);
    width:9pt; height:9pt; border-radius:50%;
    background:#444; border:1.5pt solid #fff; box-shadow:0 0 0 1pt #999;
  }

  /* ══ PROFILE TEXT ════════════════════════════════════════ */
  #print-cv .pprofile { font-size:9pt; color:#333; line-height:1.65; }
  #print-cv .pprofile p { margin:0 0 6pt; }
  #print-cv .pprofile strong { font-weight:700; color:#111; }
  #print-cv .p1-portfolio {
    margin-top:10pt;
    font-size:8.5pt; color:#0055aa; text-decoration:underline;
    font-weight:600;
  }

  /* ══ EDUCATION / LANGUAGES ════════════════════════════════ */
  #print-cv .plang-item { margin-bottom:5pt; }
  #print-cv .plang-name { font-size:8.5pt; font-weight:700; color:#222; }
  #print-cv .plang-level { font-size:8pt; color:#666; }
  #print-cv .pedu-item { margin-bottom:5pt; }
  #print-cv .pedu-deg { font-size:8.5pt; font-weight:700; color:#222; }
  #print-cv .pedu-inst { font-size:8pt; color:#666; }

  /* ══ EXPERIENCE JOBS ════════════════════════════════════ */
  #print-cv .pjob { margin-bottom:9pt; page-break-inside:avoid; }
  #print-cv .pjob-role { font-size:9.5pt; font-weight:700; color:#111; margin-bottom:1pt; }
  #print-cv .pjob-co { font-size:8pt; color:#666; font-style:italic; margin-bottom:3pt; }
  #print-cv .pjob-pts { margin:0; padding-left:10pt; font-size:8.5pt; color:#333; line-height:1.55; }
  #print-cv .pjob-pts li { margin-bottom:2pt; }

  /* ══ TAGS ════════════════════════════════════════════════ */
  #print-cv .ptag {
    display:inline-block; font-size:7.5pt;
    padding:1.5pt 5pt; border:0.7pt solid #555; color:#444;
    margin:0 2pt 3pt 0; border-radius:1pt;
  }
  #print-cv .ptags { display:flex; flex-wrap:wrap; }

}
/* ── CONTACT SECTION ── */
.contact-sec{
  padding:0;background:var(--bg);position:relative;overflow:hidden;
  max-height:0;
  opacity:0;
  pointer-events:none;
  transition:max-height 0.65s cubic-bezier(.4,0,.2,1), opacity 0.45s ease, padding 0.45s ease;
  padding-top:0;padding-bottom:0;
}
.contact-sec.open{
  max-height:3000px;
  overflow:visible;
  opacity:1;
  pointer-events:all;
  padding-bottom:60px;
}
/* Contact toggle button */
.contact-toggle-wrap{display:flex;justify-content:center;padding:40px 0;background:var(--surface);position:relative;z-index:2;}
.contact-toggle{
  display:inline-flex;align-items:center;gap:10px;
  background:none;border:1px solid var(--border);
  color:var(--accent);font-family:'Space Mono',monospace;
  font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  padding:13px 28px;cursor:pointer;
  transition:all .3s;position:relative;overflow:hidden;
}
.contact-toggle::before{
  content:'';position:absolute;inset:0;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform .35s ease;z-index:0;
}
.contact-toggle:hover::before{transform:scaleX(1);}
.contact-toggle>*{position:relative;z-index:1;}
.contact-toggle:hover{color:#000;border-color:var(--accent);}
.contact-toggle svg{width:14px;height:14px;transition:transform .35s ease;}
.contact-toggle.open svg{transform:rotate(180deg);}
body.light .contact-toggle-wrap{background:#edf1f8;}
body.light .contact-toggle{color:var(--accent);border-color:rgba(0,105,168,.3);}
body.light .contact-toggle:hover{color:#fff;}
.contact-sec::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(0,200,224,.04),transparent 60%),radial-gradient(ellipse at 80% 80%,rgba(124,58,237,.04),transparent 50%);pointer-events:none;}
.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:60px;align-items:start;}
.contact-info{display:flex;flex-direction:column;gap:28px;}
.ci-item{display:flex;align-items:flex-start;gap:16px;}
.ci-icon{width:42px;height:42px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;background:rgba(0,200,224,.05);transition:all .3s;}
.ci-icon:hover{border-color:var(--accent);background:rgba(0,200,224,.1);}
.ci-label{font-size:9px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;}
.ci-value{font-size:12px;color:var(--text);}
.ci-value a{color:var(--accent);text-decoration:none;}
.ci-value a:hover{text-decoration:underline;}
.contact-social{display:flex;gap:10px;margin-top:4px;}
.cs-link{width:38px;height:38px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:15px;text-decoration:none;transition:all .3s;color:var(--muted);}
.cs-link:hover{border-color:var(--accent);color:var(--accent);background:rgba(0,200,224,.07);transform:translateY(-2px);}
/* Form */
.cf{display:flex;flex-direction:column;gap:16px;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.cf-group{display:flex;flex-direction:column;gap:6px;}
.cf-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}
.cf-input,.cf-textarea,.cf-select{
  background:rgba(0,200,224,.04);border:1px solid var(--border);
  color:var(--text);font-family:'Space Mono',monospace;font-size:12px;
  padding:11px 14px;outline:none;width:100%;border-radius:2px;
  transition:border-color .25s,background .25s,box-shadow .25s;
}
.cf-input::placeholder,.cf-textarea::placeholder{color:var(--muted);}
.cf-input:focus,.cf-textarea:focus,.cf-select:focus{border-color:var(--accent);background:rgba(0,200,224,.07);box-shadow:0 0 0 3px rgba(0,200,224,.1);}
.cf-input.error,.cf-textarea.error,.cf-select.error{border-color:#ff4444!important;}
.cf-err{font-size:10px;color:#ff4444;margin-top:2px;display:none;}
.cf-err.show{display:block;}
.cf-textarea{resize:vertical;min-height:120px;line-height:1.7;}
.cf-select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px;}
.cf-select option{background:var(--surface);color:var(--text);}
.cf-submit{
  position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:10px;
  background:var(--accent);border:none;color:#000;
  font-family:'Space Mono',monospace;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:14px 28px;cursor:pointer;width:100%;border-radius:2px;
  transition:box-shadow .2s;box-shadow:0 4px 16px rgba(0,200,224,.22);
}
.cf-submit::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.12);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.cf-submit:hover::after{transform:scaleX(1);}
.cf-submit:hover{box-shadow:0 6px 24px rgba(0,200,224,.32);}
.cf-submit>*{position:relative;z-index:1;}
.cf-submit svg{width:14px;height:14px;transition:transform .2s;}
.cf-submit:hover svg{transform:translateX(4px);}
.cf-success{display:none;flex-direction:column;align-items:center;gap:12px;text-align:center;padding:36px;border:1px solid var(--border);background:rgba(0,200,224,.04);border-radius:2px;}
.cf-success.show{display:flex;}
.cf-success-icon{font-size:38px;}
.cf-success-title{font-family:'Montserrat',sans-serif;font-size:18px;font-weight:800;color:var(--accent);}
.cf-success-msg{font-size:12px;color:var(--muted);line-height:1.7;}
body.light .contact-sec{background:#f5f7fa;}
body.light .cf-input,body.light .cf-textarea,body.light .cf-select{background:rgba(0,105,168,.04);border-color:rgba(0,105,168,.2);color:#111827;}
body.light .cf-input::placeholder,body.light .cf-textarea::placeholder{color:#9ca3af;}
body.light .cf-input:focus,body.light .cf-textarea:focus,body.light .cf-select:focus{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,105,168,.1);}
body.light .cf-submit{color:#fff;}
body.light .cf-success{background:rgba(0,105,168,.05);}
@media(max-width:900px){
  .contact-sec{padding:60px 28px;}
  .contact-grid{grid-template-columns:1fr;gap:36px;}
  .cf-row{grid-template-columns:1fr;}
}
.exp-sec{padding:80px 0;background:var(--surface);position:relative;}
.exp-sec::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:linear-gradient(to bottom,transparent,var(--accent),transparent);}
.sec-hdr{display:flex;align-items:baseline;gap:22px;margin-bottom:52px;}
.sec-num{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);}
.sec-h2{font-family:'Montserrat',sans-serif;font-size:46px;font-weight:800;color:#fff;letter-spacing:-.02em;}
.timeline{display:grid;grid-template-columns:150px 1fr;gap:0 32px;}
.tl-date{
  font-size:11px;color:var(--accent);letter-spacing:.07em;
  text-align:right;padding-right:24px;
  border-right:1px solid var(--border);
  position:relative;padding-bottom:40px;
  padding-top:0;line-height:1.4;
}
.tl-date::after{
  content:'';position:absolute;right:-5px;top:4px;
  width:9px;height:9px;
  border:2px solid var(--accent);background:var(--surface);border-radius:50%;
}
.tl-body{padding-bottom:40px;padding-top:0;}
.tl-co{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:5px;}
.tl-role{font-family:'Montserrat',sans-serif;font-size:17px;font-weight:700;color:#fff;margin-bottom:10px;line-height:1.2;}
.tl-pts{list-style:none;display:flex;flex-direction:column;gap:5px;}
.tl-pts li{font-size:12px;color:var(--muted);padding-left:16px;position:relative;line-height:1.65;}
.tl-pts li::before{content:'—';position:absolute;left:0;color:var(--accent);font-size:10px;top:2px;}

.sk-sec{padding:80px 0;background:var(--bg);}
.sk-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:44px;}
.sk-cell{background:var(--surface);padding:26px;border:1px solid var(--border);transition:all .3s;}
.sk-cell:hover{background:var(--surface2);border-color:rgba(0,229,255,.25);transform:translateY(-2px);}
.sk-lbl{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:7px;}
.sk-name{font-family:'Montserrat',sans-serif;font-size:17px;font-weight:700;color:#fff;margin-bottom:14px;}
.sk-bg{height:2px;background:var(--border);position:relative;}
.sk-fill{position:absolute;left:0;top:0;height:100%;background:var(--accent);box-shadow:0 0 8px var(--accent);width:0;transition:width 1.5s cubic-bezier(.4,0,.2,1);}

footer{padding:0;border-top:1px solid var(--border);background:var(--surface);}
.ft-name{font-family:'Montserrat',sans-serif;font-size:19px;font-weight:800;color:#fff;}
.ft-links{display:flex;gap:22px;}
.ft-links a{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color .2s;}
.ft-links a:hover{color:var(--accent);}
.ft-copy{font-size:11px;color:var(--muted);}

::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-thumb{background:var(--accent);border-radius:2px;}
::-webkit-scrollbar-track{background:transparent;}

@media(max-width:900px){
  .hero{grid-template-columns:1fr;}
  .hero-right{min-height:50vh;}
  .exp-sec,.sk-sec{padding:40px 0;}
  .timeline{grid-template-columns:1fr;}
  .tl-date{text-align:left;border-right:none;border-left:1px solid var(--border);padding-left:18px;padding-right:0;}
  .tl-date::after{left:-5px;right:auto;}
  .tl-body{padding-left:18px;}
  .sk-grid{grid-template-columns:1fr 1fr;}
  .panel-box{padding:28px 20px;}
  .pgrid{grid-template-columns:1fr;}
  .hero-left{padding:56px 28px;}
  footer{flex-direction:column;gap:0;padding:0;text-align:center;}
  footer .wrap{flex-direction:column;gap:24px;padding-top:40px;padding-bottom:40px;align-items:center;}
  .ft-name{font-size:22px;}
  .ft-links{flex-wrap:wrap;justify-content:center;gap:14px;}
  .ft-links a{font-size:12px;}
  .ft-copy{font-size:11px;}
}

/* ══════════════════════════════════════════════
   FUNKY PAGE LOADER
══════════════════════════════════════════════ */
#loader{
  position:fixed;inset:0;z-index:99999;
  background:#080c12;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:clamp(16px,4vw,32px);
  padding:20px;
  transition:opacity .6s ease, transform .6s ease;
}
#loader.fade-out{opacity:0;transform:scale(1.04);pointer-events:none;}

/* Name reveal */
.ld-name{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(28px,6vw,64px);
  font-weight:900;
  letter-spacing:-.02em;
  color:#fff;
  overflow:hidden;
  display:flex;gap:0;
}
.ld-char{
  display:inline-block;
  opacity:0;
  transform:translateY(40px) rotate(-8deg);
  animation:ldChar .5s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes ldChar{
  to{opacity:1;transform:translateY(0) rotate(0deg);}
}

/* Glitchy accent line under name */
.ld-title{
  font-family:'Space Mono',monospace;
  font-size:11px;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:#00c8e0;
  opacity:0;
  animation:ldFadeIn .4s .9s forwards;
  position:relative;
}
.ld-title::after{
  content:'';
  position:absolute;
  left:0;bottom:-6px;
  height:1px;width:0;
  background:linear-gradient(90deg,#00c8e0,#7c3aed);
  animation:ldLine .5s 1.1s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes ldLine{to{width:100%;}}
@keyframes ldFadeIn{to{opacity:1;}}

/* Orbit loader ring */
.ld-orbit{
  position:relative;
  width:90px;height:90px;
  opacity:0;
  animation:ldFadeIn .3s .6s forwards;
}
.ld-orbit-ring{
  position:absolute;inset:0;
  border-radius:50%;
  border:2px solid transparent;
  border-top-color:#00c8e0;
  animation:ldSpin 1s linear infinite;
}
.ld-orbit-ring:nth-child(2){
  inset:10px;
  border-top-color:transparent;
  border-right-color:#7c3aed;
  animation:ldSpin .7s linear infinite reverse;
}
.ld-orbit-ring:nth-child(3){
  inset:22px;
  border-top-color:transparent;
  border-bottom-color:#f59e0b;
  animation:ldSpin 1.4s linear infinite;
}
/* Center dot */
.ld-orbit-dot{
  position:absolute;
  width:12px;height:12px;
  background:#00c8e0;
  border-radius:50%;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:ldPulse 1s ease-in-out infinite;
  box-shadow:0 0 14px #00c8e0;
}
@keyframes ldSpin{to{transform:rotate(360deg);}}
@keyframes ldPulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:1;}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.5;}}

/* Progress bar */
.ld-bar-wrap{
  width:min(260px,60vw);
  height:3px;
  background:rgba(255,255,255,.08);
  border-radius:2px;
  overflow:hidden;
  opacity:0;
  animation:ldFadeIn .3s .7s forwards;
}
.ld-bar{
  height:100%;
  width:0%;
  background:linear-gradient(90deg,#00c8e0,#7c3aed,#f59e0b);
  border-radius:2px;
  animation:ldBarFill 1.8s .7s cubic-bezier(.4,0,.2,1) forwards;
}
@keyframes ldBarFill{to{width:100%;}}

/* Floating tech icons around orbit */
.ld-icons{
  position:absolute;
  width:180px;height:180px;
  top:50%;left:50%;
  transform:translate(-50%,-50%);
  animation:ldFadeIn .3s .6s forwards;
  opacity:0;
  pointer-events:none;
}
.ld-ico{
  position:absolute;
  font-size:14px;
  animation:ldOrbitIcon linear infinite;
}
@keyframes ldOrbitIcon{
  0%  {transform:rotate(var(--start)) translateX(70px) rotate(calc(-1*var(--start)));}
  100%{transform:rotate(calc(var(--start) + 360deg)) translateX(70px) rotate(calc(-1*(var(--start)+360deg)));}
}

/* Glitch flash on name */
.ld-glitch{
  position:relative;
  animation:ldGlitch 3s 1.2s infinite;
}
@keyframes ldGlitch{
  0%,94%,100%{text-shadow:none;transform:none;}
  95%{text-shadow:3px 0 #00c8e0,-3px 0 #7c3aed;transform:skewX(-4deg);}
  97%{text-shadow:-2px 0 #f59e0b,2px 0 #00c8e0;transform:skewX(3deg);}
}
/* ══ CONTACT FORM 7 OVERRIDES ══════════════════════════════════════════════
   Maps CF7's generated HTML to the CV design system.
   CF7 structure: .wpcf7 > form.wpcf7-form > p > span.wpcf7-form-control-wrap > input/select/textarea
   ═══════════════════════════════════════════════════════════════════════════ */

/* Remove CF7's default paragraph spacing wrapper */
.wpcf7 form p {
  margin: 0 0 14px;
}
.wpcf7 form p:last-child {
  margin-bottom: 0;
}

/* ── Text inputs, email, tel, url ── */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 input[type="url"],
.wpcf7 input[type="number"] {
  width: 100%;
  background: rgba(0,200,224,.04);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  padding: 11px 14px;
  outline: none;
  border-radius: 2px;
  box-sizing: border-box;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 input[type="url"]:focus {
  border-color: var(--accent);
  background: rgba(0,200,224,.07);
  box-shadow: 0 0 0 3px rgba(0,200,224,.1);
}
.wpcf7 input::placeholder { color: var(--muted); }

/* ── Textarea ── */
.wpcf7 textarea {
  width: 100%;
  background: rgba(0,200,224,.04);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  padding: 11px 14px;
  outline: none;
  border-radius: 2px;
  box-sizing: border-box;
  resize: vertical;
  min-height: 130px;
  line-height: 1.7;
  transition: border-color .25s, background .25s, box-shadow .25s;
}
.wpcf7 textarea:focus {
  border-color: var(--accent);
  background: rgba(0,200,224,.07);
  box-shadow: 0 0 0 3px rgba(0,200,224,.1);
}
.wpcf7 textarea::placeholder { color: var(--muted); }

/* ── Select / dropdown ── */
.wpcf7 select {
  width: 100%;
  background: rgba(0,200,224,.04);
  border: 1px solid var(--border);
  color: var(--text);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  padding: 11px 36px 11px 14px;
  outline: none;
  border-radius: 2px;
  box-sizing: border-box;
  appearance: none;
  cursor: pointer;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 14px center;
  transition: border-color .25s, background-color .25s, box-shadow .25s;
}
.wpcf7 select:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,200,224,.1);
}
.wpcf7 select option {
  background: var(--surface);
  color: var(--text);
}

/* ── Checkbox (acceptance) ── */
.wpcf7 .wpcf7-acceptance {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.5;
}
.wpcf7 .wpcf7-acceptance input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 1px;
}
.wpcf7 .wpcf7-list-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0;
}
.wpcf7 .wpcf7-list-item-label {
  font-size: 11px;
  color: var(--muted);
  cursor: pointer;
}

/* ── Submit button ── */
.wpcf7 input[type="submit"] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: var(--accent);
  border: none;
  color: #000;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 14px 28px;
  cursor: pointer;
  border-radius: 2px;
  box-shadow: 0 4px 16px rgba(0,200,224,.22);
  transition: background .2s, box-shadow .2s, transform .15s;
  box-sizing: border-box;
}
.wpcf7 input[type="submit"]:hover {
  background: #00e5ff;
  box-shadow: 0 6px 24px rgba(0,200,224,.35);
  transform: translateY(-1px);
}
.wpcf7 input[type="submit"]:active {
  transform: translateY(0);
}

/* ── Error / validation messages ── */
.wpcf7 .wpcf7-not-valid-tip {
  font-size: 10px;
  color: #ff4444;
  display: block;
  margin-top: 4px;
  font-family: 'Space Mono', monospace;
}
.wpcf7 .wpcf7-not-valid {
  border-color: #ff4444 !important;
}
.wpcf7 .wpcf7-response-output {
  margin: 14px 0 0;
  padding: 10px 14px;
  font-size: 11px;
  font-family: 'Space Mono', monospace;
  border-radius: 2px;
  border: 1px solid var(--border);
}
.wpcf7 .wpcf7-mail-sent-ok {
  border-color: var(--accent);
  background: rgba(0,200,224,.07);
  color: var(--accent);
}
.wpcf7 .wpcf7-mail-sent-ng,
.wpcf7 .wpcf7-aborted,
.wpcf7 .wpcf7-spam-blocked {
  border-color: #ff4444;
  background: rgba(255,68,68,.06);
  color: #ff4444;
}
.wpcf7 .wpcf7-validation-errors {
  border-color: #f59e0b;
  background: rgba(245,158,11,.06);
  color: #f59e0b;
}

/* ── Spinner (ajax loading) ── */
.wpcf7 .wpcf7-spinner {
  display: none;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(0,200,224,.2);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: cf7spin .7s linear infinite;
  margin-left: 10px;
  vertical-align: middle;
}
.wpcf7 .wpcf7-spinner.is-active { display: inline-block; }
@keyframes cf7spin { to { transform: rotate(360deg); } }

/* ── Two-column row layout ──
   Wrap two CF7 fields in a <div class="cf-row"> in the CF7 form editor */
.wpcf7 .cf-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-bottom: 14px;
}
.wpcf7 .cf-row p { margin: 0; }
.wpcf7 .cf-row span { width: 100%; }
.wpcf7 .cf-row input,
.wpcf7 .cf-row select { width: 100%; }

/* ── Form control wrap — full width ── */
.wpcf7 .wpcf7-form-control-wrap {
  display: block;
}

/* ── Light mode overrides ── */
body.light .wpcf7 input[type="text"],
body.light .wpcf7 input[type="email"],
body.light .wpcf7 input[type="tel"],
body.light .wpcf7 textarea,
body.light .wpcf7 select {
  background: rgba(0,105,168,.04);
  border-color: rgba(0,105,168,.2);
  color: #111827;
}
body.light .wpcf7 input::placeholder,
body.light .wpcf7 textarea::placeholder { color: #9ca3af; }
body.light .wpcf7 input[type="text"]:focus,
body.light .wpcf7 input[type="email"]:focus,
body.light .wpcf7 textarea:focus,
body.light .wpcf7 select:focus {
  border-color: var(--accent);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(0,105,168,.1);
}
body.light .wpcf7 select option {
  background: #ffffff;
  color: #111827;
}
body.light .wpcf7 input[type="submit"] { color: #fff; }

/* ── Responsive ── */
@media (max-width: 700px) {
  .wpcf7 .cf-row { grid-template-columns: 1fr; }
}

/* ══ CF7 LAYOUT FIX (actual rendered HTML structure) ═══════════════════════
   CF7 wraps multiple fields in ONE <p> with <br> separators inside .cf-row.
   We override this to achieve the two-column grid layout.
   ═══════════════════════════════════════════════════════════════════════════ */

/* Make the p inside cf-row a flex/grid container */
.cf7-wrap .cf-row p {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 0 0 14px;
  align-items: start;
}

/* Hide the <br> CF7 injects between fields */
.cf7-wrap .cf-row p br {
  display: none;
}

/* Each span wrap takes full width of its grid cell */
.cf7-wrap .cf-row p .wpcf7-form-control-wrap {
  display: block;
  width: 100%;
}

/* Ensure inputs/selects fill their cell */
.cf7-wrap .cf-row p input,
.cf7-wrap .cf-row p select {
  width: 100%;
  box-sizing: border-box;
}

/* Tighten up regular (non cf-row) p spacing */
.cf7-wrap .wpcf7-form > p,
.cf7-wrap form > p {
  margin: 0 0 14px;
}
.cf7-wrap .wpcf7-form > p:last-child,
.cf7-wrap form > p:last-child {
  margin-bottom: 0;
}

/* Consent row — checkbox + label inline */
.cf7-wrap p:has(.wpcf7-acceptance) {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 11px;
  color: var(--muted);
  line-height: 1.55;
  font-family: 'Space Mono', monospace;
}

/* Spinner next to submit */
.cf7-wrap p:has(input[type="submit"]) {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 6px;
}
.cf7-wrap p:has(input[type="submit"]) input[type="submit"] {
  flex: 1;
}

/* Response output styling */
.cf7-wrap .wpcf7-response-output {
  margin-top: 12px;
  padding: 10px 14px;
  font-size: 11px;
  font-family: 'Space Mono', monospace;
  border-radius: 2px;
  border: 1px solid var(--border);
}

/* Responsive */
@media (max-width: 700px) {
  .cf7-wrap .cf-row p {
    grid-template-columns: 1fr;
  }
}

/* ══ LIVE SITE FIXES ════════════════════════════════════════════════════════ */

/* 1. Hide WordPress admin bar on frontend (logged-in editors see it in /wp-admin) */
#wpadminbar { display: none !important; }
html { margin-top: 0 !important; }

/* 2. CF7 consent row — text node sits directly in <p>, not in a span.
      Use flex on the <p> containing the acceptance span + bare text */
.cf7-wrap p:has(.wpcf7-acceptance) {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-start !important;
  gap: 10px !important;
  font-size: 11px !important;
  color: var(--muted) !important;
  line-height: 1.55 !important;
  font-family: 'Space Mono', monospace !important;
  flex-wrap: nowrap !important;
}
/* The acceptance span wraps just the checkbox — keep it tight */
.cf7-wrap .wpcf7-acceptance {
  flex-shrink: 0;
  display: flex;
  align-items: center;
}
.cf7-wrap .wpcf7-list-item {
  margin: 0;
  display: flex;
  align-items: center;
}

/* 3. Select full width fix — override any inherited width constraint */
.cf7-wrap select.wpcf7-select {
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

/* 4. All form controls inside cf-row must fill their cell */
.cf7-wrap .cf-row .wpcf7-form-control {
  width: 100% !important;
  box-sizing: border-box !important;
  min-width: 0 !important;
}

/* 5. Submit button disabled state — CF7 disables it until JS loads */
.cf7-wrap input[type="submit"]:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* 6. Fix the empty response output bar showing at bottom */
.cf7-wrap .wpcf7-response-output:empty {
  display: none;
}

/* Hide CF7 hidden fields fieldset — browser renders it with a visible border by default */
.wpcf7 fieldset.hidden-fields-container,
.wpcf7 .hidden-fields-container {
  display: none !important;
}

/* ══ CF7 FINAL POLISH ═══════════════════════════════════════════════════════ */

/* 1. Screen reader response — truly hidden, not just off-screen */
.wpcf7 .screen-reader-response {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* 2. Inline error tip — subtle accent instead of harsh red */
.wpcf7 .wpcf7-not-valid-tip {
  display: block;
  font-size: 10px;
  font-family: 'Space Mono', monospace;
  color: var(--accent3);
  margin-top: 4px;
  letter-spacing: .04em;
  opacity: 0.9;
}

/* 3. Invalid field border — accent3 (amber) not red */
.wpcf7 .wpcf7-not-valid {
  border-color: var(--accent3) !important;
  background: rgba(245,158,11,.05) !important;
  box-shadow: 0 0 0 2px rgba(245,158,11,.12) !important;
}

/* 4. Consent row — fix the gap so checkbox hugs the text */
.cf7-wrap p:has(.wpcf7-acceptance) {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: nowrap !important;
  font-size: 11px !important;
  color: var(--muted) !important;
  font-family: 'Space Mono', monospace !important;
  line-height: 1.5 !important;
  margin-bottom: 14px !important;
}
/* Collapse the nested span wrappers so checkbox sits flush */
.cf7-wrap .wpcf7-acceptance,
.cf7-wrap .wpcf7-list-item {
  display: contents !important;
}
.cf7-wrap .wpcf7-acceptance input[type="checkbox"] {
  width: 15px !important;
  height: 15px !important;
  flex-shrink: 0 !important;
  accent-color: var(--accent) !important;
  cursor: pointer !important;
  margin: 0 !important;
}

/* 5. Response output — hide when empty, style when populated */
.wpcf7 .wpcf7-response-output:empty { display: none !important; }
.wpcf7 .wpcf7-mail-sent-ok {
  display: block;
  margin-top: 14px;
  padding: 12px 16px;
  border: 1px solid var(--accent);
  background: rgba(0,200,224,.07);
  color: var(--accent);
  font-size: 11px;
  font-family: 'Space Mono', monospace;
  border-radius: 2px;
  letter-spacing: .04em;
}
.wpcf7 .wpcf7-validation-errors {
  display: block;
  margin-top: 14px;
  padding: 12px 16px;
  border: 1px solid var(--accent3);
  background: rgba(245,158,11,.06);
  color: var(--accent3);
  font-size: 11px;
  font-family: 'Space Mono', monospace;
  border-radius: 2px;
}

/* ── Avatar face — clickable via avatar-wrap hover on rings ── */

/* ── Prevent double-tap zoom on interactive elements ── */
.avatar-wrap,
.disc-btn,
.contact-toggle,
.cf-submit,
.av-chat-btn,
#theme-toggle,
#print-btn,
button {
  touch-action: manipulation;
}

/* ── Mobile contact form fixes ── */
@media (max-width: 600px) {
  .cf7-wrap .cf-row p {
    grid-template-columns: 1fr !important;
  }
  .contact-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  .wpcf7 input[type="text"],
  .wpcf7 input[type="email"],
  .wpcf7 select,
  .wpcf7 textarea {
    font-size: 16px !important; /* prevents iOS zoom on focus */
  }
}
