/* ========================================
   PILATES CORE — Homepage Custom CSS
   Prefix: pc-
   Dark theme: copper on navy/dark
   ======================================== */

:root {
    --pc-bg: #0e1118;
    --pc-bg-card: #151820;
    --pc-bg-light: #1a1e28;
    --pc-text: #e8e4de;
    --pc-text-mid: #8a8690;
    --pc-text-dim: #4e4a54;
    --pc-copper: #c4875a;
    --pc-copper-dark: #a06e48;
    --pc-copper-glow: rgba(196,135,90,.1);
    --pc-navy: #1e2a4a;
    --pc-white: #ffffff;
    --pc-serif: 'Bodoni Moda', Georgia, serif;
    --pc-sans: 'Manrope', sans-serif;
    --pc-ease: cubic-bezier(.22,1,.36,1);
}




/* ═══ HERO ═══ */

/* ══════════════════════════════════════
   NAV — Custom homepage navbar
   ══════════════════════════════════════ */
.pc-nav{position:fixed;top:0;left:0;right:0;z-index:1000;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 48px;background:rgba(14,17,24,.88);backdrop-filter:blur(16px);border-bottom:1px solid rgba(196,135,90,.06);animation:pc-nd .7s var(--pc-ease) both}

@keyframes pc-nd{from{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}

.pc-nav-brand{display:flex;align-items:center;gap:12px;text-decoration:none}

.pc-nav-diamond{width:28px;height:28px;background:var(--pc-copper);transform:rotate(45deg);display:flex;align-items:center;justify-content:center;border-radius: var(--radius-sm, 4px)}

.pc-nav-diamond span{transform:rotate(-45deg);font-size:12px;font-family:var(--pc-serif);font-weight:700;color:var(--pc-bg)}

.pc-nav-wordmark{font-family:var(--pc-serif);font-size:20px;font-weight:500;color:var(--pc-text);letter-spacing:1px}

.pc-nav-links{display:flex;align-items:center;gap:28px;list-style:none}

.pc-nav-links a{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;text-decoration:none;color:var(--pc-text-mid);transition:color .3s}

.pc-nav-links a:hover{color:var(--pc-copper)}

.pc-nav-acc{padding:9px 22px!important;border:1.5px solid var(--pc-copper)!important;color:var(--pc-copper)!important;border-radius: var(--radius-xs, 2px)!important;transition:all .3s!important}

.pc-nav-acc:hover{background:var(--pc-copper)!important;color:var(--pc-bg)!important}

/* Mobile nav toggle */
.pc-nav-toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
    z-index: 1001;
}
.pc-nav-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: currentColor;
    transition: all 0.3s;
}
/* Hamburger → X animation */
.pc-nav-toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.pc-nav-toggle.active span:nth-child(2) { opacity: 0; }
.pc-nav-toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.pc-nav-logout {
    background: none;
    border: none;
    cursor: pointer;
    font: inherit;
    color: inherit;
    padding: 0;
    font-size: 13px;
    font-weight: 600;
    opacity: 0.6;
    transition: opacity 0.3s;
}
.pc-nav-logout:hover { opacity: 1; }
.pc-footer-powered {
    text-align: center;
    padding: 16px 0 0;
    font-size: 11px;
    opacity: 0.3;
}
.pc-footer-powered a {
    color: inherit;
    text-decoration: none;
}
.pc-footer-powered a:hover { opacity: 0.7; }

@media (max-width: 768px) {
    .pc-nav-toggle { display: flex; }
    .pc-nav-links {
        display: none;
        position: absolute;
        top: 100%;
        left: 0; right: 0;
        background: inherit;
        flex-direction: column;
        padding: 20px;
        gap: 12px;
        box-shadow: 0 8px 32px rgba(0,0,0,0.1);
    }
    .pc-nav-links.active { display: flex; }
}


/* ══════════════════════════════════════
   FOOTER — Custom homepage footer
   ══════════════════════════════════════ */
.fsu{margin-top:20px}.fsu .btn-copper{width:100%;display:flex;justify-content:center}

