@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  --midnight:#071425;
  --midnight-2:#0d203a;
  --navy:#10233d;
  --ink:#15233a;
  --text:#516070;
  --muted:#7a8794;
  --ivory:#fbf6ec;
  --ivory-2:#f3eadc;
  --paper:#fffaf1;
  --white:#ffffff;
  --gold:#b98905;
  --gold-2:#d8b35b;
  --blue:#0d5b8f;
  --line:rgba(17,34,57,.12);
  --line-2:rgba(255,255,255,.14);
  --shadow:0 24px 70px rgba(8,20,38,.14);
  --shadow-strong:0 38px 110px rgba(8,20,38,.28);
  --radius:30px;
  --radius-sm:18px;
  --container:1180px;
  --ease:cubic-bezier(.19,1,.22,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:110px}
body{
  margin:0;
  min-width:320px;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 9%, rgba(184,137,5,.12), transparent 24rem),
    radial-gradient(circle at 96% 0%, rgba(13,91,143,.10), transparent 30rem),
    linear-gradient(180deg,#fffaf1 0%,#f7f1e8 52%,#f6f8fb 100%);
  font-family:Manrope,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  font-size:16px;
  line-height:1.75;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  z-index:-4;
  pointer-events:none;
  opacity:.45;
  background-image:
    linear-gradient(rgba(7,20,37,.045) 1px, transparent 1px),
    linear-gradient(90deg,rgba(7,20,37,.045) 1px, transparent 1px);
  background-size:72px 72px;
  mask-image:linear-gradient(to bottom, transparent 0, #000 10%, #000 75%, transparent 100%);
}
body::after{
  content:"";
  position:fixed;
  inset:auto -12% -34% -12%;
  height:42vh;
  z-index:-3;
  pointer-events:none;
  background:radial-gradient(closest-side, rgba(184,137,5,.16), transparent 72%);
  filter:blur(20px);
}
img{max-width:100%;display:block}
a{color:inherit}
::selection{background:var(--gold);color:#fff}

.container{width:min(var(--container),calc(100% - 48px));margin-inline:auto}
.narrow{max-width:800px}
.center{text-align:center}

h1,h2,h3{color:var(--ink);margin:0 0 18px;line-height:.98;letter-spacing:-.035em;font-family:"Instrument Serif", Georgia, serif;font-weight:400}
h1{font-size:clamp(4rem,8.5vw,8.8rem)}
h2{font-size:clamp(2.9rem,5.4vw,5.8rem)}
h3{font-size:clamp(1.5rem,2.2vw,2.3rem);line-height:1.05}
p{margin:0 0 16px}
strong{color:var(--ink);font-weight:800}

.skip-link{position:absolute;left:16px;top:-80px;z-index:3000;padding:12px 16px;border-radius:999px;background:var(--gold);color:#fff;text-decoration:none;box-shadow:var(--shadow)}
.skip-link:focus{top:16px}
.scroll-progress{position:fixed;left:0;top:0;height:3px;width:0;z-index:3200;background:linear-gradient(90deg,var(--gold),#f7d889,#1b75af);box-shadow:0 0 18px rgba(184,137,5,.45)}
.ambient-cursor{position:fixed;z-index:-2;left:0;top:0;width:360px;height:360px;border-radius:50%;pointer-events:none;opacity:0;background:
  radial-gradient(circle at 50% 50%,rgba(255,246,221,.20) 0 8%,rgba(216,179,91,.12) 22%,rgba(13,91,143,.055) 46%,transparent 74%);
transform:translate3d(calc(var(--mx,50vw) - 180px),calc(var(--my,50vh) - 180px),0);filter:blur(28px);transition:opacity .45s ease;will-change:transform,opacity}
.ambient-cursor::before{content:"";position:absolute;inset:38%;border-radius:50%;background:rgba(216,179,91,.18);filter:blur(18px);opacity:.55}
body.has-pointer .ambient-cursor{opacity:.72}

.site-header{position:sticky;top:0;z-index:2200;padding:14px 0;background:linear-gradient(180deg,rgba(255,250,241,.96),rgba(255,250,241,.58) 72%,transparent);backdrop-filter:blur(16px);transition:padding .35s var(--ease),background .35s var(--ease)}
.site-header.scrolled{padding:10px 0;background:linear-gradient(180deg,rgba(255,250,241,.98),rgba(255,250,241,.82))}
.nav-shell{min-height:76px;display:flex;align-items:center;gap:20px;padding:10px 14px 10px 18px;border:1px solid rgba(21,35,58,.10);border-radius:28px;background:rgba(255,255,255,.72);box-shadow:0 18px 58px rgba(7,20,37,.08);backdrop-filter:blur(22px) saturate(1.25)}
.brand{display:flex;align-items:center;flex:0 0 auto;text-decoration:none;transition:transform .3s var(--ease),opacity .3s var(--ease)}
.brand:hover{transform:translateY(-2px);opacity:.9}
.brand img{height:46px;width:auto}
.nav{display:flex;justify-content:center;align-items:center;gap:2px;flex:1}
.nav a{position:relative;display:inline-flex;align-items:center;min-height:38px;padding:8px 13px;border-radius:999px;color:var(--ink);font-size:13px;font-weight:800;line-height:1;text-decoration:none;letter-spacing:-.02em;transition:color .22s var(--ease),transform .22s var(--ease),background .22s var(--ease)}
.nav a::before{content:"";position:absolute;left:13px;right:13px;bottom:3px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);transform:scaleX(0);transform-origin:center;transition:transform .28s var(--ease)}
.nav a:hover,.nav a.active{color:var(--gold);background:rgba(184,137,5,.08);transform:translateY(-1px)}
.nav a:hover::before,.nav a.active::before{transform:scaleX(1)}
.header-actions{display:flex;align-items:center;gap:10px}
.icon-link{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:var(--ink);color:#fff;font:800 12px/1 Manrope,sans-serif;text-decoration:none;box-shadow:0 12px 32px rgba(7,20,37,.18);transition:transform .28s var(--ease),background .28s var(--ease)}
.icon-link:hover{background:var(--gold);transform:translateY(-3px) rotate(-6deg)}
.nav-toggle{display:none;margin-left:auto;width:48px;height:48px;border:1px solid var(--line);border-radius:18px;background:#fff;cursor:pointer}
.nav-toggle span{display:block;width:23px;height:2px;margin:6px auto;border-radius:999px;background:var(--ink);transition:transform .25s var(--ease),opacity .25s var(--ease)}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

.btn{position:relative;isolation:isolate;display:inline-flex;align-items:center;justify-content:center;gap:10px;min-height:48px;padding:13px 22px;border:0;border-radius:999px;font:800 13px/1 Manrope,sans-serif;text-decoration:none;cursor:pointer;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease),color .3s var(--ease)}
.btn::after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(110deg,transparent 0%,rgba(255,255,255,.33) 38%,transparent 72%);transform:translateX(-130%) skewX(-18deg);transition:transform .8s var(--ease)}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 45px rgba(7,20,37,.20)}
.btn:hover::after{transform:translateX(130%) skewX(-18deg)}
.btn-sm{min-height:40px;padding:11px 16px;font-size:12px}
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff;box-shadow:0 16px 38px rgba(184,137,5,.25)}
.btn-blue{background:linear-gradient(135deg,#133b61,#0d5b8f);color:#fff;box-shadow:0 16px 38px rgba(13,91,143,.22)}
.btn-outline{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.28)}

.section{position:relative;padding:132px 0}
.section.soft{background:linear-gradient(180deg,rgba(255,255,255,.42),rgba(255,255,255,.20));border-top:1px solid rgba(21,35,58,.06);border-bottom:1px solid rgba(21,35,58,.06)}
.section-title{text-align:center;margin-bottom:56px}
.section-title.left{text-align:left;margin-bottom:34px}
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin:0 0 14px;color:var(--gold);font-size:12px;font-weight:900;letter-spacing:.18em;text-transform:uppercase}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.55}
.section-title p:not(.eyebrow),.hero-content>p,.page-hero p,.article-head p{font-size:1.06rem;color:#647181;max-width:720px}
.section-title p:not(.eyebrow),.page-hero p{margin-inline:auto}

.hero{min-height:calc(100vh - 110px);display:grid;align-items:center;padding:112px 0 126px;margin-top:-104px;overflow:hidden;background:
  radial-gradient(circle at 78% 30%,rgba(216,179,91,.22),transparent 21rem),
  radial-gradient(circle at 12% 80%,rgba(13,91,143,.32),transparent 30rem),
  linear-gradient(135deg,#071425 0%,#0d203a 48%,#152b4a 100%);}
.hero::before{content:"PD";position:absolute;right:-3vw;bottom:-4vw;color:rgba(255,255,255,.035);font-family:"Instrument Serif",Georgia,serif;font-size:clamp(16rem,34vw,34rem);line-height:.75;letter-spacing:-.12em;pointer-events:none}
.hero::after{content:"";position:absolute;inset:88px 5vw auto auto;width:clamp(340px,42vw,680px);height:clamp(340px,42vw,680px);border:1px solid rgba(255,255,255,.16);border-radius:46% 54% 58% 42%;animation:morph 13s ease-in-out infinite;pointer-events:none}
.hero-bg{position:absolute;right:6vw;top:50%;width:min(46vw,620px);height:min(46vw,620px);transform:translateY(-42%);display:grid;place-items:center;border-radius:50%;overflow:visible;opacity:.38;mix-blend-mode:screen;filter:contrast(1.05)}
.hero-bg::before{content:"";position:absolute;inset:10%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.12),transparent 70%);filter:blur(4px)}
.hero-bg img{height:100%;width:100%;object-fit:contain;opacity:.9;animation:floatHero 8s ease-in-out infinite}
.hero-content{position:relative;z-index:2;max-width:760px;margin-inline:0;padding-top:72px;text-align:left}
.hero-content .eyebrow{color:#f1ca73}
.hero h1{color:#fff;font-size:clamp(4.8rem,9vw,9.6rem);max-width:880px;text-wrap:balance;text-shadow:0 20px 70px rgba(0,0,0,.25)}
.hero h1::after{content:"";display:block;width:min(340px,46vw);height:1px;margin:28px 0 0;background:linear-gradient(90deg,var(--gold-2),transparent)}
.hero-content>p{color:rgba(255,255,255,.75);font-size:clamp(1.1rem,1.5vw,1.28rem);max-width:650px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.quick-trust{display:flex;gap:12px;flex-wrap:wrap;margin-top:36px}
.quick-trust span{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border:1px solid rgba(255,255,255,.14);border-radius:999px;color:rgba(255,255,255,.72);background:rgba(255,255,255,.065);backdrop-filter:blur(12px);font-size:13px}
.quick-trust strong{color:#fff;font-weight:900}

.expertise-layout{display:grid;grid-template-columns:minmax(260px,350px) minmax(0,1fr);gap:34px;align-items:start}
.expertise-list{position:sticky;top:118px;padding:14px;border:1px solid var(--line);border-radius:var(--radius);background:rgba(255,255,255,.64);box-shadow:var(--shadow);backdrop-filter:blur(16px)}
.expertise-tab{position:relative;width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 15px;border:0;border-radius:18px;background:transparent;color:#465467;font:800 14px/1.2 Manrope,sans-serif;text-align:left;cursor:pointer;transition:background .26s var(--ease),color .26s var(--ease),transform .26s var(--ease),padding .26s var(--ease)}
.expertise-tab::after{content:"→";opacity:0;transform:translateX(-8px);transition:opacity .25s var(--ease),transform .25s var(--ease)}
.expertise-tab:hover{background:rgba(184,137,5,.08);color:var(--ink);transform:translateX(3px)}
.expertise-tab.active{padding-left:20px;color:#fff;background:linear-gradient(135deg,var(--midnight),var(--blue));box-shadow:0 14px 34px rgba(13,91,143,.18)}
.expertise-tab.active::after{opacity:1;transform:translateX(0)}
.expertise-content{min-height:560px}
.expertise-panel{position:relative;display:none;padding:46px;border-radius:36px;background:linear-gradient(145deg,rgba(255,255,255,.86),rgba(255,250,241,.88));border:1px solid rgba(184,137,5,.16);box-shadow:var(--shadow);overflow:hidden}
.expertise-panel::before{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(184,137,5,.12),transparent 70%)}
.expertise-panel::after{content:"§";position:absolute;right:30px;bottom:20px;color:rgba(184,137,5,.08);font-family:"Instrument Serif",Georgia,serif;font-size:15rem;line-height:1}
.expertise-panel.active{display:block;animation:panelIn .55s var(--ease) both}
.expertise-panel h3{max-width:700px;color:var(--ink)}
.expertise-panel p{position:relative;z-index:1;max-width:850px}
.card-icon{position:relative;z-index:1;width:52px;height:52px;display:grid;place-items:center;margin-bottom:20px;border-radius:18px;color:var(--gold);background:rgba(184,137,5,.12);box-shadow:inset 0 0 0 1px rgba(184,137,5,.18);font-weight:900}
.note{margin-top:22px;padding:18px 20px;border-left:3px solid var(--gold);border-radius:0 18px 18px 0;background:rgba(184,137,5,.08);color:#465467}

.two-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:26px}
.international-card,.team-card,.publication-card,.fees-card,.contact-grid,.article-cover,.article-content,.publication-tools{position:relative;border:1px solid rgba(21,35,58,.10);background:rgba(255,255,255,.72);box-shadow:var(--shadow);backdrop-filter:blur(18px);overflow:hidden}
.international-card{padding:34px;border-radius:34px;transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);transform-style:preserve-3d}
.international-card::before,.team-card::before,.publication-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--x,50%) var(--y,0%),rgba(216,179,91,.20),transparent 32%);opacity:0;transition:opacity .3s var(--ease);pointer-events:none}
.international-card:hover,.publication-card:hover,.team-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-strong);border-color:rgba(184,137,5,.30)}
.international-card:hover::before,.team-card:hover::before,.publication-card:hover::before{opacity:1}
.link-button{position:relative;display:inline-flex;align-items:center;gap:9px;margin-top:10px;padding:0;border:0;background:transparent;color:var(--gold);font:900 13px/1 Manrope,sans-serif;cursor:pointer;text-decoration:none}
.link-button::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:currentColor;transform:scaleX(.26);transform-origin:left;transition:transform .25s var(--ease)}
.link-button:hover::after{transform:scaleX(1)}

