/* ═══════════════════════════════════════════════
   CEB PALLEJÀ · ESTILS PRINCIPALS
   Paleta oficial Pantone:
   · Granate 202    #862633  rgb(134,38,51)
   · Blau Marí 2767 #13294B  rgb(19,41,75)
   · Ocre Or 728    #CDA470  rgb(205,164,112)
   · Blanc  #FFFFFF
   · Negre  #000000
═══════════════════════════════════════════════ */
:root{
  --red:#862633; --red-d:#5E1B24; --red-l:#A33040;
  --gold:#CDA470; --gold-d:#A6834A;
  --navy:#13294B; --navy-d:#0D1C33; --navy-l:#1C3660;
  --black:#080D16;
  --dark:#0D1828;
  --mid:#132238;
  --surface:#1A2E4A;
  --border:rgba(255,255,255,.08); --border2:rgba(255,255,255,.15);
  --text:#F2F2F2; --muted:#BDD0DE; --sub:#AABBC8;
  --radius:12px; --radius-sm:8px;
  --tr:.25s cubic-bezier(.4,0,.2,1);
  --shadow:0 8px 40px rgba(0,0,0,.6);
  --maxw:1140px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Barlow',sans-serif;background:var(--black);color:var(--text);line-height:1.7;overflow-x:hidden;}
::selection{background:var(--red);color:#fff;}
img{max-width:100%;height:auto;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}

.container{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
.section{padding:88px 0;}
.section-sm{padding:56px 0;}
@media(max-width:540px){.section{padding:56px 0;}.section-sm{padding:40px 0;}.container{padding:0 16px;}}

.tag{display:inline-block;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.title{font-family:'Bebas Neue',sans-serif;font-size:clamp(38px,6vw,68px);letter-spacing:2px;line-height:1;color:var(--text);}
.title span,.title-accent{color:var(--red);}
.subtitle{font-size:16px;color:var(--sub);line-height:1.75;max-width:560px;}
.red-line{display:block;width:44px;height:4px;background:var(--red);margin:16px 0 28px;border-radius:2px;}

.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 26px;border-radius:var(--radius-sm);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:14px;letter-spacing:2px;text-transform:uppercase;border:2px solid transparent;transition:all var(--tr);}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red);}
.btn-primary:hover{background:var(--red-l);border-color:var(--red-l);transform:translateY(-2px);box-shadow:0 6px 24px rgba(134,38,51,.45);}
.btn-outline{background:transparent;color:var(--text);border-color:var(--border2);}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);}
.btn-gold{background:var(--gold);color:#0D1828;border-color:var(--gold);}
.btn-gold:hover{background:var(--gold-d);transform:translateY(-2px);}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy);}
.btn-navy:hover{background:var(--navy-l);transform:translateY(-2px);}
.btn-sm{padding:9px 18px;font-size:12px;}

.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:all var(--tr);}
.card:hover{border-color:rgba(134,38,51,.35);transform:translateY(-4px);box-shadow:var(--shadow);}
.card-body{padding:22px;}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:background var(--tr),box-shadow var(--tr);}
.nav.scrolled{background:rgba(8,13,22,.97);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--border);}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;display:flex;align-items:center;height:68px;gap:8px;}
.nav-logo{display:flex;align-items:center;gap:11px;flex-shrink:0;margin-right:auto;}
.nav-logo img{width:42px;height:42px;border-radius:50%;border:2px solid var(--gold);}
.nav-logo-text{font-family:'Bebas Neue',sans-serif;font-size:19px;letter-spacing:2px;line-height:1;}
.nav-logo-sub{display:block;font-family:'Barlow Condensed',sans-serif;font-size:10px;font-weight:600;letter-spacing:2px;color:var(--gold);text-transform:uppercase;}
.nav-links{display:flex;align-items:center;gap:2px;}
.nav-links a{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--sub);padding:7px 11px;border-radius:6px;transition:all var(--tr);}
.nav-links a:hover,.nav-links a.active{color:var(--text);background:rgba(255,255,255,.07);}
.nav-links a.active{color:var(--gold);}
.nav-accident{background:var(--red) !important;color:#fff !important;border-radius:6px;}
.nav-accident:hover{background:var(--red-l) !important;}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:6px;background:none;border:none;margin-left:8px;}
.nav-burger span{display:block;width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s;}
.nav-mobile{display:none;position:fixed;inset:68px 0 0;background:var(--dark);padding:20px;flex-direction:column;gap:4px;overflow-y:auto;z-index:999;border-top:1px solid var(--border);}
.nav-mobile.open{display:flex;}
.nav-mobile a{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:20px;letter-spacing:2px;text-transform:uppercase;color:var(--sub);padding:11px 14px;border-radius:var(--radius-sm);border:1px solid transparent;transition:all .2s;}
.nav-mobile a:hover,.nav-mobile a.active{color:var(--text);border-color:var(--border);}
.nav-mobile a.active{color:var(--gold);}
.nav-mobile .nav-accident{background:rgba(134,38,51,.15) !important;border-color:rgba(134,38,51,.3) !important;color:var(--red) !important;}
@media(max-width:900px){.nav-links{display:none;}.nav-burger{display:flex;}}