.pc-footer{
  color: rgba(255,255,255,0.85);padding:40px 48px;background:var(--pc-bg);border-top:1px solid rgba(232,228,222,.04)}

.pc-footer-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}

.pc-footer-left{display:flex;align-items:center;gap:10px}

.pc-footer-diam{width:20px;height:20px;background:var(--pc-copper);transform:rotate(45deg);border-radius: var(--radius-xs, 3px)}

.pc-footer-name{font-family:var(--pc-serif);font-size:16px;font-weight:500;letter-spacing:1px}

.pc-footer-copy{font-size:12px;color:var(--pc-text-mid)}

.pc-footer-links{display:flex;gap:20px;list-style:none}

.pc-footer-links a{text-decoration:none;font-size:12px;color:var(--pc-text-mid);transition:color .3s}

.pc-footer-links a:hover{color:var(--pc-copper)}


.pc-hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;position:relative;padding:120px 40px 80px;overflow:hidden;background:var(--pc-bg)}

.pc-hero-deco{position:absolute;inset:0;z-index:0;overflow:hidden}
.pc-hero-deco .pc-line-h,.pc-hero-deco .pc-line-v{position:absolute;background:rgba(196,135,90,.04)}
.pc-hero-deco .pc-line-h{width:100%;height:1px;top:50%}
.pc-hero-deco .pc-line-v{height:100%;width:1px;left:50%}
.pc-hero-deco .pc-diamond{position:absolute;width:300px;height:300px;border:1px solid rgba(196,135,90,.06);transform:rotate(45deg);top:50%;left:50%;margin:-150px 0 0 -150px;animation:diamPulse 10s ease-in-out infinite}
.pc-hero-deco .pc-diamond:nth-child(4){width:200px;height:200px;margin:-100px 0 0 -100px;animation-delay:2s;border-color:rgba(196,135,90,.04)}
.pc-hero-deco .pc-diamond:nth-child(5){width:100px;height:100px;margin:-50px 0 0 -50px;animation-delay:4s;border-color:rgba(196,135,90,.03)}
@keyframes diamPulse{0%,100%{transform:rotate(45deg) scale(1);opacity:.5}50%{transform:rotate(45deg) scale(1.08);opacity:1}}

.pc-hero-content{position:relative;z-index:2;max-width:750px}
.pc-hero-eyebrow{display:inline-flex;align-items:center;gap:12px;margin-bottom:32px;animation:fu .8s .2s var(--pc-ease) both}
.pc-hero-eyebrow .pc-ebar{width:24px;height:1px;background:var(--pc-copper)}
.pc-hero-eyebrow span{font-family:var(--pc-serif);font-size:14px;font-style:italic;color:var(--pc-copper);letter-spacing:2px}

.pc-hero-title{font-family:var(--pc-serif);font-size:clamp(48px,7vw,90px);font-weight:400;line-height:1.08;margin-bottom:24px;animation:fu .8s .4s var(--pc-ease) both;color:var(--pc-text)}
.pc-hero-title em{font-style:italic;color:var(--pc-copper)}

.pc-hero-desc{font-size:16px;line-height:1.9;color:var(--pc-text-mid);max-width:480px;margin:0 auto 40px;font-weight:300;animation:fu .8s .6s var(--pc-ease) both}
.pc-hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:fu .8s .8s var(--pc-ease) both}
@keyframes fu{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}

.pc-btn-copper{padding:16px 36px;background:var(--pc-copper);color:var(--pc-bg);border:none;border-radius: var(--radius-xs, 2px);font-family:var(--pc-sans);font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all .3s var(--pc-ease);box-shadow:0 6px 24px rgba(196,135,90,.2)}
.pc-btn-copper:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(196,135,90,.3)}
.pc-btn-out{padding:16px 36px;background:transparent;color:var(--pc-text);border:1.5px solid rgba(232,228,222,.12);border-radius: var(--radius-xs, 2px);font-family:var(--pc-sans);font-size:13px;font-weight:600;letter-spacing:1px;text-transform:uppercase;cursor:pointer;text-decoration:none;transition:all .3s var(--pc-ease)}
.pc-btn-out:hover{border-color:var(--pc-copper);color:var(--pc-copper);transform:translateY(-2px)}