.team-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;align-items:stretch}
.team-card{border-radius:34px;background:linear-gradient(180deg,#fff,#fbf6ec);transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column}
.team-card img{width:100%;height:330px;object-fit:cover;filter:saturate(.94) contrast(1.02);transition:filter .35s var(--ease),transform .6s var(--ease)}
.team-card:hover img{filter:saturate(1.08) contrast(1.05);transform:scale(1.04)}
.team-card-body{position:relative;z-index:1;padding:28px}
.team-card h3{font-size:2rem;margin-bottom:8px}
.role{margin-bottom:12px;color:var(--gold);font-size:12px;font-weight:900;letter-spacing:.14em;text-transform:uppercase}
.team-card ul{padding-left:18px;margin:14px 0 14px;color:#5d6978;font-size:14px}

.publication-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;margin-bottom:42px}
.publication-grid.compact{margin-bottom:40px}
.publication-card{border-radius:30px;background:rgba(255,255,255,.76);transition:transform .35s var(--ease),box-shadow .35s var(--ease);display:flex;flex-direction:column;min-height:100%}
.publication-image{position:relative;display:block;margin:14px 14px 0;border-radius:22px;overflow:hidden;background:#e9edf2;text-decoration:none;aspect-ratio:1.55/1}
.publication-image::after{content:"Lire";position:absolute;right:14px;bottom:14px;padding:8px 12px;border-radius:999px;background:rgba(7,20,37,.72);color:#fff;font:800 11px/1 Manrope,sans-serif;opacity:0;transform:translateY(8px);transition:opacity .28s var(--ease),transform .28s var(--ease);backdrop-filter:blur(10px)}
.publication-card:hover .publication-image::after{opacity:1;transform:translateY(0)}
.publication-image img{width:100%;height:100%;object-fit:cover;transition:transform .65s var(--ease),filter .35s var(--ease)}
.publication-card:hover .publication-image img{transform:scale(1.07);filter:saturate(1.05)}
.publication-body{position:relative;z-index:1;padding:22px 24px 28px;display:flex;flex-direction:column;gap:8px;flex:1}
.publication-body span,.category-pill{align-self:flex-start;color:var(--gold);font-size:11px;font-weight:900;letter-spacing:.12em;text-transform:uppercase}
.publication-body h3{font-size:1.58rem;line-height:1.05;margin:0;letter-spacing:-.03em}
.publication-body h3 a{text-decoration:none;background:linear-gradient(currentColor,currentColor) 0 100%/0 1px no-repeat;transition:background-size .25s var(--ease),color .25s var(--ease)}
.publication-body h3 a:hover{color:var(--gold);background-size:100% 1px}
.publication-body p{margin-top:auto;font-size:14px;color:#697686}

.fees-card{max-width:820px;margin-inline:auto;padding:44px;border-radius:34px;background:linear-gradient(145deg,#fff,#fff7ea)}
.fees-card h2{font-size:clamp(2.5rem,4.2vw,4.4rem)}
.accordion{margin-top:26px;border-radius:24px;overflow:hidden;border:1px solid rgba(21,35,58,.10)}
.accordion-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;padding:20px 22px;border:0;border-bottom:1px solid rgba(21,35,58,.09);background:rgba(255,255,255,.64);color:var(--ink);font:900 14px/1.2 Manrope,sans-serif;text-align:left;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease)}
.accordion-trigger:hover{background:rgba(184,137,5,.08);color:var(--gold)}
.accordion-trigger span{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:rgba(184,137,5,.11);color:var(--gold)}
.accordion-panel{max-height:0;overflow:hidden;transition:max-height .45s var(--ease);background:rgba(255,255,255,.40)}
.accordion-panel.open{max-height:560px}
.accordion-panel>div{padding:20px 22px 24px;color:#5b6877}
.fees-note{margin-top:26px;padding:22px;border-radius:24px;background:rgba(13,91,143,.07);border:1px solid rgba(13,91,143,.10)}
.fees-note h3{font-size:1.45rem}

.contact-section{padding-top:120px;background:linear-gradient(135deg,var(--midnight) 0%,#102a4a 100%);overflow:hidden}
.contact-section::before{content:"";position:absolute;inset:-20% -10% auto auto;width:560px;height:560px;border-radius:50%;background:radial-gradient(circle,rgba(184,137,5,.24),transparent 68%);filter:blur(10px)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:start;padding:48px;border-radius:38px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);color:rgba(255,255,255,.78);box-shadow:0 36px 120px rgba(0,0,0,.26)}
.contact-grid h2{color:#fff}.contact-grid .eyebrow{color:#f2c75d}.contact-grid p{max-width:570px}.contact-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.contact-form{display:grid;gap:14px}
.contact-form label{display:grid;gap:8px;color:rgba(255,255,255,.78);font-size:13px;font-weight:800}
.contact-form input,.contact-form textarea,.publication-tools input{width:100%;border:1px solid rgba(21,35,58,.12);border-radius:18px;background:rgba(255,255,255,.88);color:var(--ink);padding:15px 16px;font:600 14px/1.4 Manrope,sans-serif;outline:0;transition:border-color .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease)}
.contact-form input,.contact-form textarea{border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.10);color:#fff}
.contact-form textarea{resize:vertical;min-height:136px}
.contact-form input:focus,.contact-form textarea:focus,.publication-tools input:focus{border-color:rgba(216,179,91,.65);box-shadow:0 0 0 5px rgba(216,179,91,.13);background:rgba(255,255,255,.15)}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:rgba(255,255,255,.48)}

.page-hero,.article-hero{position:relative;padding:118px 0 88px;overflow:hidden;background:
  radial-gradient(circle at 74% 10%,rgba(184,137,5,.16),transparent 24rem),
  linear-gradient(135deg,var(--midnight),#143153);color:rgba(255,255,255,.76)}
.page-hero::after,.article-hero::after{content:"";position:absolute;right:8vw;top:34%;width:280px;height:280px;border:1px solid rgba(255,255,255,.15);border-radius:44% 56% 50% 50%;animation:morph 12s ease-in-out infinite}
.page-hero h1,.article-hero h1{color:#fff;font-size:clamp(4rem,7vw,7rem);text-wrap:balance}
.page-hero .eyebrow,.article-hero .eyebrow{color:#f2c75d}
.page-hero p,.article-hero p{color:rgba(255,255,255,.76);margin-inline:0}
.publication-tools{padding:22px;border-radius:28px;margin-bottom:36px;background:rgba(255,255,255,.78)}
.filter-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.filter-btn{border:1px solid rgba(21,35,58,.12);border-radius:999px;background:#fff;color:var(--ink);padding:10px 14px;font:900 12px/1 Manrope,sans-serif;cursor:pointer;transition:background .25s var(--ease),color .25s var(--ease),border-color .25s var(--ease),transform .25s var(--ease)}
.filter-btn:hover,.filter-btn.active{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px)}

.article-head{position:relative;z-index:1}.breadcrumb{display:inline-flex;margin-bottom:22px;color:#f2c75d;text-decoration:none;font-weight:900}.breadcrumb:hover{text-decoration:underline}.category-pill{display:inline-flex;margin-bottom:16px;padding:9px 12px;border-radius:999px;background:rgba(216,179,91,.14);color:#f2c75d;border:1px solid rgba(216,179,91,.22)}
.article-layout{display:grid;grid-template-columns:minmax(300px,440px) minmax(0,1fr);gap:34px;align-items:start}
.article-cover{position:sticky;top:120px;border-radius:34px;padding:14px;background:rgba(255,255,255,.76)}
.article-cover img{width:100%;border-radius:24px;object-fit:cover;aspect-ratio:1.3/1}
.article-content{padding:46px;border-radius:34px;background:rgba(255,255,255,.78);color:#475565;font-size:1.04rem}
.article-content p:first-child{font-family:"Instrument Serif",Georgia,serif;font-size:2.2rem;line-height:1.1;color:var(--ink)}

.modal{position:fixed;inset:0;z-index:4000;display:none;place-items:center;padding:24px;background:rgba(7,20,37,.62);backdrop-filter:blur(14px)}
.modal.open{display:grid;animation:fadeIn .25s ease both}.modal-dialog{position:relative;width:min(720px,100%);max-height:min(760px,86vh);overflow:auto;padding:38px;border-radius:34px;background:linear-gradient(145deg,#fff,#fff7ea);box-shadow:var(--shadow-strong)}.modal-dialog h2{font-size:clamp(2.4rem,4vw,4rem)}.modal-close{position:absolute;right:18px;top:18px;width:42px;height:42px;border:0;border-radius:50%;background:var(--ink);color:#fff;font-size:24px;cursor:pointer}

.site-footer{position:relative;padding:86px 0 36px;background:linear-gradient(135deg,#071425,#0d3157);color:rgba(255,255,255,.72);overflow:hidden}
.site-footer::before{content:"PD";position:absolute;right:-4vw;bottom:-3vw;color:rgba(255,255,255,.035);font-family:"Instrument Serif",Georgia,serif;font-size:22rem;line-height:.7;letter-spacing:-.12em}
.footer-grid{display:grid;grid-template-columns:1.1fr .9fr 1fr;gap:48px;position:relative;z-index:1}.footer-logo{height:54px;width:auto;margin-bottom:18px}.site-footer h2,.site-footer h3{color:#fff}.site-footer h2{font-size:2.2rem}.site-footer h3{font:900 13px/1.2 Manrope,sans-serif;letter-spacing:.14em;text-transform:uppercase;color:#f2c75d}.footer-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.footer-list a,.site-footer a{color:inherit;text-decoration:none}.footer-list a:hover,.site-footer a:hover{color:#fff}.footer-bottom{position:relative;z-index:1;display:flex;justify-content:space-between;gap:24px;margin-top:58px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);font-size:13px}
.floating-contact,.back-top{position:fixed;z-index:2000;width:54px;height:54px;border:0;border-radius:50%;display:grid;place-items:center;text-decoration:none;box-shadow:0 18px 48px rgba(7,20,37,.22);cursor:pointer}.floating-contact{right:22px;bottom:22px;background:linear-gradient(135deg,var(--gold),var(--gold-2));color:#fff}.back-top{right:22px;bottom:88px;background:#fff;color:var(--ink);opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .25s var(--ease),transform .25s var(--ease)}.back-top.visible{opacity:1;pointer-events:auto;transform:translateY(0)}

.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease) var(--delay,0ms),transform .8s var(--ease) var(--delay,0ms)}.reveal.visible{opacity:1;transform:none}
@keyframes morph{0%,100%{border-radius:44% 56% 50% 50%;transform:rotate(0deg)}50%{border-radius:58% 42% 45% 55%;transform:rotate(8deg)}}
@keyframes floatHero{0%,100%{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-18px) rotate(1deg)}}
@keyframes panelIn{from{opacity:0;transform:translateY(16px) scale(.985)}to{opacity:1;transform:none}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

@media (max-width:1050px){
  .header-actions .btn{display:none}.nav-shell{min-height:68px}.brand img{height:42px}.nav-toggle{display:block}.nav{position:fixed;left:24px;right:24px;top:96px;display:grid;gap:8px;padding:18px;border:1px solid var(--line);border-radius:28px;background:rgba(255,255,255,.96);box-shadow:var(--shadow-strong);transform:translateY(-18px);opacity:0;pointer-events:none;transition:opacity .25s var(--ease),transform .25s var(--ease)}.nav.open{opacity:1;pointer-events:auto;transform:translateY(0)}.nav a{justify-content:center;min-height:48px}.hero{min-height:auto;padding-top:150px}.hero-bg{right:-12vw;width:70vw;height:70vw;opacity:.22}.expertise-layout,.article-layout{grid-template-columns:1fr}.expertise-list,.article-cover{position:relative;top:auto}.expertise-list{display:flex;gap:8px;overflow:auto;scrollbar-width:thin}.expertise-tab{min-width:230px}.team-grid,.publication-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.footer-grid,.contact-grid{grid-template-columns:1fr}.two-grid{grid-template-columns:1fr}}
@media (max-width:720px){
  .container{width:min(var(--container),calc(100% - 32px))}.site-header{padding:10px 0}.nav-shell{border-radius:22px}.brand img{height:36px}.hero{margin-top:-92px;padding:142px 0 92px}.hero h1{font-size:clamp(4rem,17vw,5.8rem)}.hero-actions,.contact-actions{flex-direction:column;align-items:stretch}.quick-trust{display:grid}.quick-trust span{justify-content:center}.section{padding:86px 0}.section-title{text-align:left;margin-bottom:36px}.section-title p:not(.eyebrow){margin-inline:0}.expertise-panel,.fees-card,.contact-grid,.article-content{padding:28px;border-radius:26px}.team-grid,.publication-grid{grid-template-columns:1fr}.team-card img{height:300px}.page-hero,.article-hero{padding:92px 0 70px}.footer-bottom{flex-direction:column}.floating-contact{right:16px;bottom:16px}.back-top{right:16px;bottom:82px}.modal-dialog{padding:28px}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}.reveal{opacity:1!important;transform:none!important}.ambient-cursor{display:none}}

/* =========================================================
   Ajuste 2026: banner más sencillo, elegante y menos exagerado
   ========================================================= */
.hero{
  min-height:680px;
  align-items:center;
  padding:118px 0 96px;
  margin-top:-104px;
  background:
    linear-gradient(90deg, rgba(255,253,248,.98) 0%, rgba(255,253,248,.92) 44%, rgba(244,248,252,.90) 100%),
    radial-gradient(circle at 78% 42%, rgba(184,137,5,.10), transparent 23rem),
    linear-gradient(135deg,#fffaf1 0%,#eef5fb 100%);
  border-bottom:1px solid rgba(21,35,58,.08);
}
.hero::before,
.hero::after{display:none;content:none;}
.hero-bg{
  right:9vw;
  top:56%;
  width:min(34vw,440px);
  height:min(34vw,440px);
  transform:translateY(-45%);
  opacity:.14;
  mix-blend-mode:multiply;
  filter:grayscale(.2) contrast(1.04);
}
.hero-bg::before{display:none;}
.hero-bg img{
  animation:none;
  opacity:1;
}
.hero-content{
  max-width:720px;
  padding-top:92px;
  text-align:left;
}
.hero-content .eyebrow{color:var(--gold);}
.hero h1{
  color:var(--ink);
  font-size:clamp(3.45rem,6.8vw,6.6rem);
  line-height:.98;
  max-width:760px;
  text-shadow:none;
}
.hero h1::after{
  width:190px;
  margin:24px 0 0;
  background:linear-gradient(90deg,var(--gold),rgba(184,137,5,.06));
}
.hero-content>p{
  max-width:650px;
  color:#586678;
  font-size:clamp(1rem,1.25vw,1.18rem);
}
.hero-actions{margin-top:26px;}
.quick-trust{margin-top:30px;}
.quick-trust span{
  color:#586678;
  border-color:rgba(21,35,58,.12);
  background:rgba(255,255,255,.72);
  box-shadow:0 12px 34px rgba(8,20,38,.06);
}
.quick-trust strong{color:var(--ink);}

.page-hero,.article-hero{
  padding:104px 0 76px;
  background:
    radial-gradient(circle at 82% 18%,rgba(184,137,5,.10),transparent 22rem),
    linear-gradient(135deg,#fffaf1 0%,#f4f8fc 100%);
  color:#586678;
  border-bottom:1px solid rgba(21,35,58,.08);
}
.page-hero::after,.article-hero::after{display:none;content:none;}
.page-hero h1,.article-hero h1{
  color:var(--ink);
  font-size:clamp(3.25rem,6.2vw,6.1rem);
  text-shadow:none;
}
.page-hero .eyebrow,.article-hero .eyebrow{color:var(--gold);}
.page-hero p,.article-hero p{color:#586678;}
.breadcrumb{color:var(--gold);}
.category-pill{
  color:var(--gold);
  background:rgba(184,137,5,.10);
  border-color:rgba(184,137,5,.18);
}

@media (max-width:1050px){
  .hero{min-height:auto;padding:150px 0 96px;}
  .hero-bg{right:-10vw;width:58vw;height:58vw;opacity:.10;}
}
@media (max-width:720px){
  .hero{margin-top:-92px;padding:138px 0 78px;}
  .hero-content{padding-top:58px;text-align:center;}
  .hero h1{font-size:clamp(3rem,13vw,4.8rem);}
  .hero h1::after{margin-inline:auto;}
  .hero-content>p{margin-inline:auto;}
  .hero-bg{right:50%;top:48%;width:88vw;height:88vw;transform:translate(50%,-50%);opacity:.065;}
  .quick-trust span{box-shadow:none;}
  .page-hero,.article-hero{padding:88px 0 60px;}
}

/* =========================================================
   Ajuste: banner centrado dentro del ancho de página
   ========================================================= */
.container.hero-content{
  width:min(var(--container), calc(100% - 48px));
  max-width:var(--container);
  margin-left:auto;
  margin-right:auto;
  padding-left:0;
  padding-right:0;
}
.hero-content > .eyebrow,
.hero-content > h1,
.hero-content > p,
.hero-content > .hero-actions,
.hero-content > .quick-trust{
  max-width:720px;
}
.hero-content > .hero-actions,
.hero-content > .quick-trust{
  width:fit-content;
}
.hero-bg{
  right:10vw;
  width:min(32vw,520px);
  height:min(32vw,520px);
  opacity:.075;
}
.hero-bg img{
  object-fit:contain;
}

@media (min-width:1500px){
  .hero-bg{right:14vw;}
}

@media (max-width:1050px){
  .container.hero-content{width:min(var(--container), calc(100% - 36px));}
  .hero-content > .eyebrow,
  .hero-content > h1,
  .hero-content > p,
  .hero-content > .hero-actions,
  .hero-content > .quick-trust{max-width:660px;}
}

@media (max-width:720px){
  .container.hero-content{width:min(var(--container), calc(100% - 32px));}
  .hero-content > .eyebrow,
  .hero-content > h1,
  .hero-content > p,
  .hero-content > .hero-actions,
  .hero-content > .quick-trust{max-width:100%;}
  .hero-content > .hero-actions,
  .hero-content > .quick-trust{width:100%;}
}


/* =========================================================
   Logo actualizado: usa el WebP proporcionado por el cliente
   ========================================================= */
.brand{
  gap:10px;
  min-width:max-content;
}
.brand .brand-symbol{
  width:44px;
  height:44px;
  object-fit:contain;
  flex:0 0 auto;
  filter:drop-shadow(0 8px 18px rgba(184,137,5,.16));
}
.brand .brand-name{
  display:grid;
  gap:2px;
  line-height:.92;
  color:var(--ink);
  letter-spacing:.02em;
  text-transform:uppercase;
}
.brand .brand-name strong{
  color:var(--ink);
  font:900 14px/1 Manrope,system-ui,sans-serif;
  letter-spacing:.06em;
}
.brand .brand-name em{
  color:rgba(21,35,58,.72);
  font:800 11px/1 Manrope,system-ui,sans-serif;
  font-style:normal;
  letter-spacing:.22em;
}
.site-header.scrolled .brand .brand-symbol{
  width:40px;
  height:40px;
}
.footer-logo{
  width:58px;
  height:58px;
  object-fit:contain;
  opacity:.95;
  filter:drop-shadow(0 10px 24px rgba(0,0,0,.22));
}
.hero-bg{
  width:min(28vw,440px);
  height:min(28vw,440px);
  opacity:.11;
  mix-blend-mode:multiply;
  filter:none;
}
.hero-bg::before{display:none;}
.hero-bg img{
  object-fit:contain;
  opacity:.9;
}
@media (max-width:1050px){
  .brand .brand-name strong{font-size:13px;}
  .brand .brand-name em{font-size:10px;letter-spacing:.18em;}
}
@media (max-width:720px){
  .brand{gap:8px;}
  .brand .brand-symbol{width:38px;height:38px;}
  .brand .brand-name strong{font-size:12px;letter-spacing:.035em;}
  .brand .brand-name em{font-size:9px;letter-spacing:.15em;}
  .hero-bg{width:72vw;height:72vw;opacity:.065;}
}
@media (max-width:430px){
  .brand .brand-name strong{max-width:128px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .brand .brand-name em{display:none;}
}