/* HERO */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden;padding-top:68px;}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#080D16 0%,#1a0810 35%,#0D1828 70%,#080D16 100%);}
.hero-glow{position:absolute;top:-150px;right:-150px;width:500px;height:500px;background:radial-gradient(circle,rgba(134,38,51,.25) 0%,transparent 70%);pointer-events:none;}
.hero-glow2{position:absolute;bottom:-80px;left:-80px;width:350px;height:350px;background:radial-gradient(circle,rgba(205,164,112,.12) 0%,transparent 70%);pointer-events:none;}
.hero-glow3{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(19,41,75,.3) 0%,transparent 70%);pointer-events:none;}
.hero-senyera{position:absolute;top:0;right:0;display:flex;flex-direction:column;height:100%;width:7px;}
.hs{flex:1;}
.hs-g{background:var(--gold);}
.hs-r{background:var(--red);}
.hero-content{position:relative;z-index:1;padding:72px 0;}
.hero-eyebrow{display:flex;align-items:center;gap:10px;margin-bottom:24px;}
.hero-eyebrow-line{width:36px;height:2px;background:var(--red);}
.hero-founded{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:12px;letter-spacing:4px;text-transform:uppercase;color:var(--gold);}
.hero-title{font-family:'Bebas Neue',sans-serif;letter-spacing:3px;line-height:.9;margin-bottom:6px;}
.hero-line1{font-size:clamp(56px,9vw,120px);color:var(--text);}
.hero-line2{font-size:clamp(56px,9vw,120px);color:var(--red);}
.hero-line3{font-size:clamp(26px,4.5vw,58px);letter-spacing:6px;color:var(--text);opacity:.7;}
.hero-sub{font-size:17px;color:var(--sub);max-width:460px;margin:22px 0 36px;line-height:1.75;}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;}
.hero-stats{display:flex;gap:36px;margin-top:60px;padding-top:36px;border-top:1px solid var(--border);flex-wrap:wrap;}
.stat-num{font-family:'Bebas Neue',sans-serif;font-size:50px;letter-spacing:2px;line-height:1;color:var(--gold);}
.stat-lbl{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:2px;}

/* PAGE HEADER */
.page-hero{padding:120px 0 60px;background:linear-gradient(135deg,#080D16 0%,#1a0810 40%,#0D1828 70%,#080D16 100%);position:relative;overflow:hidden;}
.page-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(134,38,51,.18) 0%,transparent 70%);pointer-events:none;}
.page-hero::after{content:'';position:absolute;bottom:-80px;left:-80px;width:350px;height:350px;background:radial-gradient(circle,rgba(19,41,75,.25) 0%,transparent 70%);pointer-events:none;}
.page-hero .container{position:relative;z-index:1;}
.breadcrumb{display:flex;align-items:center;gap:8px;font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:16px;}
.breadcrumb a:hover{color:var(--gold);}
.breadcrumb-sep{color:var(--border2);}

/* GRIDS */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:900px){.grid-3{grid-template-columns:repeat(2,1fr);}.grid-4{grid-template-columns:repeat(2,1fr);}.grid-2{grid-template-columns:1fr;}}
@media(max-width:480px){.grid-3,.grid-4{grid-template-columns:1fr;}}