/* ═══ UTILS ═══ */
.pc-sec-pad{padding:100px 48px}
.pc-stag{display:inline-flex;align-items:center;gap:10px;font-family:var(--pc-serif);font-size:13px;font-style:italic;color:var(--pc-copper);letter-spacing:1px;margin-bottom:14px}
.pc-stag::before{content:'';width:20px;height:1px;background:var(--pc-copper)}
.pc-stitle{font-family:var(--pc-serif);font-size:clamp(34px,4.5vw,54px);font-weight:400;line-height:1.1;margin-bottom:14px;color:var(--pc-text)}
.pc-stitle em{color:var(--pc-copper);font-style:italic}
.pc-sdesc{font-size:15px;line-height:1.9;color:var(--pc-text-mid);font-weight:300;max-width:440px}

/* ═══ DISCIPLINES — 3 col cards with copper top ═══ */
.pc-disciplines{background:var(--pc-bg-card);border-top:1px solid rgba(196,135,90,.05);border-bottom:1px solid rgba(196,135,90,.05)}
.pc-disc-inner{max-width:1200px;margin:0 auto}
.pc-disc-header{text-align:center;margin-bottom:56px}
.pc-disc-header .pc-stag{justify-content:center}.pc-disc-header .pc-stag::before{display:none}
.pc-disc-header .pc-sdesc{margin:0 auto}

.pc-disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}

.pc-dg-card{background:var(--pc-bg-light);border-radius: var(--radius-lg, 4px);overflow:hidden;border:1px solid rgba(232,228,222,.03);transition:all .5s var(--pc-ease);cursor:pointer;position:relative}
.pc-dg-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--pc-copper),transparent);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--pc-ease)}
.pc-dg-card:hover::before{transform:scaleX(1)}
.pc-dg-card:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.3);border-color:rgba(196,135,90,.1)}

