/* ═══════════════════════════════════════════════════════════════════
 VAAVIYO HOTELS, partner.css
 Page-specific styles for /partner.html (Partner With Us).
 Reuses brand tokens from main.css. Adds:
 - Image PLACEHOLDER component (.img-ph), solid brand-colored blocks
 with an icon + label, used in place of real photography until
 Vaaviyo supplies hotel photos.
 - Two-column intro section (.partner-intro)
 - Benefit cards grid (.benefit-grid / .benefit-card)
 - Services accordion-style cards (.service-card)
 - Partnership models comparison (.model-grid / .model-card)
 - Process timeline (.process / .process-step)
 - Stats banner (.partner-stats)
 - Inquiry form (.partner-form)
═══════════════════════════════════════════════════════════════════ */
/* ─── Image PLACEHOLDER component ─────────────────────────────── */
.img-ph {
 position: relative;
 background: var(--v-stone);
 border-radius: 3px;
 overflow: hidden;
 display: grid; place-items: center;
 color: var(--v-mist);
 font-family: var(--font-body);
 border: 1px dashed rgba(184, 51, 58, .25);
 /* Subtle Rajasthani-tinted texture using layered gradients */
 background-image:
 linear-gradient(135deg, rgba(184, 51, 58, .06) 0%, transparent 40%),
 linear-gradient(225deg, rgba(217, 196, 163, .35) 0%, transparent 50%);
}
.img-ph .img-ph-inner {
 text-align: center; padding: 24px;
 display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.img-ph i {
 font-size: 36px; color: var(--v-red); opacity: .55;
}
.img-ph .img-ph-label {
 font-size: 11px; font-weight: 600; letter-spacing: 2.5px;
 text-transform: uppercase; color: var(--v-mist);
}
.img-ph .img-ph-caption {
 font-family: var(--font-display); font-size: 14px; font-style: italic;
 color: var(--v-ink); opacity: .7;
}
/* Variant: dark placeholder on dark backgrounds (e.g. inside maroon sections) */
.img-ph.dark {
 background: var(--v-maroon-d);
 border-color: rgba(217, 196, 163, .3);
 background-image:
 linear-gradient(135deg, rgba(217, 196, 163, .08) 0%, transparent 50%);
}
.img-ph.dark i { color: var(--v-sand); }
.img-ph.dark .img-ph-label { color: rgba(247, 241, 230, .6); }
.img-ph.dark .img-ph-caption { color: var(--v-cream); }
/* Variant: when a real photo replaces the placeholder, drop in an <img>
 plus a caption span, the placeholder backgrounds/icons are hidden. */
.img-ph.has-photo {
 background: var(--v-maroon-d); border: 0;
 background-image: none;
}
.img-ph.has-photo > img {
 position: absolute; inset: 0;
 width: 100%; height: 100%; object-fit: cover;
}
.img-ph.has-photo .img-ph-inner { display: none; }
.img-ph.has-photo .photo-caption {
 position: absolute; left: 18px; right: 18px; bottom: 16px;
 z-index: 2; color: var(--v-cream);
 font-family: var(--font-display); font-style: italic;
 font-size: 14px; line-height: 1.3;
 text-shadow: 0 1px 8px rgba(0, 0, 0, .6);
}
.img-ph.has-photo::after {
 /* dark gradient at the base so the caption stays readable */
 content: ""; position: absolute; inset: 0; z-index: 1;
 background: linear-gradient(to top, rgba(15, 10, 12, .75) 0%, transparent 50%);
 pointer-events: none;
}
/* Variant: sand-tone placeholder for accent slots */
.img-ph.sand {
 background: var(--v-sand);
 background-image:
 linear-gradient(135deg, rgba(184, 51, 58, .12) 0%, transparent 40%),
 linear-gradient(225deg, rgba(247, 241, 230, .4) 0%, transparent 50%);
 border-color: rgba(184, 51, 58, .3);
}
.img-ph.sand i { color: var(--v-red); opacity: .7; }
.img-ph.sand .img-ph-label { color: var(--v-red-d); }
/* ─── PARTNER PAGE HERO ─────────────────────────────────────── */
.partner-hero {
 position: relative; min-height: 460px;
 background: var(--v-maroon);
 display: flex; align-items: center; justify-content: center;
 padding: 80px var(--gutter);
 overflow: hidden;
}
.partner-hero .partner-hero-bg {
 position: absolute; inset: 0;
 width: 100%; height: 100%;
 object-fit: cover; object-position: center;
 z-index: 0;
}
.partner-hero .partner-hero-overlay {
 position: absolute; inset: 0; z-index: 1;
 background: linear-gradient(180deg, rgba(90, 26, 31, .55) 0%, rgba(90, 26, 31, .78) 100%);
}
.partner-hero::before {
 content: ""; position: absolute; inset: 0; z-index: 2;
 pointer-events: none;
 background:
 radial-gradient(circle at 20% 30%, rgba(217, 196, 163, .12) 0%, transparent 45%),
 radial-gradient(circle at 80% 70%, rgba(184, 51, 58, .25) 0%, transparent 50%);
}
.partner-hero .partner-hero-inner {
 position: relative; z-index: 3; text-align: center;
 max-width: 820px; color: var(--v-cream);
}
.partner-hero .eyebrow {
 display: inline-block; padding: 6px 14px;
 border: 1px solid rgba(247, 241, 230, .35);
 color: var(--v-sand); margin-bottom: 24px;
}
.partner-hero h1 {
 font-size: clamp(36px, 5.5vw, 64px); line-height: 1.08;
 color: var(--v-cream); margin-bottom: 18px;
}
.partner-hero h1 em { font-style: italic; color: var(--v-sand); }
.partner-hero p {
 font-size: clamp(15px, 1.5vw, 18px); line-height: 1.7;
 color: rgba(247, 241, 230, .88); max-width: 640px;
 margin: 0 auto 30px;
}
.partner-hero .arch-divider::before { border-color: var(--v-sand); }
.partner-hero .arch-divider::after { background: var(--v-maroon); color: var(--v-sand); }
/* ─── INTRO / VISION (two-column) ──────────────────────────── */
.sec-partner-intro {
 background: var(--v-cream);
 padding: clamp(70px, 9vw, 110px) var(--gutter);
}
.partner-intro {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: 1fr 1fr; gap: 60px;
 align-items: center;
}
.partner-intro .intro-text .eyebrow { display: block; margin-bottom: 12px; }
.partner-intro .intro-text h2 {
 font-size: clamp(28px, 3.6vw, 42px); line-height: 1.15;
 margin-bottom: 8px;
}
.partner-intro .intro-text h2 em { font-style: italic; color: var(--v-red); }
.partner-intro .intro-text p {
 color: var(--v-mist); font-size: 16px; line-height: 1.8;
 margin: 10px 0 16px;
}
.partner-intro .intro-quote {
 font-family: var(--font-display); font-style: italic;
 font-size: 18px; line-height: 1.6; color: var(--v-ink);
 border-left: 3px solid var(--v-red); padding: 4px 0 4px 22px;
 margin: 24px 0 28px;
}
.partner-intro .intro-img.img-ph { aspect-ratio: 4 / 5; min-height: 420px; }
/* ─── STATS BANNER ─────────────────────────────────────────── */
.partner-stats {
 background: var(--v-maroon-d); color: var(--v-cream);
 padding: 60px var(--gutter); position: relative;
}
.partner-stats::before {
 content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
 background: linear-gradient(to right,
 transparent 0%, var(--v-red) 20%, var(--v-sand) 50%, var(--v-red) 80%, transparent 100%);
}
.partner-stats-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px;
 text-align: center;
}
.partner-stats .stat-num {
 font-family: var(--font-display); font-size: clamp(36px, 4vw, 52px);
 font-weight: 500; color: var(--v-sand); line-height: 1;
}
.partner-stats .stat-num em { font-style: normal; color: var(--v-red-l); }
.partner-stats .stat-label {
 font-size: 12px; font-weight: 600; letter-spacing: 2px;
 text-transform: uppercase; color: rgba(247, 241, 230, .75);
 margin-top: 10px;
}
/* ─── WHY PARTNER (benefit cards) ──────────────────────────── */
.sec-benefits { background: var(--v-white); }
.benefit-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.benefit-card {
 background: var(--v-cream); padding: 38px 32px;
 border-radius: 3px; border: 1px solid var(--v-stone);
 position: relative; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.benefit-card:hover {
 transform: translateY(-6px); box-shadow: var(--shadow-md);
 border-color: var(--v-sand);
}
.benefit-card .benefit-icon {
 width: 60px; height: 60px; border-radius: 50%;
 background: var(--v-red-15); color: var(--v-red);
 display: grid; place-items: center; margin-bottom: 22px;
 font-size: 22px;
}
.benefit-card h3 {
 font-size: 22px; margin-bottom: 12px; color: var(--v-ink);
}
.benefit-card p {
 font-size: 15px; line-height: 1.7; color: var(--v-mist); margin: 0;
}
.benefit-card .benefit-num {
 position: absolute; top: 24px; right: 28px;
 font-family: var(--font-display); font-style: italic;
 font-size: 36px; color: var(--v-red); opacity: .15;
}
/* ─── SERVICES (icon + text grid) ──────────────────────────── */
.sec-services {
 background: var(--v-cream);
 position: relative;
}
.services-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
.service-card {
 background: var(--v-white); border: 1px solid var(--v-stone);
 border-radius: 3px; padding: 30px 32px;
 display: flex; gap: 22px; align-items: flex-start;
 transition: transform .25s ease, box-shadow .25s ease, border-left-color .25s ease;
 border-left: 4px solid transparent;
}
.service-card:hover {
 transform: translateY(-3px); box-shadow: var(--shadow-md);
 border-left-color: var(--v-red);
}
.service-card .svc-icon {
 flex: 0 0 56px; width: 56px; height: 56px;
 background: var(--v-red); color: var(--v-white);
 display: grid; place-items: center;
 font-size: 22px; border-radius: 3px;
}
.service-card h3 {
 font-size: 20px; margin-bottom: 8px; color: var(--v-ink);
}
.service-card p {
 font-size: 14px; line-height: 1.65; color: var(--v-mist); margin: 0 0 8px;
}
.service-card ul {
 list-style: none; padding: 0; margin: 10px 0 0;
}
.service-card ul li {
 font-size: 13px; color: var(--v-ink); padding-left: 18px;
 position: relative; margin-bottom: 6px;
}
.service-card ul li::before {
 content: "❖"; position: absolute; left: 0; top: 0;
 color: var(--v-red); font-size: 11px;
}
/* ─── PARTNERSHIP MODELS ─────────────────────────────────── */
.sec-models { background: var(--v-white); }
.model-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
.model-card {
 position: relative; overflow: hidden;
 border-radius: 3px;
 background: var(--v-white); border: 1px solid var(--v-stone);
 padding: 0;
}
.model-card.featured {
 border-color: var(--v-red); transform: translateY(-12px);
 box-shadow: var(--shadow-md);
}
.model-card.featured::before {
 content: "Most Popular"; position: absolute;
 top: 14px; right: -34px;
 background: var(--v-red); color: var(--v-white);
 padding: 5px 40px; font-size: 10px; font-weight: 700;
 letter-spacing: 1.5px; text-transform: uppercase;
 transform: rotate(35deg); z-index: 1;
}
.model-card .model-img.img-ph { aspect-ratio: 16/9; }
.model-card .model-body { padding: 30px 32px 32px; }
.model-card h3 {
 font-size: 22px; margin-bottom: 6px; color: var(--v-ink);
}
.model-card .model-tag {
 font-size: 11px; font-weight: 600; letter-spacing: 2.5px;
 text-transform: uppercase; color: var(--v-red); margin-bottom: 8px;
}
.model-card .model-desc {
 font-size: 14px; line-height: 1.7; color: var(--v-mist);
 margin: 8px 0 18px;
}
.model-card ul {
 list-style: none; padding: 0; margin: 0 0 22px;
}
.model-card ul li {
 font-size: 13px; padding: 8px 0 8px 22px; position: relative;
 border-bottom: 1px dashed var(--v-stone); color: var(--v-ink);
}
.model-card ul li:last-child { border-bottom: 0; }
.model-card ul li::before {
 content: ""; position: absolute; left: 0; top: 14px;
 width: 12px; height: 1.5px; background: var(--v-red);
}
.model-card .model-cta {
 display: inline-flex; align-items: center; gap: 8px;
 font-size: 12px; font-weight: 600; letter-spacing: 1.5px;
 text-transform: uppercase; color: var(--v-red);
 padding: 6px 0; border-bottom: 1px solid var(--v-red);
 transition: color .2s ease, gap .2s ease;
}
.model-card .model-cta:hover { color: var(--v-red-d); gap: 12px; }
/* ─── PROCESS TIMELINE ───────────────────────────────────── */
.sec-process {
 background: var(--v-cream);
 position: relative;
}
.process {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px;
 position: relative;
}
.process::before {
 content: ""; position: absolute; top: 36px; left: 12.5%; right: 12.5%;
 height: 1px; background: var(--v-sand);
 z-index: 0;
}
.process-step {
 text-align: center; position: relative; z-index: 1;
}
.process-step .step-num {
 width: 72px; height: 72px; margin: 0 auto 22px;
 background: var(--v-cream); border: 2px solid var(--v-red);
 border-radius: 50%; display: grid; place-items: center;
 font-family: var(--font-display); font-size: 28px; font-weight: 500;
 color: var(--v-red); position: relative;
 transition: background .25s ease, color .25s ease;
}
.process-step:hover .step-num {
 background: var(--v-red); color: var(--v-white);
}
.process-step h3 {
 font-size: 18px; margin-bottom: 8px; color: var(--v-ink);
}
.process-step p {
 font-size: 14px; line-height: 1.6; color: var(--v-mist); margin: 0;
}
/* ─── PORTFOLIO / GALLERY (image placeholders showing variety) ─ */
.sec-portfolio {
 background: var(--v-maroon); color: var(--v-cream);
 position: relative;
}
.sec-portfolio .section-head h2 { color: var(--v-cream); }
.sec-portfolio .section-head h2 em { color: var(--v-sand); }
.sec-portfolio .section-head p { color: rgba(247, 241, 230, .78); }
.sec-portfolio .eyebrow { color: var(--v-sand); }
.sec-portfolio .arch-divider::before { border-color: var(--v-sand); }
.sec-portfolio .arch-divider::after { background: var(--v-maroon); color: var(--v-sand); }
.portfolio-grid {
 max-width: var(--container); margin: 0 auto;
 display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 1fr 1fr;
 gap: 16px;
}
.portfolio-grid .img-ph { aspect-ratio: auto; min-height: 220px; }
.portfolio-grid .img-ph:nth-child(1) { grid-row: span 2; min-height: 460px; }
/* ─── INQUIRY FORM ──────────────────────────────────────── */
.sec-inquiry {
 background: var(--v-white);
}
.inquiry-wrap {
 max-width: 1100px; margin: 0 auto;
 display: grid; grid-template-columns: 1fr 1.4fr; gap: 60px;
 align-items: start;
}
.inquiry-aside .eyebrow { display: block; margin-bottom: 10px; }
.inquiry-aside h2 {
 font-size: clamp(28px, 3.4vw, 38px); line-height: 1.15;
 margin-bottom: 14px;
}
.inquiry-aside h2 em { font-style: italic; color: var(--v-red); }
.inquiry-aside p {
 font-size: 15px; line-height: 1.7; color: var(--v-mist);
 margin: 0 0 22px;
}
.inquiry-contact { margin-top: 30px; }
.inquiry-contact .ic-row {
 display: flex; gap: 14px; align-items: flex-start;
 margin-bottom: 16px;
 font-size: 14px; line-height: 1.6;
}
.inquiry-contact .ic-row i {
 flex: 0 0 36px; width: 36px; height: 36px;
 background: var(--v-red-15); color: var(--v-red);
 display: grid; place-items: center; border-radius: 50%;
 font-size: 14px;
}
.inquiry-contact .ic-row strong {
 display: block; font-weight: 600; color: var(--v-ink);
 font-size: 13px; letter-spacing: 1px; text-transform: uppercase;
 margin-bottom: 2px;
}
.inquiry-contact .ic-row a:hover { color: var(--v-red); }
.partner-form {
 background: var(--v-cream); padding: 40px;
 border: 1px solid var(--v-stone); border-radius: 3px;
}
.partner-form .form-row {
 display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
 margin-bottom: 18px;
}
.partner-form .form-field { display: flex; flex-direction: column; }
.partner-form .form-field.full { grid-column: 1 / -1; }
.partner-form label {
 font-size: 11px; font-weight: 600; letter-spacing: 1.5px;
 text-transform: uppercase; color: var(--v-ink);
 margin-bottom: 6px;
}
.partner-form input,
  .partner-form select,
  .partner-form textarea {
 background: var(--v-white); border: 1px solid var(--v-stone);
 padding: 13px 14px; font: inherit; font-size: 14px;
 color: var(--v-ink); border-radius: 2px;
 transition: border-color .2s ease, box-shadow .2s ease;
}
.partner-form input:focus, .partner-form select:focus, .partner-form textarea:focus {
 outline: 0; border-color: var(--v-red);
 box-shadow: 0 0 0 3px rgba(184, 51, 58, .12);
}
.partner-form textarea { min-height: 110px; resize: vertical; }
.partner-form .form-check {
 display: flex; gap: 10px; align-items: flex-start;
 font-size: 13px; color: var(--v-mist); line-height: 1.55;
 margin: 6px 0 20px;
}
.partner-form .form-check input { width: 16px; height: 16px; margin-top: 2px; }
.partner-form button[type="submit"] {
 background: var(--v-red); color: var(--v-white);
 border: 1px solid var(--v-red); padding: 14px 32px;
 font-size: 13px; font-weight: 600; letter-spacing: 2px;
 text-transform: uppercase; border-radius: 2px; cursor: pointer;
 transition: background .25s ease, transform .15s ease, box-shadow .25s ease;
}
.partner-form button[type="submit"]:hover {
 background: var(--v-red-d); transform: translateY(-2px);
 box-shadow: 0 12px 28px rgba(184, 51, 58, .3);
}
.partner-form button[type="submit"]:disabled {
 background: var(--v-mist); border-color: var(--v-mist);
 cursor: default; transform: none; box-shadow: none;
}
.form-success {
 display: none; padding: 16px; margin-bottom: 18px;
 background: rgba(184, 51, 58, .08); border-left: 3px solid var(--v-red);
 color: var(--v-ink); font-size: 14px; border-radius: 2px;
}
.form-success.is-visible { display: block; }
/* ─── BREADCRUMB ──────────────────────────────────────────── */
.breadcrumb {
 background: var(--v-cream);
 padding: 14px var(--gutter);
 font-size: 13px; color: var(--v-mist);
 border-bottom: 1px solid var(--v-stone);
}
.breadcrumb .crumb-inner {
 max-width: var(--container); margin: 0 auto;
 display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
}
.breadcrumb a { color: var(--v-red); transition: color .2s ease; }
.breadcrumb a:hover { color: var(--v-red-d); }
.breadcrumb i { font-size: 9px; color: var(--v-mist); }
/* ─── RESPONSIVE ──────────────────────────────────────────── */
/* Defensive: long emails/addresses won't break layout */
.ic-row a.ic-row div { overflow-wrap: anywhere; word-break: break-word; }
@media (max-width: 1024px) {
 .partner-hero { min-height: 420px; padding: 64px 22px; }
 .partner-hero h1 { font-size: clamp(32px, 5vw, 54px); }
 .partner-intro { grid-template-columns: 1fr; gap: 36px; }
 .partner-intro .intro-img.img-ph { aspect-ratio: 16/10; min-height: 0; }
 .partner-stats { padding: 50px 22px; }
 .partner-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 28px; }
 .benefit-grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
 .services-grid { grid-template-columns: 1fr; gap: 16px; }
 .model-grid { grid-template-columns: 1fr; gap: 24px; max-width: 540px; margin-left: auto; margin-right: auto; }
 .model-card.featured { transform: none; }
 .process { grid-template-columns: repeat(2, 1fr); gap: 32px 24px; }
 .process::before { display: none; }
 .portfolio-grid { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
 .portfolio-grid .img-ph:nth-child(1) { grid-row: auto; grid-column: span 2; min-height: 280px; }
 .inquiry-wrap { grid-template-columns: 1fr; gap: 36px; }
}
@media (max-width: 768px) {
 .partner-hero {
 min-height: 360px; padding: 56px 18px;
 }
 .partner-hero .partner-hero-bg { object-position: 50% 35%; }
 .partner-hero .partner-hero-overlay {
 background: linear-gradient(180deg, rgba(90, 26, 31, .6) 0%, rgba(90, 26, 31, .82) 100%);
 }
 .partner-hero h1 { font-size: clamp(28px, 7vw, 44px); }
 .partner-hero p { font-size: 14.5px; line-height: 1.65; }
 .partner-hero .eyebrow { font-size: 10px; letter-spacing: 3.5px; padding: 4px 12px; margin-bottom: 18px; }
 .sec-partner-intro { padding: 50px 18px; }
 .partner-intro .intro-text h2 { font-size: clamp(22px, 5vw, 32px); }
 .partner-intro .intro-text p { font-size: 14.5px; line-height: 1.7; }
 .partner-intro .intro-quote { font-size: 16px; padding-left: 18px; margin: 18px 0 22px; }
 .partner-stats { padding: 40px 18px; }
 .partner-stats-grid { grid-template-columns: 1fr 1fr; gap: 18px; }
 .partner-stats .stat-num { font-size: 32px; }
 .partner-stats .stat-label { font-size: 11px; letter-spacing: 1.5px; }
 .sec-benefits, .sec-services, .sec-models, .sec-process, .sec-portfolio, .sec-inquiry {
 padding-left: 18px; padding-right: 18px;
 }
 .benefit-grid { grid-template-columns: 1fr; gap: 16px; }
 .benefit-card { padding: 28px 24px; }
 .benefit-card .benefit-num { font-size: 28px; top: 20px; right: 22px; }
 .benefit-card .benefit-icon { width: 52px; height: 52px; font-size: 19px; margin-bottom: 18px; }
 .benefit-card h3 { font-size: 20px; }
 .benefit-card p { font-size: 14px; }
 .service-card { flex-direction: column; gap: 14px; padding: 22px; }
 .service-card .svc-icon { flex: 0 0 50px; width: 50px; height: 50px; font-size: 19px; }
 .service-card h3 { font-size: 18px; }
 .service-card p { font-size: 13.5px; }
 .service-card ul li { font-size: 12.5px; }
 .model-grid { max-width: 100%; }
 .model-card .model-img.img-ph { aspect-ratio: 16/9; }
 .model-card .model-body { padding: 24px 22px 26px; }
 .model-card h3 { font-size: 20px; }
 .model-card .model-desc { font-size: 13.5px; }
 .model-card.featured::before {
 /* The diagonal "Most Popular" ribbon can clip awkwardly on tiny cards */
 font-size: 9px; padding: 4px 32px; top: 12px; right: -32px;
 }
 .process { grid-template-columns: 1fr; gap: 28px; }
 .process-step .step-num { width: 60px; height: 60px; font-size: 22px; margin-bottom: 16px; }
 .process-step h3 { font-size: 17px; }
 .process-step p { font-size: 13.5px; }
 .portfolio-grid { grid-template-columns: 1fr; gap: 14px; }
 .portfolio-grid .img-ph:nth-child(1) { grid-column: auto; min-height: 240px; }
 .portfolio-grid .img-ph { min-height: 200px; }
 .inquiry-aside h2 { font-size: 26px; }
 .inquiry-aside p { font-size: 14.5px; }
 .inquiry-contact .ic-row { font-size: 13.5px; }
 .inquiry-contact .ic-row i { flex: 0 0 32px; width: 32px; height: 32px; font-size: 12px; }
 .partner-form { padding: 24px 20px; }
 .partner-form .form-row { grid-template-columns: 1fr; gap: 14px; margin-bottom: 14px; }
 .partner-form input,
  .partner-form select,
  .partner-form textarea { font-size: 16px; padding: 12px 13px; }
 .partner-form button[type="submit"] {
 width: 100%; padding: 16px; min-height: 48px;
 }
 .partner-form .form-check { font-size: 12.5px; }
 .img-ph i { font-size: 28px; }
 .img-ph .img-ph-caption { font-size: 13px; }
 .breadcrumb { padding: 12px 18px; font-size: 12px; }
}
@media (max-width: 480px) {
 .partner-hero { min-height: 320px; padding: 48px 14px; }
 .partner-hero .partner-hero-bg { object-position: 50% 30%; }
 .partner-hero .partner-hero-overlay {
 background: linear-gradient(180deg, rgba(90, 26, 31, .65) 0%, rgba(90, 26, 31, .85) 100%);
 }
 .partner-hero h1 { font-size: 30px; }
 .sec-partner-intro, .sec-benefits, .sec-services, .sec-models, .sec-process, .sec-portfolio, .sec-inquiry { padding-left: 14px; padding-right: 14px; }
 .partner-stats { padding: 32px 14px; }
 .partner-stats-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
 .partner-stats .stat-num { font-size: 28px; }
 .benefit-card { padding: 24px 20px; }
 .service-card { padding: 20px 18px; }
 .model-card .model-body { padding: 22px 18px 24px; }
 .partner-form { padding: 22px 16px; }
}
@media (max-width: 360px) {
 .partner-hero h1 { font-size: 26px; }
 .partner-intro .intro-text h2 { font-size: 22px; }
 .partner-stats-grid { grid-template-columns: 1fr; gap: 12px; }
 .partner-stats .stat-num { font-size: 30px; }
 .model-card.featured::before { font-size: 8.5px; padding: 4px 28px; right: -28px; }
}