/* BADGES */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.5px;}
.badge-masc{background:rgba(19,41,75,.5);color:#7AAED6;border:1px solid rgba(19,41,75,.8);}
.badge-fem{background:rgba(134,38,51,.2);color:#E88899;border:1px solid rgba(134,38,51,.4);}
.badge-mix{background:rgba(205,164,112,.12);color:var(--gold);border:1px solid rgba(205,164,112,.3);}

/* FORMS */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;}
.form-label{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.form-label.req::after{content:" *";color:var(--red);}
.form-input,.form-select,.form-textarea{background:var(--mid);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:'Barlow',sans-serif;font-size:14px;padding:11px 14px;transition:border-color var(--tr);width:100%;}
.form-input:focus,.form-select:focus,.form-textarea:focus{outline:3px solid var(--red);outline-offset:0;border-color:var(--red);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--muted);}
.form-select{appearance:none;-webkit-appearance:none;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='%23888' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;}
.form-select option{background:var(--mid);}
.form-textarea{resize:vertical;min-height:90px;line-height:1.6;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}
.form-submit{width:100%;padding:14px;background:var(--red);border:none;border-radius:var(--radius-sm);color:#fff;font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:3px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:10px;transition:all var(--tr);margin-top:8px;}
.form-submit:hover{background:var(--red-l);transform:translateY(-1px);box-shadow:0 6px 24px rgba(134,38,51,.45);}

/* ALERTS */
.alert{border-radius:var(--radius);padding:18px 22px;display:flex;align-items:flex-start;gap:14px;}
.alert-red{background:rgba(134,38,51,.1);border:1px solid rgba(134,38,51,.3);}
.alert-gold{background:rgba(205,164,112,.08);border:1px solid rgba(205,164,112,.25);}
.alert-navy{background:rgba(19,41,75,.25);border:1px solid rgba(19,41,75,.5);}
.alert-icon{font-size:24px;flex-shrink:0;margin-top:2px;}
.alert-title{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:1px;color:var(--red);margin-bottom:4px;}
.alert-gold .alert-title{color:var(--gold);}
.alert-navy .alert-title{color:#7AAED6;}
.alert-body{font-size:14px;color:var(--sub);line-height:1.7;}
.alert-body a{color:var(--gold);}

/* FOOTER */
.footer{background:var(--navy-d);border-top:1px solid rgba(134,38,51,.25);padding:36px 0;}
.footer-inner{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;position:relative;}
.footer-logo{display:flex;align-items:center;gap:10px;}
.footer-logo img{width:34px;height:34px;border-radius:50%;border:1px solid var(--gold);}
.footer-brand{font-family:'Bebas Neue',sans-serif;font-size:17px;letter-spacing:2px;}
.footer-copy{font-size:12px;color:var(--muted);}
.footer-copy span{color:var(--gold);}
.footer-links{display:flex;gap:16px;flex-wrap:wrap;}
.footer-links a{font-size:12px;color:var(--muted);transition:color var(--tr);}
.footer-links a:hover{color:var(--text);}
.senyera{display:flex;flex-direction:row;gap:0;width:72px;height:16px;border-radius:3px;overflow:hidden;flex-shrink:0;}
.sf{flex:1;height:100%;}
.sf-g{background:var(--gold);}
.sf-r{background:var(--red);}
@media(max-width:600px){.footer-inner{flex-direction:column;text-align:center;}.footer-logo{justify-content:center;}}

/* DROPDOWN */
.has-sub{position:relative;}
.norm-toggle{color:var(--gold) !important;}
.sub-menu{display:none;position:absolute;top:100%;left:50%;transform:translateX(-50%);background:var(--dark);border:1px solid var(--border2);border-radius:var(--radius);min-width:240px;padding-top:6px;padding-left:8px;padding-right:8px;padding-bottom:8px;z-index:9999;box-shadow:0 12px 40px rgba(0,0,0,.6);}.sub-menu::before{content:"";position:absolute;top:-8px;left:0;right:0;height:8px;}
.has-sub:hover .sub-menu{display:block;}
.sub-link{display:flex;align-items:center;gap:8px;padding:9px 12px;border-radius:6px;font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:14px;color:var(--sub);transition:all var(--tr);}
.sub-link:hover{background:rgba(255,255,255,.06);color:var(--text);}
.sub-link::before{content:'›';color:var(--red);font-size:16px;}
.mob-norm-header{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);padding:14px 14px 6px;margin-top:8px;border-top:1px solid var(--border);}
.mob-sub{font-family:'Barlow Condensed',sans-serif;font-weight:600;font-size:17px;letter-spacing:1px;text-transform:uppercase;color:var(--sub);padding:9px 14px;border-radius:6px;transition:all .2s;display:block;}
.mob-sub:hover{color:var(--gold);}

/* ── WCAG AAA — Accessibility additions ──────────────────────────────────── */

/* Skip link — visible en focus (WCAG 2.4.1 + 2.4.12) */
.skip-link{position:absolute;top:-120px;left:16px;z-index:9999;background:var(--gold);color:#000;
  padding:10px 20px;border-radius:0 0 8px 8px;font-weight:700;font-size:14px;letter-spacing:.5px;
  text-decoration:none;transition:top .2s;border:3px solid #000;}
.skip-link:focus{top:0;outline:3px solid #000;outline-offset:2px;}

/* Focus global — 3px anell or (WCAG 2.4.12 AAA / 1.4.6) */
:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px;}
a:focus-visible,button:focus-visible{outline:3px solid var(--gold);outline-offset:3px;}

/* Mides mínimes 44×44px (WCAG 2.5.8) */
.btn{min-height:44px;}
.nav-links a{min-height:44px;display:inline-flex;align-items:center;}
.form-input,.form-select,.form-textarea{min-height:44px;}
.form-submit{min-height:44px;}
.nav-mobile a{min-height:44px;display:flex;align-items:center;}

/* Interlineat 1.7 (WCAG 1.4.8 AAA) */
.alert-body,.doc-p,.bodyP{line-height:1.7;}
p{line-height:1.7;}
