/* ═══════════════════════════════════════════════
   Axioma Dijital — CSS Global
═══════════════════════════════════════════════ */
:root {
  --navy:      #0F2A4A;
  --navy-mid:  #1B4F8A;
  --blue:      #2E7DD1;
  --blue-lt:   #EBF3FB;
  --green:     #0D7C59;
  --green-lt:  #E6F5F0;
  --white:     #FFFFFF;
  --bg:        #F7F9FC;
  --slate:     #64748B;
  --text:      #1E293B;
  --border:    #E2E8F0;
  --shadow:    0 4px 24px rgba(15,42,74,0.10);
  --shadow-lg: 0 12px 40px rgba(15,42,74,0.16);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',sans-serif;color:var(--text);background:var(--white);font-size:16px;line-height:1.6;}
h1,h2,h3,h4{font-family:'Poppins',sans-serif;line-height:1.25;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}

/* ── Utilities ─────────────────────────────── */
.container{max-width:1200px;margin:0 auto;padding:0 24px;}
.section{padding:80px 0;}
.section-alt{background:var(--bg);}
.badge{display:inline-block;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:var(--blue-lt);color:var(--navy-mid);margin-bottom:14px;}
.badge-green{background:var(--green-lt);color:var(--green);}
.section-title{font-size:clamp(26px,3.5vw,38px);font-weight:700;color:var(--navy);margin-bottom:12px;}
.section-sub{font-size:16px;color:var(--slate);max-width:580px;}
.section-header{margin-bottom:52px;}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:8px;font-weight:600;font-size:15px;cursor:pointer;transition:.2s;border:none;font-family:'Inter',sans-serif;}
.btn-primary{background:var(--navy-mid);color:#fff;}
.btn-primary:hover{background:var(--navy);transform:translateY(-1px);box-shadow:var(--shadow);}
.btn-outline{background:transparent;color:var(--navy-mid);border:2px solid var(--navy-mid);}
.btn-outline:hover{background:var(--navy-mid);color:#fff;}
.btn-green{background:var(--green);color:#fff;}
.btn-green:hover{background:#0a6348;transform:translateY(-1px);}
.btn-white{background:#fff;color:var(--navy);}
.btn-white:hover{background:#EBF3FB;}
.reveal{opacity:0;transform:translateY(26px);transition:.5s ease;}
.reveal.visible{opacity:1;transform:none;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.text-center{text-align:center;}
.text-center .section-sub{margin:0 auto;}

/* ── Header ────────────────────────────────── */
header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.97);border-bottom:1px solid var(--border);backdrop-filter:blur(8px);}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:66px;padding:10px 0;gap:20px;}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--navy);}
.logo-img{height:40px;width:40px;flex-shrink:0;mix-blend-mode:multiply;object-fit:contain;}
.logo-text{display:flex;flex-direction:column;gap:3px;line-height:1;}
.logo-name{font-family:'Anurati',sans-serif;font-weight:400;font-size:26px;letter-spacing:.18em;color:var(--navy);text-transform:uppercase;line-height:1;}
.logo-sub{display:flex;align-items:center;gap:6px;}
.logo-sub-line{display:block;width:30px;height:1.5px;background:var(--blue);flex-shrink:0;}
.logo-sub-word{font-family:'Exo 2',sans-serif;font-size:8.5px;font-weight:700;letter-spacing:.32em;color:var(--navy);text-transform:uppercase;white-space:nowrap;}
.logo-tagline{font-family:'Inter',sans-serif;font-size:9.5px;color:var(--slate);letter-spacing:.01em;line-height:1.3;}
.logo-accent{color:var(--blue);font-style:italic;}
.logo-icon{width:34px;height:34px;background:var(--navy-mid);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;}
.logo-svg{width:36px;height:36px;flex-shrink:0;}
nav{display:flex;align-items:center;gap:2px;}
nav a{padding:7px 12px;border-radius:6px;font-size:14px;font-weight:500;color:var(--text);transition:.15s;}
nav a:hover,nav a.active{background:var(--bg);color:var(--navy-mid);}
nav a.active{font-weight:600;}
.header-actions{display:flex;align-items:center;gap:8px;}
.header-actions .btn{padding:8px 18px;font-size:14px;}
.hdr-icon{width:34px;height:34px;border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--slate);background:var(--bg);cursor:pointer;transition:.15s;border:1px solid var(--border);}
.hdr-icon:hover{background:var(--blue-lt);color:var(--navy-mid);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;}
.hamburger span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:.2s;}
.mobile-menu{display:none;position:absolute;top:66px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);padding:14px 24px;flex-direction:column;gap:4px;z-index:999;}
.mobile-menu a{padding:10px 14px;border-radius:6px;font-size:15px;font-weight:500;color:var(--text);}
.mobile-menu a:hover,.mobile-menu a.active{background:var(--bg);color:var(--navy-mid);}
.mobile-menu a.active{font-weight:600;}
.mobile-menu a.mm-clients{margin-top:6px;background:var(--blue-lt);color:var(--navy-mid);font-weight:600;border:1.5px solid var(--navy-mid);border-radius:7px;}
.mobile-menu a.mm-clients:hover,.mobile-menu a.mm-clients.active{background:var(--navy-mid);color:#fff;}
.mobile-menu.open{display:flex;}
@media(max-width:900px){nav{display:none;}.hamburger{display:flex;}.header-actions .btn-outline,.header-actions .btn-primary{display:none;}}

/* ── Page Hero (interior pages) ─────────────── */
.page-hero{background:linear-gradient(155deg,#0F2A4A 0%,#1B4F8A 100%);padding:60px 0;}
.page-hero h1{font-size:clamp(28px,4vw,46px);font-weight:800;color:#fff;margin-bottom:14px;}
.page-hero p{font-size:16px;color:rgba(255,255,255,.78);max-width:560px;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.55);margin-bottom:20px;}
.breadcrumb a{color:rgba(255,255,255,.7);}
.breadcrumb a:hover{color:#fff;}
.breadcrumb i{font-size:10px;}

/* ── Hero Home ──────────────────────────────── */
.hero{background:linear-gradient(155deg,#0F2A4A 0%,#1B4F8A 55%,#2563B0 100%);padding:80px 0 0;overflow:hidden;position:relative;}
.hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:flex-end;}
.hero-content{padding-bottom:80px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 16px;border-radius:20px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.88);font-size:13px;font-weight:500;margin-bottom:22px;border:1px solid rgba(255,255,255,.14);}
.hero h1{font-size:clamp(30px,4vw,50px);font-weight:800;color:#fff;margin-bottom:18px;line-height:1.15;}
.hero h1 span{color:#7DD3FC;}
.hero p{font-size:16px;color:rgba(255,255,255,.78);margin-bottom:34px;max-width:470px;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:28px;margin-top:40px;padding-top:28px;border-top:1px solid rgba(255,255,255,.12);}
.hero-stat strong{display:block;font-size:26px;font-weight:700;color:#fff;}
.hero-stat span{font-size:12px;color:rgba(255,255,255,.6);}
.hero-visual{display:flex;align-items:flex-end;justify-content:center;}
.dashboard{background:rgba(255,255,255,.07);backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.14);border-radius:14px 14px 0 0;padding:20px;width:100%;box-shadow:0 -6px 36px rgba(0,0,0,.28);}
.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.dash-title{color:#fff;font-size:13px;font-weight:600;}
.dash-dots{display:flex;gap:5px;}
.dash-dots span{width:9px;height:9px;border-radius:50%;}
.dash-dots span:nth-child(1){background:#FF5F56;}
.dash-dots span:nth-child(2){background:#FFBD2E;}
.dash-dots span:nth-child(3){background:#27C93F;}
.kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px;}
.kpi{background:rgba(255,255,255,.07);border-radius:9px;padding:11px;text-align:center;border:1px solid rgba(255,255,255,.09);}
.kpi strong{display:block;font-size:18px;font-weight:700;color:#fff;}
.kpi span{font-size:10px;color:rgba(255,255,255,.5);}
.kpi.accent{background:rgba(125,211,252,.1);border-color:rgba(125,211,252,.18);}
.kpi.accent strong{color:#7DD3FC;}
.dash-chart{background:rgba(255,255,255,.05);border-radius:9px;padding:12px;margin-bottom:9px;border:1px solid rgba(255,255,255,.07);}
.chart-bars{display:flex;align-items:flex-end;gap:7px;height:48px;}
.bar{flex:1;border-radius:3px 3px 0 0;background:rgba(125,211,252,.2);}
.bar.hi{background:#7DD3FC;}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.dash-item{background:rgba(255,255,255,.05);border-radius:9px;padding:11px;border:1px solid rgba(255,255,255,.07);}
.dash-item-lbl{font-size:10px;color:rgba(255,255,255,.45);margin-bottom:3px;}
.dash-item-val{font-size:13px;font-weight:600;color:#fff;}
.sdot{display:inline-block;width:6px;height:6px;border-radius:50%;background:#27C93F;margin-right:4px;}
@media(max-width:900px){.hero-inner{grid-template-columns:1fr;}.hero-visual{display:none;}.hero-content{padding-bottom:40px;}}

/* ── Service Cards ──────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc-card{background:#fff;border:1px solid var(--border);border-radius:13px;padding:30px 26px;transition:.2s;cursor:pointer;}
.svc-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-3px);}
.svc-icon{width:50px;height:50px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:16px;}
.ic-blue{background:var(--blue-lt);color:var(--navy-mid);}
.ic-green{background:var(--green-lt);color:var(--green);}
.ic-slate{background:#F1F5F9;color:#475569;}
.svc-card h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:7px;}
.svc-card p{font-size:14px;color:var(--slate);line-height:1.65;}
.svc-link{display:inline-flex;align-items:center;gap:5px;margin-top:14px;font-size:13px;font-weight:600;color:var(--navy-mid);}
.svc-link i{font-size:10px;transition:.15s;}
.svc-card:hover .svc-link i{transform:translateX(3px);}
@media(max-width:900px){.services-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.services-grid{grid-template-columns:1fr;}}

/* ── Compare ────────────────────────────────── */
.cmp-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:14px;overflow:hidden;box-shadow:var(--shadow);}
.cmp-head{padding:20px 26px;font-size:15px;font-weight:700;}
.cmp-head-l{background:#F1F5F9;color:var(--slate);}
.cmp-head-r{background:var(--navy);color:#fff;}
.cmp-sub{font-size:12px;font-weight:400;color:rgba(255,255,255,.6);margin-top:2px;}
.cmp-rows .row{display:flex;align-items:center;gap:9px;padding:13px 26px;font-size:14px;border-bottom:1px solid var(--border);}
.cmp-l{background:#fff;}
.cmp-r{background:#1B4F8A;color:rgba(255,255,255,.88);}
.cmp-r .row{border-color:rgba(255,255,255,.1);}
.cmp-l .row i{color:#CBD5E1;font-size:12px;}
.cmp-r .row i{color:#7DD3FC;font-size:12px;}
@media(max-width:680px){.cmp-wrap{grid-template-columns:1fr;}}

/* ── Steps ──────────────────────────────────── */
.steps{display:grid;grid-template-columns:repeat(5,1fr);gap:0;position:relative;}
.steps::before{content:'';position:absolute;top:27px;left:10%;right:10%;height:2px;background:var(--border);z-index:0;}
.step{text-align:center;position:relative;z-index:1;}
.step-num{width:54px;height:54px;border-radius:50%;background:#fff;border:2px solid var(--blue);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:17px;font-weight:700;color:var(--navy-mid);box-shadow:var(--shadow);}
.step h4{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:5px;}
.step p{font-size:12px;color:var(--slate);line-height:1.5;padding:0 8px;}
@media(max-width:780px){.steps{grid-template-columns:1fr 1fr;gap:26px;}.steps::before{display:none;}}

/* ── Sectors ────────────────────────────────── */
.sectors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.sectors-list{list-style:none;display:flex;flex-direction:column;gap:0;max-width:760px;margin:0 auto;border:1px solid var(--border);border-radius:12px;overflow:hidden;}
.sectors-list li{display:flex;align-items:flex-start;gap:16px;padding:18px 22px;border-bottom:1px solid var(--border);background:#fff;}
.sectors-list li:last-child{border-bottom:none;}
.sectors-list li>i{width:40px;height:40px;border-radius:10px;background:var(--blue-lt);color:var(--navy-mid);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.sectors-list li strong{display:block;font-size:15px;font-weight:600;color:var(--navy);margin-bottom:4px;}
.sectors-list li span{font-size:14px;color:var(--slate);line-height:1.5;}

.sector-card{background:#fff;border:1px solid var(--border);border-radius:12px;padding:22px;text-align:center;transition:.2s;}
.sector-card:hover{border-color:var(--blue);box-shadow:var(--shadow);}
.sector-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 14px;background:var(--blue-lt);color:var(--navy-mid);}
.sector-card h4{font-size:14px;font-weight:600;color:var(--navy);margin-bottom:5px;}
.sector-card p{font-size:13px;color:var(--slate);}
@media(max-width:780px){.sectors-grid{grid-template-columns:1fr 1fr;}}

/* ── Testimonios ────────────────────────────── */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.testi-card{background:#fff;border:1px solid var(--border);border-radius:13px;padding:26px;}
.testi-stars{display:flex;gap:3px;margin-bottom:13px;}
.testi-stars i{color:#F59E0B;font-size:12px;}
.testi-text{font-size:14px;color:var(--slate);line-height:1.7;margin-bottom:16px;font-style:italic;}
.testi-author{display:flex;align-items:center;gap:11px;}
.testi-av{width:38px;height:38px;border-radius:50%;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--navy-mid);font-size:13px;}
.testi-name{font-size:14px;font-weight:600;color:var(--text);}
.testi-role{font-size:12px;color:var(--slate);}
@media(max-width:780px){.testi-grid{grid-template-columns:1fr;}}

/* ── CTA Banner ─────────────────────────────── */
.cta-banner{background:linear-gradient(135deg,#0F2A4A,#1B4F8A);padding:70px 0;text-align:center;}
.cta-banner h2{font-size:clamp(24px,3.5vw,38px);font-weight:800;color:#fff;margin-bottom:12px;}
.cta-banner p{font-size:16px;color:rgba(255,255,255,.72);margin-bottom:30px;max-width:500px;margin-left:auto;margin-right:auto;}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;}

/* ── Forms ──────────────────────────────────── */
.form-card{background:#fff;border-radius:14px;padding:34px;border:1px solid var(--border);box-shadow:var(--shadow);}
.form-card h3{font-size:19px;font-weight:700;color:var(--navy);margin-bottom:22px;}
.fg{margin-bottom:14px;}
.fg label{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:5px;}
.fg input,.fg select,.fg textarea{width:100%;padding:9px 13px;border:1px solid var(--border);border-radius:7px;font-family:'Inter',sans-serif;font-size:14px;color:var(--text);background:#fff;outline:none;transition:.15s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);}
.fg textarea{resize:vertical;min-height:90px;}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:500px){.fg-row{grid-template-columns:1fr;}}

/* ── Why/Feature cards ──────────────────────── */
.feat-card{display:flex;align-items:flex-start;gap:14px;padding:18px;background:#fff;border-radius:11px;border:1px solid var(--border);}
.feat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.feat-card h4{font-size:15px;font-weight:600;color:var(--navy);margin-bottom:4px;}
.feat-card p{font-size:13px;color:var(--slate);}

/* ── Software modules ───────────────────────── */
.sw-modules{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.sw-mod{display:flex;align-items:center;gap:9px;padding:11px 14px;background:#fff;border:1px solid var(--border);border-radius:9px;font-size:13px;font-weight:500;}
.sw-mod i{color:var(--green);font-size:12px;}
.sw-visual{background:var(--bg);border-radius:14px;padding:26px;border:1px solid var(--border);}

/* ── Client Area ────────────────────────────── */
.client-area{background:var(--navy);padding:80px 0;}
.cl-inner{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.cl-content .section-title{color:#fff;}
.cl-content .section-sub{color:rgba(255,255,255,.68);}
.cl-feats{display:flex;flex-direction:column;gap:12px;margin-top:26px;}
.cl-feat{display:flex;align-items:center;gap:11px;color:rgba(255,255,255,.82);font-size:14px;}
.cl-feat i{color:#7DD3FC;font-size:13px;}
.cl-panel{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:13px;padding:22px;}
.pnav{display:flex;gap:6px;margin-bottom:18px;flex-wrap:wrap;}
.pnav-item{padding:6px 13px;border-radius:6px;font-size:13px;font-weight:500;color:rgba(255,255,255,.55);cursor:pointer;transition:.15s;}
.pnav-item.active,.pnav-item:hover{background:rgba(255,255,255,.12);color:#fff;}
.pw{background:rgba(255,255,255,.05);border-radius:9px;padding:13px;margin-bottom:9px;border:1px solid rgba(255,255,255,.08);}
.pw-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:7px;}
.pw-lbl{font-size:11px;color:rgba(255,255,255,.45);}
.pw-val{font-size:19px;font-weight:700;color:#fff;}
.pbadge{font-size:11px;padding:2px 9px;border-radius:20px;}
.pb-g{background:rgba(125,211,252,.15);color:#7DD3FC;}
.pb-a{background:rgba(251,191,36,.13);color:#FBB924;}
@media(max-width:900px){.cl-inner{grid-template-columns:1fr;}}

/* ── Contact ────────────────────────────────── */
.ct-info{display:flex;flex-direction:column;gap:18px;}
.ct-item{display:flex;align-items:flex-start;gap:13px;}
.ct-item-icon{width:42px;height:42px;border-radius:9px;background:var(--blue-lt);display:flex;align-items:center;justify-content:center;color:var(--navy-mid);font-size:15px;flex-shrink:0;}
.ct-item strong{display:block;font-size:14px;font-weight:600;color:var(--text);}
.ct-item span{font-size:14px;color:var(--slate);}

/* ── Footer ─────────────────────────────────── */
footer#site-footer{background:#0A1929;color:rgba(255,255,255,.72);padding:56px 0 0;}
.ft-grid{display:grid;grid-template-columns:2fr repeat(4,minmax(0,1fr));gap:36px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.07);}
.ft-brand .logo-tagline{color:rgba(255,255,255,.55);max-width:280px;}
.ft-brand p{font-size:14px;color:rgba(255,255,255,.5);line-height:1.7;max-width:250px;margin-top:13px;}
.ft-socials{display:flex;gap:9px;margin-top:18px;}
.ft-soc{width:32px;height:32px;border-radius:7px;background:rgba(255,255,255,.07);display:flex;align-items:center;justify-content:center;font-size:13px;color:rgba(255,255,255,.55);transition:.15s;}
.ft-soc:hover{background:var(--navy-mid);color:#fff;}
.ft-col h4{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-bottom:14px;}
.ft-col ul{display:flex;flex-direction:column;gap:9px;}
.ft-col ul li a{font-size:14px;color:rgba(255,255,255,.5);transition:.15s;}
.ft-col ul li a:hover{color:#fff;}
.ft-col ul li a.ft-clients-link{display:inline-flex;align-items:center;gap:5px;color:#7DD3FC;font-weight:600;}
.ft-col ul li a.ft-clients-link:hover{color:#fff;}
.ft-bottom{display:flex;align-items:center;justify-content:space-between;padding:18px 0;font-size:13px;color:rgba(255,255,255,.3);flex-wrap:wrap;gap:8px;}
@media(max-width:1100px){
  .ft-grid{grid-template-columns:1fr 1fr;gap:28px 24px;}
  .ft-brand{grid-column:1 / -1;}
}
@media(max-width:480px){
  .ft-grid{grid-template-columns:1fr 1fr;gap:24px 16px;}
  .ft-brand{grid-column:1 / -1;}
  .ft-col h4{font-size:11px;margin-bottom:10px;}
  .ft-col ul{gap:7px;}
  .ft-col ul li a{font-size:13px;}
}

/* ── Cookie banner ──────────────────────────── */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;background:#fff;border-top:1px solid var(--border);box-shadow:0 -8px 32px rgba(11,22,40,.12);padding:18px 0;transition:transform .35s ease,opacity .35s ease;}
.cookie-banner-hidden{transform:translateY(110%);opacity:0;pointer-events:none;}
.cookie-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.cookie-banner-text{flex:1;min-width:260px;}
.cookie-banner-text strong{display:flex;align-items:center;gap:8px;font-size:15px;color:var(--navy);margin-bottom:6px;}
.cookie-banner-text p{font-size:13px;color:var(--slate);line-height:1.6;margin:0;}
.cookie-banner-text a{color:var(--blue);text-decoration:underline;}
.cookie-banner-actions{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap;}
@media(max-width:640px){.cookie-banner-actions{width:100%;}.cookie-banner-actions .btn{flex:1;justify-content:center;}}

/* ── Responsive grids ───────────────────────── */
@media(max-width:900px){.grid-2{grid-template-columns:1fr;gap:36px;}.grid-3{grid-template-columns:1fr 1fr;}.cl-inner{grid-template-columns:1fr;}}
@media(max-width:600px){.grid-3,.grid-4{grid-template-columns:1fr;}.sectors-grid{grid-template-columns:1fr 1fr;}}

/* ── Chat Widget ────────────────────────────── */
#chat-widget{position:fixed;bottom:24px;right:24px;z-index:9999;}
#chat-btn{width:54px;height:54px;border-radius:50%;background:var(--navy-mid);color:#fff;display:flex;align-items:center;justify-content:center;font-size:21px;cursor:pointer;box-shadow:0 4px 18px rgba(27,79,138,.4);transition:.2s;border:none;}
#chat-btn:hover{background:var(--navy);transform:scale(1.05);}
#chat-box{display:none;flex-direction:column;width:316px;height:420px;background:#fff;border-radius:14px;box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden;margin-bottom:11px;}
#chat-box.open{display:flex;}
#chat-box.open + #chat-btn{display:none!important;}
.chat-hd{background:var(--navy);padding:14px 16px;display:flex;align-items:center;gap:11px;}
.chat-av{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;font-size:15px;color:#fff;}
.chat-hd-info{flex:1;}
.chat-hd-name{font-size:14px;font-weight:600;color:#fff;}
.chat-hd-status{font-size:11px;color:rgba(255,255,255,.6);display:flex;align-items:center;gap:4px;}
#chat-close{background:none;border:none;color:rgba(255,255,255,.55);font-size:15px;cursor:pointer;}
.chat-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:9px;background:#F8FAFC;}
.msg{max-width:84%;padding:9px 13px;border-radius:11px;font-size:14px;line-height:1.55;}
.msg-bot{background:#fff;border:1px solid var(--border);color:var(--text);border-radius:4px 11px 11px 11px;}
.msg-user{background:var(--navy-mid);color:#fff;align-self:flex-end;border-radius:11px 11px 4px 11px;}
.cq{display:flex;flex-direction:column;gap:5px;margin-top:5px;}
.cq-btn{padding:6px 11px;border-radius:7px;border:1px solid var(--border);background:#fff;font-size:12px;cursor:pointer;text-align:left;transition:.15s;color:var(--navy-mid);font-weight:500;font-family:'Inter',sans-serif;}
.cq-btn:hover{background:var(--blue-lt);}
.chat-inp-row{display:flex;padding:11px;border-top:1px solid var(--border);gap:7px;}
#chat-input{flex:1;padding:8px 12px;border:1px solid var(--border);border-radius:7px;font-size:14px;outline:none;font-family:'Inter',sans-serif;}
#chat-input:focus{border-color:var(--blue);}
#chat-send{width:34px;height:34px;border-radius:7px;background:var(--navy-mid);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;}
.typing-indicator{display:flex;align-items:center;gap:4px;padding:12px 16px;}
.typing-indicator span{display:inline-block;width:7px;height:7px;border-radius:50%;background:#CBD5E1;animation:typingBounce 1.2s infinite ease-in-out;}
.typing-indicator span:nth-child(2){animation-delay:.2s;}
.typing-indicator span:nth-child(3){animation-delay:.4s;}
@keyframes typingBounce{0%,60%,100%{transform:translateY(0);}30%{transform:translateY(-7px);}}

/* ── Back Top / Notif ───────────────────────── */
#back-top{position:fixed;bottom:86px;right:28px;width:38px;height:38px;background:var(--bg);border:1px solid var(--border);border-radius:8px;display:none;align-items:center;justify-content:center;cursor:pointer;color:var(--slate);z-index:998;transition:.2s;}
#back-top.show{display:flex;}
#back-top:hover{background:var(--navy-mid);color:#fff;}
.notif{position:fixed;top:78px;right:24px;background:#fff;border:1px solid var(--border);border-radius:11px;padding:13px 17px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:11px;font-size:14px;transform:translateX(130%);transition:.32s;z-index:9000;max-width:290px;}
.notif.show{transform:none;}
.notif i{color:var(--green);font-size:17px;}
.notif.notif-error{border-color:#fca5a5;background:#fff5f5;}
.notif.notif-error i{color:var(--red);}

/* ═══════════════════════════════════════════════
   PAGE INNER — Shared
═══════════════════════════════════════════════ */
.page-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);padding:100px 0 80px;color:#fff;}
.page-hero-sm{padding:80px 0 60px;}
.page-hero-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.page-hero-text{max-width:640px;}
.page-hero-content{color:#fff;}
.page-hero-content h1{font-size:clamp(28px,4vw,46px);font-weight:800;line-height:1.15;margin-bottom:18px;color:#fff;}
.page-hero-content h1 span{color:#7DD3FC;}
.page-hero-content p{font-size:17px;color:rgba(255,255,255,.78);margin-bottom:28px;max-width:500px;}
.page-hero-text h1{font-size:clamp(28px,4vw,46px);font-weight:800;line-height:1.15;margin-bottom:18px;color:#fff;}
.page-hero-text h1 span{color:#7DD3FC;}
.page-hero-text p{font-size:17px;color:rgba(255,255,255,.78);max-width:560px;}
.page-hero-cards{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.feat-card-mini{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:18px;display:flex;align-items:center;gap:14px;backdrop-filter:blur(6px);}
.feat-card-mini-icon{width:40px;height:40px;background:rgba(125,211,252,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#7DD3FC;font-size:18px;flex-shrink:0;}
.feat-card-mini-title{font-size:14px;font-weight:600;color:#fff;}
.feat-card-mini-sub{font-size:12px;color:rgba(255,255,255,.55);}
@media(max-width:860px){.page-hero-inner{grid-template-columns:1fr;}.page-hero-cards{display:none;}}

/* ── Service list inside cards ──────────────── */
.svc-list{margin-top:12px;display:flex;flex-direction:column;gap:6px;}
.svc-list li{font-size:14px;color:var(--slate);display:flex;align-items:flex-start;gap:8px;}
.svc-list li::before{content:"·";color:var(--blue);font-weight:700;flex-shrink:0;}
.btn-sm{padding:8px 16px;font-size:13px;}
.btn-lg{padding:14px 32px;font-size:16px;}
.w-full{width:100%;}

/* ══════════════════════════════════════════════
   SOFTWARE PAGE
══════════════════════════════════════════════ */
.sw-block{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-bottom:80px;}
.sw-block-reverse{direction:rtl;}
.sw-block-reverse > *{direction:ltr;}
.sw-block-badge{display:inline-block;padding:4px 12px;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;}
.sw-erp{background:#EBF3FB;color:var(--navy-mid);}
.sw-crm{background:#E6F5F0;color:var(--green);}
.sw-tpv{background:#FEF3C7;color:#92400E;}
.sw-block-info h3{font-size:26px;font-weight:700;color:var(--navy);margin-bottom:12px;}
.sw-block-info p{color:var(--slate);margin-bottom:18px;}
.sw-features{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.sw-features li{display:flex;align-items:center;gap:10px;font-size:15px;color:var(--text);}
.sw-features li i{color:var(--green);flex-shrink:0;}
/* CRM Mock */
.crm-mock{background:#0F2A4A;border-radius:14px;padding:20px;color:#fff;min-height:240px;}
.crm-mock .sw-features li{color:#fff;}
.crm-header{font-size:13px;font-weight:600;margin-bottom:16px;color:rgba(255,255,255,.8);}
.crm-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.crm-col-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.4);margin-bottom:8px;}
.crm-card{background:rgba(255,255,255,.08);border-radius:8px;padding:10px 12px;margin-bottom:8px;border-left:3px solid rgba(125,211,252,.4);}
.crm-card.hot{border-left-color:#F59E0B;}
.crm-card.won{border-left-color:#22C55E;}
.crm-company{font-size:13px;font-weight:500;color:#fff;}
.crm-val{font-size:11px;color:rgba(255,255,255,.5);margin-top:3px;}
/* TPV Mock */
.tpv-mock{background:#0F2A4A;border-radius:14px;padding:20px;color:#fff;}
.tpv-header{font-size:13px;font-weight:600;margin-bottom:14px;color:rgba(255,255,255,.8);}
.tpv-products{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.tpv-prod{display:flex;justify-content:space-between;padding:8px 12px;border-radius:7px;background:rgba(255,255,255,.07);font-size:13px;cursor:pointer;}
.tpv-prod span{font-weight:600;color:#7DD3FC;}
.tpv-prod.active{background:rgba(125,211,252,.15);border:1px solid rgba(125,211,252,.3);}
.tpv-total{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;margin-bottom:12px;}
.tpv-total-row{display:flex;justify-content:space-between;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:4px;}
.tpv-grand{color:#fff;font-size:16px;font-weight:700;}
.tpv-btns{display:grid;grid-template-columns:1fr 1fr;gap:8px;}
.tpv-btn{padding:10px;border-radius:8px;text-align:center;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;}
.tpv-cash{background:#22C55E;color:#fff;}
.tpv-card{background:#3B82F6;color:#fff;}
@media(max-width:860px){.sw-block{grid-template-columns:1fr;}.sw-block-reverse{direction:ltr;}}

/* ── Software highlight banner ──────────────── */
.sw-highlight-banner{display:grid;grid-template-columns:1fr 340px;gap:56px;align-items:center;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:20px;padding:48px 52px;}
.sw-highlight-badge{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;background:rgba(255,255,255,.12);border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-bottom:14px;}
.sw-highlight-left h2{font-size:clamp(22px,3vw,32px);font-weight:800;color:#fff;margin-bottom:12px;line-height:1.2;}
.sw-highlight-left p{font-size:15px;color:rgba(255,255,255,.72);margin-bottom:18px;line-height:1.65;}
.sw-highlight-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.sw-highlight-list li{display:flex;align-items:center;gap:10px;font-size:14px;color:rgba(255,255,255,.85);}
.sw-highlight-list li i{color:#5EEAD4;flex-shrink:0;}
.sw-highlight-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.sw-mini-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:13px;font-weight:600;color:rgba(255,255,255,.85);text-align:center;transition:.2s;}
.sw-mini-card:hover{background:rgba(255,255,255,.18);}
.sw-mini-card i{font-size:26px;color:#7DD3FC;}
.sw-highlight-banner-single{grid-template-columns:1fr;}


/* ══════════════════════════════════════════════
   SERVICIOS PAGE — Pricing
══════════════════════════════════════════════ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start;}
.price-card{background:#fff;border:2px solid var(--border);border-radius:16px;padding:32px 28px;position:relative;}
.price-featured{border-color:var(--navy-mid);box-shadow:var(--shadow-lg);}
.price-badge-top{position:absolute;top:-14px;left:50%;transform:translateX(-50%);background:var(--navy-mid);color:#fff;padding:4px 16px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap;}
.price-tier{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.price-amount{font-size:28px;font-weight:800;color:var(--navy-mid);margin-bottom:4px;}
.price-amount span{font-size:14px;font-weight:400;color:var(--slate);}
.price-desc{font-size:13px;color:var(--slate);margin-bottom:24px;}
.price-features{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;}
.price-features li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text);}
.price-features li i.fa-check{color:var(--green);flex-shrink:0;margin-top:2px;}
.price-features li i.fa-xmark{color:#CBD5E1;flex-shrink:0;margin-top:2px;}
.price-features li.disabled{color:var(--slate);}
@media(max-width:860px){.pricing-grid{grid-template-columns:1fr;max-width:400px;margin:0 auto;}}

/* ══════════════════════════════════════════════
   SOPORTE PAGE
══════════════════════════════════════════════ */
.support-options{display:flex;gap:12px;margin-bottom:40px;flex-wrap:wrap;}
.support-opt{padding:14px 24px;border-radius:10px;border:2px solid var(--border);background:#fff;cursor:pointer;display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;color:var(--slate);transition:.15s;}
.support-opt:hover{border-color:var(--navy-mid);color:var(--navy-mid);}
.support-opt-active{border-color:var(--navy-mid);color:var(--navy-mid);background:var(--blue-lt);}
.support-tab{width:100%;}
.support-tab.hidden{display:none;}
/* Form */
.form-wrap{background:#fff;border:1px solid var(--border);border-radius:16px;padding:36px;max-width:800px;}
.portal-form-wrap{max-width:440px;margin:0 auto;}
.form-header{margin-bottom:28px;}
.form-header h3{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.form-header p{font-size:15px;color:var(--slate);}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.form-full{grid-column:1 / -1;}
.form-group label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:6px;}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:'Inter',sans-serif;color:var(--text);background:#fff;transition:.15s;outline:none;}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue);}
.form-group textarea{resize:vertical;min-height:110px;}
.file-drop{border:2px dashed var(--border);border-radius:10px;padding:28px;text-align:center;cursor:pointer;transition:.15s;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--slate);}
.file-drop:hover{border-color:var(--blue);background:var(--blue-lt);}
.file-drop i{font-size:28px;color:var(--navy-mid);}
.file-sub{font-size:12px;color:var(--slate);}
.form-footer{display:flex;align-items:center;gap:20px;margin-top:24px;flex-wrap:wrap;}
.form-note{font-size:13px;color:var(--slate);display:flex;align-items:center;gap:6px;}
.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;color:var(--slate);}
.checkbox-label input{width:auto;}
.checkbox-label a{color:var(--blue);text-decoration:underline;}
/* QR Seguimiento */
.qr-search{margin-bottom:24px;}
.qr-input-row{display:flex;gap:12px;max-width:500px;}
.qr-input-row input{flex:1;padding:12px 16px;border:1.5px solid var(--border);border-radius:8px;font-size:15px;font-family:'Inter',sans-serif;outline:none;}
.qr-input-row input:focus{border-color:var(--blue);}
.qr-result{margin-top:24px;}
.qr-result.hidden{display:none;}
.ticket-status-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:28px;}
.ticket-status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
.ticket-code{font-size:18px;font-weight:700;color:var(--navy);font-family:'Poppins',sans-serif;}
.ticket-status-badge{padding:5px 14px;border-radius:20px;font-size:13px;font-weight:600;}
.status-open{background:#FEF3C7;color:#92400E;}
.status-progress{background:#EBF3FB;color:var(--navy-mid);}
.status-closed{background:var(--green-lt);color:var(--green);}
.status-error{background:#FEE2E2;color:#B91C1C;}
.ticket-details{display:flex;flex-direction:column;gap:8px;margin-bottom:24px;}
.td-row{display:flex;gap:12px;font-size:14px;}.td-row span{color:var(--slate);min-width:80px;}
.ticket-timeline{display:flex;gap:0;overflow-x:auto;}
.tl-step{display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:90px;}
.tl-dot{width:16px;height:16px;border-radius:50%;background:var(--border);border:3px solid #fff;box-shadow:0 0 0 2px var(--border);flex-shrink:0;z-index:1;}
.tl-step.tl-done .tl-dot{background:var(--green);box-shadow:0 0 0 2px var(--green-lt);}
.tl-step.active .tl-dot{background:var(--navy-mid);box-shadow:0 0 0 2px var(--blue-lt);}
.tl-label{font-size:11px;font-weight:600;color:var(--navy);text-align:center;}
.tl-date{font-size:10px;color:var(--slate);text-align:center;}
.qr-demo-note{margin-top:24px;padding:14px 18px;background:var(--blue-lt);border-radius:10px;font-size:14px;color:var(--slate);display:flex;align-items:center;gap:10px;}
.qr-demo-note i{color:var(--navy-mid);}
/* FAQ */
.faq-wrap{max-width:740px;}
.faq-item{border:1px solid var(--border);border-radius:12px;margin-bottom:12px;overflow:hidden;}
.faq-q{width:100%;background:#fff;border:none;padding:18px 22px;text-align:left;font-size:15px;font-weight:600;color:var(--navy);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:'Inter',sans-serif;}
.faq-q i{color:var(--slate);transition:.25s;flex-shrink:0;}
.faq-item.open .faq-q i{transform:rotate(180deg);}
.faq-a{display:none;padding:0 22px 18px;}
.faq-a p{font-size:14px;color:var(--slate);line-height:1.7;}
.faq-item.open .faq-a{display:block;}
/* Contact quick */
.contact-quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.contact-quick-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:28px;text-align:center;}
.contact-quick-icon{font-size:32px;color:var(--navy-mid);margin-bottom:12px;}
.contact-quick-card h4{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.contact-quick-card p{font-size:14px;color:var(--slate);margin-bottom:16px;}
.contact-quick-hours{font-size:12px;color:var(--slate);margin-top:10px;display:block;}
@media(max-width:860px){.form-grid{grid-template-columns:1fr;}.contact-quick-grid{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════════
   CONTACTO PAGE
══════════════════════════════════════════════ */
.contact-layout{display:grid;grid-template-columns:1fr 400px;gap:48px;align-items:start;}
.contact-layout-single{grid-template-columns:1fr;max-width:760px;margin:0 auto;}
.contact-form-side .form-wrap{max-width:100%;}
.contact-info-block{background:#fff;border:1px solid var(--border);border-radius:16px;padding:28px;margin-bottom:20px;}
.contact-info-block h3{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:20px;}
.contact-item{display:flex;gap:16px;margin-bottom:20px;}
.contact-item:last-child{margin-bottom:0;}
.contact-item-icon{width:42px;height:42px;background:var(--blue-lt);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--navy-mid);font-size:17px;flex-shrink:0;}
.contact-item-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);margin-bottom:3px;}
.contact-item-value{font-size:15px;font-weight:600;color:var(--navy);}
.contact-item-sub{font-size:12px;color:var(--slate);margin-top:2px;}
.consult-box{background:linear-gradient(135deg,var(--navy),var(--navy-mid));border-radius:14px;padding:24px;text-align:center;color:#fff;margin-bottom:20px;}
.consult-icon{font-size:30px;margin-bottom:12px;color:#7DD3FC;}
.consult-box h4{font-size:16px;font-weight:700;margin-bottom:8px;}
.consult-box p{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:16px;}
.contact-socials{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;text-align:center;}
.contact-socials-title{font-size:13px;font-weight:600;color:var(--navy);margin-bottom:14px;}
.socials-row{display:flex;justify-content:center;gap:10px;}
.social-btn{width:38px;height:38px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--slate);transition:.15s;font-size:15px;}
.social-btn:hover{background:var(--navy-mid);color:#fff;border-color:var(--navy-mid);}
.map-placeholder{background:var(--blue-lt);border-radius:16px;height:280px;display:flex;align-items:center;justify-content:center;}
.map-inner{text-align:center;}
.map-inner i{font-size:40px;color:var(--navy-mid);margin-bottom:12px;}
.map-inner h4{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.map-inner p{font-size:14px;color:var(--slate);margin-bottom:16px;}
@media(max-width:940px){.contact-layout{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════════
   CLIENTES PAGE — Portal
══════════════════════════════════════════════ */
.portal-avatar{width:60px;height:60px;background:var(--blue-lt);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;color:var(--navy-mid);margin:0 auto 14px;}
.portal-links{display:flex;justify-content:center;gap:10px;margin-top:16px;font-size:13px;}
.portal-links a{color:var(--blue);}
.portal-demo-note{margin-top:14px;padding:12px 16px;background:var(--blue-lt);border-radius:8px;font-size:13px;color:var(--slate);display:flex;align-items:center;gap:8px;}
.portal-demo-note i{color:var(--navy-mid);}
.portal-dashboard.hidden,.portal-login.hidden,.hidden{display:none!important;}

/* ── Portal: Login error ── */
.login-error{background:#FEF2F2;border:1px solid #FECACA;color:#B91C1C;border-radius:8px;padding:10px 14px;font-size:13px;margin-bottom:14px;display:flex;align-items:center;gap:8px;}

/* ── Portal Modal (ticket detalle) ── */
.p-modal-overlay{position:fixed;inset:0;background:rgba(15,26,48,.55);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px;overflow-y:auto;}
.p-modal-overlay.hidden{display:none!important;}
.p-modal{background:#fff;border-radius:18px;width:100%;max-width:700px;box-shadow:0 24px 60px rgba(0,0,0,.22);display:flex;flex-direction:column;max-height:90vh;}
.p-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);flex-shrink:0;}
.p-modal-title-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.p-modal-close{background:none;border:none;font-size:18px;color:var(--slate);cursor:pointer;padding:4px 8px;border-radius:6px;transition:.15s;}
.p-modal-close:hover{background:var(--bg);color:var(--navy);}
.p-modal-body{padding:24px;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:20px;}

/* ── Ticket Detail Info ── */
.dtl-grid{display:flex;flex-wrap:wrap;gap:6px 24px;margin-bottom:14px;}
.dtl-row{display:flex;align-items:center;gap:8px;font-size:13px;}.dtl-row span{color:var(--slate);min-width:70px;}
.dtl-asunto{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:10px;}
.dtl-descripcion{font-size:14px;color:var(--text);line-height:1.7;background:var(--bg);border-radius:10px;padding:14px 16px;}

/* ── Mensaje Thread ── */
.msg-thread-header{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--slate);display:flex;align-items:center;gap:7px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.msg-thread{display:flex;flex-direction:column;gap:12px;min-height:60px;max-height:320px;overflow-y:auto;padding:4px 0;}
.msg-empty{font-size:14px;color:var(--slate);text-align:center;padding:18px 0;}
.msg-bubble{padding:12px 16px;border-radius:12px;max-width:88%;display:flex;flex-direction:column;gap:6px;font-size:14px;line-height:1.6;}
.msg-bubble.from-admin{background:var(--bg);border:1px solid var(--border);border-radius:12px 12px 12px 2px;align-self:flex-start;}
.msg-bubble.from-cliente{background:var(--navy-mid);color:#fff;border-radius:12px 12px 2px 12px;align-self:flex-end;}
.msg-bubble.from-cliente .msg-meta,.msg-bubble.from-cliente .msg-fecha{color:rgba(255,255,255,.7);}
.msg-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.msg-autor{font-weight:600;font-size:12px;}
.msg-fecha{font-size:11px;color:var(--slate);}
.msg-text{white-space:pre-wrap;}
.msg-file-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--navy-mid);text-decoration:none;padding:6px 12px;border-radius:8px;background:var(--blue-lt);border:1px solid rgba(29,78,137,.15);margin-top:4px;transition:.15s;}
.msg-file-link:hover{background:#DBEAFE;color:var(--navy);}
.msg-bubble.from-cliente .msg-file-link{background:rgba(255,255,255,.18);color:#fff;border-color:rgba(255,255,255,.25);}
.msg-bubble.from-cliente .msg-file-link:hover{background:rgba(255,255,255,.28);}

/* ── Reply Form ── */
.msg-reply-wrap{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:18px;display:flex;flex-direction:column;gap:12px;}
.msg-reply-header{font-size:13px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:7px;}
.msg-reply-wrap textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:12px 14px;font-size:14px;font-family:inherit;resize:vertical;transition:.15s;background:#fff;}
.msg-reply-wrap textarea:focus{outline:none;border-color:var(--navy-mid);}
.msg-file-zone{border:2px dashed var(--border);border-radius:9px;padding:12px 16px;display:flex;align-items:center;gap:10px;font-size:13px;color:var(--slate);cursor:pointer;transition:.15s;}
.msg-file-zone:hover,.msg-file-zone.has-file{border-color:var(--navy-mid);color:var(--navy);background:var(--blue-lt);}
.msg-file-zone i{font-size:16px;color:var(--navy-mid);}
.msg-reply-actions{display:flex;justify-content:space-between;align-items:center;gap:10px;}

/* ── Proyectos ── */
.proj-cards{display:flex;flex-direction:column;gap:16px;}
.proj-card{border:1px solid var(--border);border-radius:13px;padding:20px;}
.proj-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px;}
.proj-nombre{font-size:16px;font-weight:700;color:var(--navy);}
.proj-tipo{font-size:12px;color:var(--slate);margin-top:2px;}
.proj-fase{font-size:13px;color:var(--slate);margin-bottom:12px;display:flex;align-items:center;gap:6px;}
.proj-fase i{color:var(--navy-mid);}
.proj-progress-wrap{margin-bottom:10px;}
.proj-progress-labels{display:flex;justify-content:space-between;font-size:12px;color:var(--slate);margin-bottom:6px;}
.proj-progress{background:var(--border);border-radius:20px;height:8px;overflow:hidden;}
.proj-progress-bar{height:100%;background:linear-gradient(90deg,var(--navy-mid),var(--blue));border-radius:20px;transition:width .4s ease;}
.proj-eta{font-size:13px;color:var(--slate);display:flex;align-items:center;gap:6px;}

@media(max-width:600px){
  .p-modal{max-height:100vh;border-radius:0;}
  .p-modal-overlay{padding:0;}
  .msg-bubble{max-width:96%;}
  .msg-reply-actions{flex-direction:column;align-items:stretch;}
  .msg-reply-actions .btn{justify-content:center;}
}
.dashboard-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;}
.dashboard-header h2{font-size:24px;font-weight:700;color:var(--navy);}
.dashboard-header h2 span{color:var(--navy-mid);}
.dashboard-header p{font-size:14px;color:var(--slate);}
.dash-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px;}
.dash-kpi-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px;display:flex;align-items:center;gap:16px;}
.dash-kpi-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;}
.ic-blue{background:var(--blue-lt);color:var(--navy-mid);}
.ic-green{background:var(--green-lt);color:var(--green);}
.ic-slate{background:#F1F5F9;color:var(--slate);}
.dash-kpi-val{font-size:28px;font-weight:800;color:var(--navy);line-height:1;}
.dash-kpi-label{font-size:13px;color:var(--slate);margin-top:3px;}
.dash-section{background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px;margin-bottom:24px;}
.dash-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.dash-section-header h4{font-size:16px;font-weight:700;color:var(--navy);display:flex;align-items:center;gap:8px;}
.dash-table-wrap{overflow-x:auto;}
.dash-table{width:100%;border-collapse:collapse;font-size:14px;}
.dash-table th{padding:10px 14px;text-align:left;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--slate);border-bottom:2px solid var(--border);}
.dash-table td{padding:12px 14px;border-bottom:1px solid var(--border);color:var(--text);}
.dash-table tr:last-child td{border-bottom:none;}
.ticket-code-sm{font-family:monospace;background:var(--bg);padding:3px 8px;border-radius:5px;font-size:12px;color:var(--navy-mid);}
.status-pill{padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600;}
/* repair card */
.repair-cards{display:flex;flex-direction:column;gap:14px;}
.repair-card{border:1px solid var(--border);border-radius:12px;padding:18px;}
.repair-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.repair-device{font-size:14px;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:16px;}
.repair-progress{display:flex;gap:0;overflow-x:auto;margin-bottom:12px;}
.repair-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex:1;min-width:80px;font-size:11px;color:var(--slate);text-align:center;}
.repair-step i{font-size:16px;}
.repair-step.done{color:var(--green);}
.repair-step.active{color:var(--navy-mid);font-weight:600;}
.repair-eta{font-size:13px;color:var(--slate);display:flex;align-items:center;gap:6px;}
.btn-link{font-size:13px;color:var(--blue);display:flex;align-items:center;gap:4px;}
@media(max-width:860px){.dash-kpi-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:540px){.dash-kpi-grid{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════════
   PERFIL PROFESIONAL
══════════════════════════════════════════════ */
.profile-grid{display:grid;grid-template-columns:340px 1fr;gap:48px;align-items:start;margin-bottom:48px;}
.profile-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:32px;box-shadow:var(--shadow);position:sticky;top:86px;}
.profile-avatar{width:72px;height:72px;border-radius:16px;background:linear-gradient(135deg,var(--navy-mid),var(--blue));color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-size:24px;font-weight:700;margin-bottom:18px;}
.profile-badge{display:inline-block;padding:5px 12px;border-radius:6px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--blue-lt);color:var(--navy-mid);margin-bottom:12px;line-height:1.4;}
.profile-name{font-size:26px;font-weight:700;color:var(--navy);margin-bottom:12px;}
.profile-bio{font-size:15px;color:var(--slate);line-height:1.7;margin-bottom:22px;}
.profile-contacts{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.profile-contact{display:flex;align-items:center;gap:14px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);transition:.15s;}
.profile-contact:hover{border-color:var(--blue);background:var(--blue-lt);}
.profile-contact i{width:36px;height:36px;border-radius:8px;background:var(--blue-lt);color:var(--navy-mid);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0;}
.profile-contact span{display:flex;flex-direction:column;font-size:14px;font-weight:600;color:var(--navy);}
.profile-contact span small{font-size:11px;font-weight:500;color:var(--slate);text-transform:uppercase;letter-spacing:.04em;}
.profile-card .btn{width:100%;justify-content:center;}
.spec-list{display:flex;flex-direction:column;gap:20px;}
.spec-card{display:flex;gap:20px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:24px;transition:.2s;}
.spec-card:hover{border-color:var(--blue);box-shadow:var(--shadow);}
.spec-num{font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;color:var(--navy-mid);background:var(--blue-lt);width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;letter-spacing:.02em;}
.spec-body{flex:1;}
.spec-icon{width:44px;height:44px;border-radius:10px;background:var(--blue-lt);color:var(--navy-mid);display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:12px;}
.spec-body h3{font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px;}
.spec-body p{font-size:14px;color:var(--slate);line-height:1.7;}
.profile-quote{background:var(--navy);color:#fff;border-radius:16px;padding:36px 40px;position:relative;overflow:hidden;}
.profile-quote::before{content:'';position:absolute;top:-40px;right:-40px;width:160px;height:160px;background:rgba(255,255,255,.04);border-radius:50%;}
.profile-quote>i{font-size:28px;color:rgba(255,255,255,.25);margin-bottom:14px;display:block;}
.profile-quote p{font-size:17px;line-height:1.75;color:rgba(255,255,255,.92);font-style:italic;max-width:900px;position:relative;}
.profile-quote .quote-author{display:block;margin-top:16px;font-size:14px;font-weight:600;color:#7DD3FC;font-style:normal;position:relative;}
.ft-contact{display:flex;flex-direction:column;gap:8px;margin-top:14px;}
.ft-contact a{display:flex;align-items:center;gap:8px;font-size:13px;color:rgba(255,255,255,.75);transition:.15s;}
.ft-contact a:hover{color:#fff;}
.ft-contact i{width:28px;color:#7DD3FC;}
@media(max-width:960px){
  .profile-grid{grid-template-columns:1fr;}
  .profile-card{position:static;}
}
@media(max-width:600px){
  .spec-card{flex-direction:column;gap:12px;}
  .spec-num{font-size:24px;}
  .profile-quote{padding:28px 24px;}
}

/* ══════════════════════════════════════════════
   HOME NAV + SERVICE DETAIL PAGES
══════════════════════════════════════════════ */
.home-nav-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.home-nav-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:26px;transition:.2s;display:block;}
.home-nav-card:hover{border-color:var(--blue);box-shadow:var(--shadow);transform:translateY(-2px);}
.home-nav-icon{width:48px;height:48px;border-radius:11px;background:var(--blue-lt);color:var(--navy-mid);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px;}
.home-nav-card h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.home-nav-card p{font-size:14px;color:var(--slate);margin-bottom:14px;line-height:1.6;}
.link-arrow{font-size:13px;font-weight:600;color:var(--navy-mid);display:inline-flex;align-items:center;gap:6px;}
.home-nav-card:hover .link-arrow{color:var(--blue);}
.service-detail-grid{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start;}
.service-detail-lead{font-size:17px;color:var(--text);line-height:1.75;margin-bottom:28px;}
.service-detail-main h3{font-size:20px;font-weight:700;color:var(--navy);margin-bottom:16px;}
.service-feature-list{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;}
.service-feature-list li{display:flex;align-items:flex-start;gap:10px;font-size:15px;color:var(--text);}
.service-feature-list li i{color:var(--green);margin-top:3px;flex-shrink:0;}
.service-detail-cta{display:flex;flex-wrap:wrap;gap:12px;}
.spec-card-link{text-decoration:none;color:inherit;cursor:pointer;}
.spec-card-link:hover{border-color:var(--blue);box-shadow:var(--shadow);}
.page-hero-sm .breadcrumb span{color:rgba(255,255,255,.55);}
@media(max-width:960px){
  .home-nav-grid{grid-template-columns:1fr 1fr;}
  .service-detail-grid{grid-template-columns:1fr;}
}
@media(max-width:560px){.home-nav-grid{grid-template-columns:1fr;}}