.pc-dg-visual{height:200px;display:flex;align-items:center;justify-content:center;position:relative}
.pc-dg-card:nth-child(1) .pc-dg-visual{background:linear-gradient(160deg,#1e2a4a,#151820)}
.pc-dg-card:nth-child(2) .pc-dg-visual{background:linear-gradient(160deg,#2a1e1e,#201515)}
.pc-dg-card:nth-child(3) .pc-dg-visual{background:linear-gradient(160deg,#1e2a22,#152018)}

.pc-dg-emoji{font-size:56px;transition:transform .5s var(--pc-ease);filter:drop-shadow(0 0 30px rgba(196,135,90,.15))}
.pc-dg-card:hover .pc-dg-emoji{transform:scale(1.15)}
.pc-dg-num{position:absolute;top:16px;left:20px;font-family:var(--pc-serif);font-size:14px;font-style:italic;color:var(--pc-copper);opacity:.4}

.pc-dg-body{padding:28px}
.pc-dg-name{font-family:var(--pc-serif);font-size:24px;font-weight:500;margin-bottom:10px;color:var(--pc-text)}
.pc-dg-text{font-size:13px;line-height:1.8;color:var(--pc-text-mid);font-weight:300;margin-bottom:20px}
.pc-dg-link{font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--pc-copper);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .3s}
.pc-dg-link:hover{gap:12px}

/* ═══ TEAM — Offset masonry ═══ */
.pc-team{background:var(--pc-bg)}
.pc-team-inner{max-width:1200px;margin:0 auto}
.pc-team-header{margin-bottom:56px}

.pc-team-masonry{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pc-tm{background:var(--pc-bg-card);border:1px solid rgba(232,228,222,.03);border-radius: var(--radius-lg, 4px);overflow:hidden;transition:all .5s var(--pc-ease);cursor:pointer}
.pc-tm:hover{transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.25);border-color:rgba(196,135,90,.12)}
.pc-tm:nth-child(2){margin-top:40px}

.pc-tm-top{height:200px;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.pc-tm:nth-child(1) .pc-tm-top{background:linear-gradient(135deg,#2a2420,#1a1815)}
.pc-tm:nth-child(2) .pc-tm-top{background:linear-gradient(135deg,#20242a,#15181a)}
.pc-tm:nth-child(3) .pc-tm-top{background:linear-gradient(135deg,#24202a,#18151a)}

.pc-tm-init{font-family:var(--pc-serif);font-size:72px;font-weight:400;font-style:italic;color:rgba(196,135,90,.1);transition:all .5s var(--pc-ease)}
.pc-tm:hover .pc-tm-init{color:rgba(196,135,90,.2);transform:scale(1.1)}
.pc-tm-top::after{content:'';position:absolute;bottom:0;left:0;width:3px;height:36px;background:var(--pc-copper)}

.pc-tm-body{padding:28px}
.pc-tm-role{font-family:var(--pc-serif);font-size:12px;font-style:italic;color:var(--pc-copper);margin-bottom:8px;letter-spacing:.5px}
.pc-tm-name{font-family:var(--pc-serif);font-size:22px;font-weight:500;margin-bottom:10px;color:var(--pc-text)}
.pc-tm-bio{font-size:13px;line-height:1.8;color:var(--pc-text-mid);font-weight:300}

/* ═══ CENTRO ═══ */
.pc-centro{background:var(--pc-bg-card);border-top:1px solid rgba(196,135,90,.05)}
.pc-centro-inner{max-width:1200px;margin:0 auto}
.pc-centro-split{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center;margin-bottom:56px}
.pc-centro-vis{height:380px;border-radius: var(--radius-lg, 4px);overflow:hidden;background:linear-gradient(160deg,var(--pc-bg-light),var(--pc-bg));display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;position:relative}
.pc-centro-vis .pc-cvi{font-size:72px;animation:cvf 5s ease-in-out infinite;filter:drop-shadow(0 0 30px rgba(196,135,90,.15))}
@keyframes cvf{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.pc-centro-vis .pc-cvl{font-family:var(--pc-serif);font-size:13px;font-style:italic;color:var(--pc-text-mid)}
.pc-centro-vis::before{content:'';position:absolute;width:180px;height:180px;border:1px solid rgba(196,135,90,.05);transform:rotate(45deg);border-radius: var(--radius-sm, 4px);animation:diamPulse 15s ease-in-out infinite}

.pc-centro-tiles{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pc-ct{background:var(--pc-bg-light);border:1px solid rgba(232,228,222,.03);border-radius: var(--radius-lg, 4px);padding:28px 22px;transition:all .4s var(--pc-ease)}
.pc-ct:hover{transform:translateY(-3px);border-color:rgba(196,135,90,.1)}
.pc-ct .pc-cti{font-size:24px;margin-bottom:12px;display:block}
.pc-ct h3{font-family:var(--pc-serif);font-size:18px;font-weight:500;margin-bottom:8px;color:var(--pc-text)}
.pc-ct p{font-size:13px;line-height:1.8;color:var(--pc-text-mid);font-weight:300}
.pc-ct.pc-cop-ct{background:linear-gradient(135deg,var(--pc-copper),var(--pc-copper-dark));border:none;grid-column:1/-1}
.pc-ct.pc-cop-ct h3,.pc-ct.pc-cop-ct p{color:var(--pc-bg)}
.pc-ct.pc-cop-ct p{opacity:.8}
.pc-ct.pc-cop-ct .pc-ctl{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-weight:700;font-size:13px;color:var(--pc-bg);text-decoration:none;transition:gap .3s}
.pc-ct.pc-cop-ct .pc-ctl:hover{gap:12px}

/* ═══ CONTACT ═══ */
.pc-contact{ color: rgba(255,255,255,0.85);background:var(--pc-bg);position:relative;overflow:hidden}
.pc-contact::before{content:'';position:absolute;bottom:-200px;left:50%;transform:translateX(-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(196,135,90,.04),transparent 70%)}
.pc-contact-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:72px;align-items:start;position:relative;z-index:1}
.pc-contact-left .pc-sdesc{margin-bottom:36px}
.pc-cdr{display:flex;align-items:center;gap:14px;padding:16px 0;border-bottom:1px solid rgba(232,228,222,.04)}
.pc-cdr-i{width:40px;height:40px;background:var(--pc-copper-glow);border:1px solid rgba(196,135,90,.1);border-radius: var(--radius-md, 8px);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.pc-cdr-t small{display:block;font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(196,135,90,.7);margin-bottom:3px}
.pc-cdr-t strong{font-weight:500;font-size:15px}

.pc-cf{background:var(--pc-bg-card);border:1px solid rgba(232,228,222,.04);border-radius: var(--radius-lg, 4px);padding:44px;position:relative}
.pc-cf::before{content:'';position:absolute;top:0;left:28px;right:28px;height:2px;background:linear-gradient(90deg,var(--pc-copper),transparent);border-radius:0 0 2px 2px}
.pc-cf h3{font-family:var(--pc-serif);font-size:26px;font-weight:500;margin-bottom:4px;color:var(--pc-text)}
.pc-cf .pc-cfs{font-size:14px;color:var(--pc-text-mid);margin-bottom:28px;font-weight:300}
.pc-fg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.pc-fi{display:flex;flex-direction:column;gap:5px}.pc-fi.pc-full{grid-column:1/-1}
.pc-fi label{font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--pc-text-mid)}
.pc-fi input,.pc-fi textarea{background:var(--pc-bg-light);border:1px solid rgba(232,228,222,.06);border-radius: var(--radius-md, 8px);padding:14px 16px;font-family:var(--pc-sans);font-size:15px;color:var(--pc-text);transition:all .3s;width:100%}
.pc-fi input:focus,.pc-fi textarea:focus{outline:none;border-color:var(--pc-copper);box-shadow:0 0 0 3px var(--pc-copper-glow)}
.pc-fi input::placeholder,.pc-fi textarea::placeholder{color:var(--pc-text-dim)}
.pc-fi textarea{resize:vertical;min-height:100px}
.pc-fsu{margin-top:20px}.pc-fsu .pc-btn-copper{width:100%;display:flex;justify-content:center}

@media(max-width:1024px){.pc-disc-grid,.pc-team-masonry{grid-template-columns:1fr;max-width:450px;margin-left:auto;margin-right:auto}.pc-tm:nth-child(2){margin-top:0}.pc-centro-split{grid-template-columns:1fr}.pc-contact-inner{grid-template-columns:1fr}.pc-centro-tiles{grid-template-columns:1fr}}
@media(max-width:768px){.pc-sec-pad{padding:72px 20px}.pc-fg{grid-template-columns:1fr}.pc-cf{padding:28px 20px}.pc-hero{padding:100px 20px 60px}}


/* ── CMS HELPERS ── */
.pc-team-avatar-img {
    width: 100%; height: 100%;
    object-fit: cover; border-radius: var(--radius-lg, 4px) 16px 0 0;
}
.pc-centro-photo {
    width: 100%; height: 100%;
    object-fit: cover; border-radius: var(--radius-lg, 4px);
}
.pc-events-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(320px, 100%), 1fr));
    gap: 24px;
}
.bg-gradient { display: none; }

/* ══ Homepage Section Ordering (CMS Builder drag & drop) ══ */
.hp-sections-container { display: flex; flex-direction: column; width: 100%; }
.hp-section { width: 100%; }

/* ══ Registration Section ══ */
.registration-section {
    padding: 60px 20px;
    text-align: center;
    background: var(--color-bg-secondary, #f8f9fa);
}
.registration-inner {
    max-width: 600px;
    margin: 0 auto;
}
.registration-label {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--color-primary, #6366f1);
    margin-bottom: 8px;
}
.registration-title {
    font-size: 28px;
    font-weight: 700;
    color: var(--color-text, #1f2937);
    margin: 0 0 12px;
}
.registration-desc {
    font-size: 16px;
    line-height: 1.6;
    color: var(--color-text-muted, #6b7280);
    margin: 0 0 24px;
}
.registration-btn {
    display: inline-block;
    padding: 14px 32px;
    background: var(--color-primary, #6366f1);
    color: #fff;
    text-decoration: none;
    border-radius: var(--radius-md, 8px);
    font-weight: 600;
    font-size: 16px;
    transition: transform 0.2s, box-shadow 0.2s;
}
.registration-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.registration-note {
    font-size: 13px;
    color: var(--color-text-muted, #6b7280);
    margin-top: 16px;
    font-style: italic;
}

/* Fix: hero con immagine CMS */
.pc-hero--has-image {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.pc-hero--has-image::before {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.55);
    z-index: 0;
}


/* ═══════════════════════════════════════════
   TEACHER MODAL — pilates-core
   ═══════════════════════════════════════════ */

.teacher-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 2000;
    background: rgba(0, 0, 0, 0.75);
    backdrop-filter: blur(6px);
    align-items: center;
    justify-content: center;
    padding: 24px;
}
.teacher-modal-overlay.active {
    display: flex;
}
.teacher-modal {
    background: var(--pc-bg-card);
    border: 1px solid rgba(196, 135, 90, 0.15);
    max-width: 580px;
    width: 100%;
    position: relative;
    animation: fu 0.35s var(--pc-ease) both;
}
.teacher-modal::before {
    content: '';
    position: absolute;
    top: 0; left: 28px; right: 28px;
    height: 2px;
    background: linear-gradient(90deg, var(--pc-copper), transparent);
}
.teacher-modal-close {
    position: absolute;
    top: 14px;
    right: 18px;
    background: none;
    border: none;
    color: var(--pc-text-mid);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    transition: color 0.2s;
    z-index: 1;
}
.teacher-modal-close:hover { color: var(--pc-copper); }

.teacher-modal-content {
    display: flex;
    gap: 28px;
    padding: 40px 36px 36px;
}
.teacher-modal-photo {
    width: 110px;
    height: 110px;
    flex-shrink: 0;
    background: var(--pc-bg-light);
    border: 1px solid rgba(196, 135, 90, 0.12);
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--pc-serif);
    font-size: 2.5rem;
    font-style: italic;
    color: rgba(196, 135, 90, 0.4);
}
.teacher-modal-photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.teacher-modal-info { flex: 1; min-width: 0; }
.teacher-modal-role {
    font-family: var(--pc-serif);
    font-size: 12px;
    font-style: italic;
    color: var(--pc-copper);
    letter-spacing: 1px;
    margin-bottom: 6px;
}
.teacher-modal-name {
    font-family: var(--pc-serif);
    font-size: 26px;
    font-weight: 500;
    color: var(--pc-text);
    margin-bottom: 12px;
    line-height: 1.1;
}
.teacher-modal-desc {
    font-size: 14px;
    line-height: 1.8;
    color: var(--pc-text-mid);
    font-weight: 300;
}
.teacher-modal-social {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 16px;
}
.teacher-modal-social a {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--pc-copper);
    text-decoration: none;
    border: 1px solid rgba(196, 135, 90, 0.25);
    padding: 5px 14px;
    transition: all 0.25s;
}
.teacher-modal-social a:hover {
    background: var(--pc-copper);
    color: var(--pc-bg);
}

/* Multi-sede badges */
.teacher-sedi-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin: 6px 0 10px;
}
.badge-sede-small {
    font-size: 11px;
    padding: 2px 8px;
    background: var(--pc-copper-glow);
    border: 1px solid rgba(196, 135, 90, 0.2);
    color: var(--pc-text-mid);
}

@media (max-width: 540px) {
    .teacher-modal-content { flex-direction: column; padding: 36px 20px 28px; }
    .teacher-modal-photo { width: 80px; height: 80px; }
    .teacher-modal-name { font-size: 22px; }
}
