/* ════════════════════════════════════════════════
   Bespoke 상세 — 담담한 블로그 에디토리얼 · 모바일 퍼스트
   ★ 애니는 opacity/transform 만 (출렁임 0) · 보일 때만 재생(--play)
   ★ 데모 = 헤드라인의 동사를 그대로 증명 (장식 금지)
   ════════════════════════════════════════════════ */

.bk { overflow-x: hidden; word-break: keep-all; overflow-wrap: break-word; }
.bk-wrap { width: 100%; max-width: 1080px; margin: 0 auto; padding: 0 24px; }
.bk .lbl { font-family: var(--display); font-size: 11.5px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: var(--olive); }
.bk .prata { font-family: "Prata", serif; font-weight: 400; }

/* 텍스트 1회 등장 */
.up { opacity: 0; transform: translateY(14px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.up.show { opacity: 1; transform: none; }
.up.d1.show { transition-delay: .07s; }
.up.d2.show { transition-delay: .14s; }
@media (prefers-reduced-motion: reduce) { .up { opacity: 1; transform: none; transition: none; } }

/* 데모 재생 게이트 — 컨테이너에 .run 붙으면 --play 변수로 일괄 재생 */
.bdemo, .flow { --play: paused; }
.bdemo.run, .flow.run { --play: running; }
@media (prefers-reduced-motion: reduce) {
  .bdemo .an, .flow .an { animation: none !important; opacity: 1 !important; transform: none !important; }
}

/* ════════ 01 · HERO (에디토리얼) ════════ */
.b-hero { padding: clamp(58px, 10vw, 112px) 0 clamp(48px, 8vw, 84px); }
.b-hero .col { max-width: 660px; }
.b-hero .eyebrow { display: block; margin-bottom: clamp(20px, 4vw, 28px); color: var(--gray-2); }
.b-hero h1 { font-size: clamp(27px, 4.6vw, 44px); font-weight: 700; line-height: 1.34; letter-spacing: -.03em; margin: 0; color: var(--ink); text-wrap: balance; }
.b-hero h1 .u { text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 7px; text-decoration-color: var(--terra); }
.b-hero .body { margin-top: clamp(26px, 4vw, 38px); display: flex; flex-direction: column; gap: 20px; }
.b-hero .body p { margin: 0; color: var(--gray); font-size: clamp(15.5px, 2vw, 17.5px); line-height: 1.9; letter-spacing: -.01em; max-width: 58ch; text-wrap: pretty; }
.b-hero .body b { color: var(--ink); font-weight: 600; }
.b-hero .body .u { color: var(--ink); font-weight: 600; text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 3px; text-decoration-color: rgba(91,98,54,.6); }
.b-hero .cta-row { margin-top: clamp(30px, 4vw, 40px); display: flex; gap: 12px; flex-wrap: wrap; }
.btn-olive { background: var(--olive); color: #fff; }
.btn-olive:hover { background: #4B5233; transform: translateY(-2px); box-shadow: 0 14px 30px -14px rgba(91,98,54,.5); }

/* ════════ 02 · WORKFLOW — 세로 타임라인, 레일을 따라 이어지는 흐름 ════════ */
.b-flow { padding: clamp(56px, 10vw, 110px) 0; border-top: 1px solid var(--line); }
.b-flow .narrow2 { max-width: 700px; }
.b-flow .lbl { display: block; margin-bottom: 18px; }
.flow-lead { margin: 0; font-size: clamp(18px, 2.8vw, 23px); font-weight: 500; line-height: 1.6; letter-spacing: -.02em; color: var(--gray); text-wrap: pretty; }
.flow-lead b { color: var(--ink); font-weight: 700; }
/* 타임라인 */
.flow.steps { position: relative; margin-top: clamp(38px, 6vw, 56px); padding-left: 36px;
  display: flex; flex-direction: column; gap: clamp(36px, 5vw, 50px); }
.flow .rail { position: absolute; left: 10px; top: 10px; bottom: 10px; width: 1.5px; background: var(--line); overflow: hidden; }
.flow .rail .pulse { position: absolute; left: 50%; top: -16px; width: 7px; height: 13px; margin-left: -3.5px;
  border-radius: 99px; background: var(--olive); opacity: 0;
  animation: railFlow 5.2s linear infinite; animation-play-state: var(--play, paused); }
@keyframes railFlow { 0% { transform: translateY(0); opacity: 0; } 5% { opacity: .85; } 92% { opacity: .85; } 100% { transform: translateY(980px); opacity: 0; } }
.step { position: relative; }
.step::before { content: ""; position: absolute; left: -31px; top: 8px; width: 8px; height: 8px;
  border-radius: 99px; background: var(--paper); border: 2px solid var(--olive); }
.step .shead { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.step .sno { font-family: var(--display); font-weight: 400; font-size: clamp(20px, 3.4vw, 26px); color: var(--gray-2); letter-spacing: -.02em; line-height: 1; }
.step h3 { margin: 0; font-size: clamp(18px, 3vw, 23px); font-weight: 700; letter-spacing: -.02em; color: var(--ink); }
.step .sen { font-family: var(--display); font-size: 11px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: var(--gray-2); }
.step .squote { margin: 11px 0 0; font-size: clamp(15.5px, 2.3vw, 17px); font-weight: 700; color: var(--olive); letter-spacing: -.01em; }
.step .sbody { margin: 11px 0 0; color: #464B54; font-size: clamp(15px, 2vw, 16px); line-height: 1.85; letter-spacing: -.01em; max-width: 56ch; text-wrap: pretty; }
.step .sbody b { color: var(--ink); font-weight: 700; }

/* ════════ 가치 섹션 공통 ════════ */
.vsec { padding: clamp(60px, 12vw, 124px) 0; border-top: 1px solid var(--line); }
.vsec .in-grid { display: grid; gap: clamp(28px, 6vw, 56px); align-items: center; }
.vtext .en { font-family: var(--display); font-size: 11.5px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--olive); }
.vtext h2 { font-size: clamp(23px, 4vw, 33px); font-weight: 700; line-height: 1.34; letter-spacing: -.025em; margin: 14px 0 0; color: var(--ink); }
.vtext h2 .u { text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 4px; text-decoration-color: rgba(91,98,54,.5); }
.vtext p { margin: 16px 0 0; color: var(--gray); font-size: clamp(15.5px, 2.2vw, 17px); line-height: 1.75; max-width: 40ch; }

/* 데모 카드 — 고정 높이 (공간 선점) */
.bdemo { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  padding: clamp(18px, 3.4vw, 24px); box-shadow: 0 36px 70px -50px rgba(11,11,12,.24);
  height: 364px; display: flex; flex-direction: column; overflow: hidden; }
.bdemo .dh { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 13px; flex: none; }
.bdemo .dh .tagr { margin-left: auto; font-family: ui-monospace, monospace; font-size: 11px; color: var(--gray-2); font-weight: 500; }

/* ════════ 데모1 · AUDIT — 스캔 라인이 훑고, 비효율만 짚어냄 ════════ */
.d-audit .list { position: relative; flex: 1; display: flex; flex-direction: column; gap: 7px; }
.d-audit .arow { position: relative; display: flex; align-items: center; gap: 9px; height: 40px; padding: 0 13px;
  border: 1px solid var(--line); border-radius: 10px; font-size: 12.5px; flex: none; overflow: hidden; }
.d-audit .arow .nm { font-weight: 600; color: var(--ink); position: relative; z-index: 1; }
.d-audit .arow .ok { margin-left: auto; color: var(--olive); font-weight: 800; font-size: 12px; opacity: 0; position: relative; z-index: 1; }
.d-audit .arow .tint { position: absolute; inset: 0; background: var(--terra-soft); opacity: 0; }
.d-audit .arow .flag { position: absolute; right: 11px; top: 50%; margin-top: -11px; font-size: 10.5px; font-weight: 800;
  color: #B4470E; background: #fff; border: 1px solid #F0C9B2; padding: 3px 9px; border-radius: 99px; opacity: 0; z-index: 1; }
/* 스캔 라인 */
.d-audit .scan { position: absolute; left: -4px; right: -4px; top: 0; height: 2px; z-index: 2;
  background: linear-gradient(90deg, transparent, var(--olive) 30%, var(--olive) 70%, transparent); opacity: 0; }
.d-audit .scan.an { animation: scanY 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
@keyframes scanY { 0%, 5% { transform: translateY(0); opacity: 0; } 8% { opacity: 1; } 46% { transform: translateY(228px); opacity: 1; } 50%, 100% { transform: translateY(228px); opacity: 0; } }
/* 통과 ✓ (1·3·5행) / 비효율 플래그 (2·4행) — 스캔이 지나간 직후 등장, 유지 */
.d-audit .ok.an.k1 { animation: aOn1 7.5s linear infinite; animation-play-state: var(--play, paused); }
.d-audit .ok.an.k3 { animation: aOn3 7.5s linear infinite; animation-play-state: var(--play, paused); }
.d-audit .ok.an.k5 { animation: aOn5 7.5s linear infinite; animation-play-state: var(--play, paused); }
.d-audit .an.f2 { animation: aOn2 7.5s linear infinite; animation-play-state: var(--play, paused); }
.d-audit .an.f4 { animation: aOn4 7.5s linear infinite; animation-play-state: var(--play, paused); }
@keyframes aOn1 { 0%, 13% { opacity: 0; } 16%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
@keyframes aOn2 { 0%, 20% { opacity: 0; } 23%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
@keyframes aOn3 { 0%, 28% { opacity: 0; } 31%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
@keyframes aOn4 { 0%, 35% { opacity: 0; } 38%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
@keyframes aOn5 { 0%, 43% { opacity: 0; } 46%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
/* 합계 */
.d-audit .sum { margin-top: 10px; flex: none; display: flex; align-items: center; gap: 8px; background: var(--terra-soft);
  border-radius: 10px; padding: 11px 13px; font-size: 12.5px; font-weight: 700; color: #B4470E; opacity: 0; transform: translateY(6px); }
.d-audit .sum small { font-weight: 500; color: #C97B4E; }
.d-audit .sum.an { animation: sumIn 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
@keyframes sumIn { 0%, 52% { opacity: 0; transform: translateY(6px); } 58%, 88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }

/* ════════ 데모2 · AI — 실제 컴플레인 → 브랜드 톤 답변이 생성됨 ════════ */
.d-ai .k { font-family: var(--display); font-size: 10px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; color: var(--gray-2); display: block; margin-bottom: 6px; }
.d-ai .bub-in { background: var(--paper-2); border-radius: 13px; border-bottom-left-radius: 5px; padding: 11px 14px;
  font-size: 13px; line-height: 1.5; color: var(--ink); max-width: 88%; flex: none; opacity: 0; transform: translateY(6px); }
.d-ai .mid { display: flex; align-items: center; gap: 7px; padding: 11px 2px; flex: none; opacity: 0; }
.d-ai .mid svg { width: 15px; height: 15px; stroke: var(--olive); fill: none; stroke-width: 2; flex: none; }
.d-ai .mid .chip2 { font-size: 10.5px; font-weight: 700; color: var(--olive); background: var(--olive-soft); border-radius: 99px; padding: 4px 10px; }
.d-ai .out { border: 1px solid #DCE0CC; background: #FBFCF7; border-radius: 13px; border-bottom-right-radius: 5px;
  padding: 12px 14px; flex: 1; margin-left: auto; width: 92%; }
.d-ai .out .oln { font-size: 13px; line-height: 1.62; color: var(--ink); opacity: 0; transform: translateY(5px); }
.d-ai .done { margin-top: 10px; flex: none; align-self: flex-end; display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 700; color: var(--olive); background: var(--olive-soft); border-radius: 99px; padding: 6px 12px;
  opacity: 0; transform: translateY(5px); }
.d-ai .an.t1 { animation: ai1 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-ai .an.t2 { animation: ai2 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-ai .an.t3 { animation: ai3 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-ai .an.t4 { animation: ai4 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-ai .an.t5 { animation: ai5 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-ai .an.t6 { animation: ai6 7.5s var(--ease) infinite; animation-play-state: var(--play, paused); }
@keyframes ai1 { 0%, 3%  { opacity: 0; transform: translateY(6px); } 8%,  88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }
@keyframes ai2 { 0%, 14% { opacity: 0; } 19%, 88% { opacity: 1; } 95%, 100% { opacity: 0; } }
@keyframes ai3 { 0%, 26% { opacity: 0; transform: translateY(5px); } 31%, 88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }
@keyframes ai4 { 0%, 38% { opacity: 0; transform: translateY(5px); } 43%, 88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }
@keyframes ai5 { 0%, 50% { opacity: 0; transform: translateY(5px); } 55%, 88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }
@keyframes ai6 { 0%, 62% { opacity: 0; transform: translateY(5px); } 67%, 88% { opacity: 1; transform: none; } 95%, 100% { opacity: 0; } }

/* ════════ 데모3 · TAILORED — 투박한 외주 vs 정갈한 D10 (교차) ════════ */
.d-win { padding: clamp(16px, 3vw, 20px); }
.d-win .stage2 { position: relative; flex: 1; }
.d-win .win { position: absolute; inset: 0; border-radius: 13px; overflow: hidden; display: flex; flex-direction: column; }
.d-win .win .wtag { position: absolute; top: 46px; right: 12px; font-size: 10.5px; font-weight: 800; padding: 4px 10px; border-radius: 99px; z-index: 2; }
/* Before — 투박한 외주 */
.win.before { border: 1px solid #B9B9B9; background: #ECECEC; font-family: "Apple SD Gothic Neo", sans-serif; }
.win.before .tb { display: flex; align-items: center; background: #7A7A7A; color: #fff; font-size: 11px; font-weight: 700; padding: 7px 10px; flex: none; }
.win.before .tb .x { margin-left: auto; letter-spacing: 3px; font-weight: 400; }
.win.before .wtag { background: #DADADA; color: #6E6E6E; border: 1px solid #B9B9B9; }
.win.before .fb { flex: 1; padding: 12px; display: flex; flex-direction: column; gap: 7px; }
.win.before .frow { display: flex; gap: 6px; align-items: center; }
.win.before .flab { width: 64px; font-size: 10.5px; color: #444; flex: none; }
.win.before .fin { flex: 1; height: 24px; background: #fff; border: 1px solid #8E8E8E; }
.win.before .fbtns { margin-top: auto; display: flex; gap: 6px; justify-content: flex-end; }
.win.before .fbtn { font-size: 10.5px; padding: 5px 12px; background: linear-gradient(#FDFDFD, #D9D9D9); border: 1px solid #8E8E8E; color: #222; }
.win.before .fbtn.blue { background: linear-gradient(#5A8DEE, #3E6ED0); color: #fff; border-color: #2F56A8; }
/* After — D10 */
.win.after { border: 1px solid var(--line); background: var(--paper); }
.win.after .tb { display: flex; align-items: center; gap: 6px; padding: 11px 14px; border-bottom: 1px solid var(--line); background: #FCFCFB; flex: none; }
.win.after .tb i { width: 9px; height: 9px; border-radius: 99px; background: #DDDCD8; }
.win.after .tb .tt { margin-left: 10px; font-family: var(--display); font-size: 11px; font-weight: 600; color: var(--ink); letter-spacing: .03em; }
.win.after .tb .tt span { color: var(--gray-2); font-weight: 500; }
.win.after .wtag { background: var(--olive-soft); color: var(--olive); border: 1px solid #D8DEC2; }
.win.after .fb { flex: 1; padding: 16px; display: flex; flex-direction: column; gap: 9px; }
.win.after .hrow { font-size: 13px; font-weight: 800; letter-spacing: -.02em; color: var(--ink); }
.win.after .srow { display: flex; align-items: center; gap: 9px; height: 34px; padding: 0 12px; background: #fff;
  border: 1px solid var(--line); border-radius: 9px; font-size: 11.5px; color: var(--ink); font-weight: 600; }
.win.after .srow .st { margin-left: auto; font-size: 10px; font-weight: 700; color: var(--olive); background: var(--olive-soft); padding: 3px 8px; border-radius: 99px; }
.win.after .foot2 { margin-top: auto; display: flex; justify-content: flex-end; }
.win.after .obtn { font-size: 11px; font-weight: 700; color: #fff; background: var(--ink); border-radius: 99px; padding: 6px 14px; }
/* 교차 페이드 (9초 주기) */
.d-win .win.an.wa { animation: swapA 9s var(--ease) infinite; animation-play-state: var(--play, paused); }
.d-win .win.an.wb { animation: swapB 9s var(--ease) infinite; animation-play-state: var(--play, paused); }
@keyframes swapA { 0%, 40% { opacity: 1; } 48%, 90% { opacity: 0; } 98%, 100% { opacity: 1; } }
@keyframes swapB { 0%, 40% { opacity: 0; } 48%, 90% { opacity: 1; } 98%, 100% { opacity: 0; } }

/* ════════ 06 · CASE STUDIES ════════ */
.b-cases { padding: clamp(60px, 11vw, 120px) 0; border-top: 1px solid var(--line); }
.case-head { text-align: center; margin-bottom: clamp(32px, 5vw, 48px); }
.case-head h2 { font-size: clamp(23px, 4.2vw, 33px); font-weight: 700; line-height: 1.34; letter-spacing: -.025em; margin: 12px 0 0; color: var(--ink); }
.case-grid { display: grid; grid-template-columns: 1fr; gap: 14px; }
.case { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 26px 28px; display: flex; flex-direction: column; }
.case .cno { font-family: var(--display); font-size: 12px; font-weight: 700; color: var(--olive); letter-spacing: .04em; }
.case .cno span { color: var(--gray-2); font-weight: 600; }
.case .ct { margin: 13px 0 0; font-size: clamp(15.5px, 2.2vw, 17px); font-weight: 700; color: var(--ink); letter-spacing: -.02em; line-height: 1.45; }
.case p { margin: 12px 0 0; color: #464B54; font-size: 14.5px; line-height: 1.78; letter-spacing: -.01em; text-wrap: pretty; }
.case p b { color: var(--ink); font-weight: 700; }
@media (min-width: 820px) { .case-grid { grid-template-columns: repeat(3, 1fr); } }

/* ════════ 07 · FAQ (전체 펼침) ════════ */
.b-faq { padding: clamp(60px, 11vw, 116px) 0; border-top: 1px solid var(--line); }
.b-faq .narrow { max-width: 720px; }
.b-faq .fh { text-align: center; margin-bottom: clamp(30px, 5vw, 44px); }
.b-faq .fh h2 { font-size: clamp(23px, 4.2vw, 33px); font-weight: 700; line-height: 1.34; letter-spacing: -.025em; margin: 12px 0 0; color: var(--ink); }
.b-faq .fh h2 .u { text-decoration: underline; text-decoration-thickness: 1.5px; text-underline-offset: 4px; text-decoration-color: rgba(91,98,54,.5); }
.b-faq .qa { padding: 24px 0; border-bottom: 1px solid var(--line); }
.b-faq .qa:first-of-type { border-top: 1px solid var(--line); }
.b-faq .qa h3 { margin: 0; font-size: clamp(15.5px, 2.4vw, 17px); font-weight: 700; color: var(--ink); letter-spacing: -.01em; }
.b-faq .qa p { margin: 11px 0 0; color: var(--gray); font-size: 15px; line-height: 1.78; max-width: 64ch; }

/* ════════ 08 · INQUIRY (다크 카드 · 올리브 버튼) ════════ */
.b-inq { padding: clamp(56px, 11vw, 116px) 0 clamp(76px, 12vw, 132px); border-top: 1px solid var(--line); }
.b-inq .lbl { display: block; text-align: center; margin-bottom: clamp(26px, 5vw, 36px); }
.inqcard { max-width: 560px; margin: 0 auto; background: var(--ink); color: var(--d-fg); border-radius: var(--r-lg);
  padding: clamp(32px, 6vw, 52px); text-align: center; }
.inqcard .pname { font-family: "Prata", serif; font-weight: 400; font-size: clamp(34px, 7vw, 44px); line-height: 1; }
.inqcard .byline { font-family: var(--display); font-size: 11.5px; font-weight: 500; letter-spacing: .12em; text-transform: uppercase; color: var(--d-dim); margin-top: 12px; }
.inqcard .sub { margin: 22px 0 0; font-size: clamp(16px, 2.4vw, 18px); font-weight: 600; color: var(--d-fg); letter-spacing: -.015em; }
.inqcard .body { margin: 16px auto 0; max-width: 40ch; color: var(--d-dim); font-size: 14.5px; line-height: 1.8; }
.inqcard .assure { display: flex; gap: 9px; align-items: flex-start; text-align: left; background: rgba(255,255,255,.05);
  border: 1px solid var(--d-line); border-radius: 12px; padding: 13px 15px; margin: 26px 0 20px; font-size: 13px; color: var(--d-fg); line-height: 1.55; }
.inqcard .assure svg { width: 17px; height: 17px; flex: none; stroke: #A7B073; fill: none; stroke-width: 2; margin-top: 1px; }
.inqcard .btn-olive { width: 100%; justify-content: center; box-shadow: none; }

/* 문의 폼 (다크 카드 안) */
.inqform { margin-top: 28px; text-align: left; display: flex; flex-direction: column; gap: 13px; }
.inqform .field label { color: var(--d-dim); font-size: 12.5px; }
.inqform .field input, .inqform .field textarea, .inqform .field select {
  background: rgba(255,255,255,.06); border-color: var(--d-line); color: var(--d-fg); }
.inqform .field input::placeholder, .inqform .field textarea::placeholder { color: #6B6B67; }
.inqform .field input:focus, .inqform .field textarea:focus, .inqform .field select:focus {
  border-color: #A7B073; box-shadow: 0 0 0 3px rgba(167,176,115,.15); }
.inqform .field textarea { min-height: 96px; resize: vertical; }
.inqform .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; }
.inqform .msg { font-size: 13px; min-height: 18px; text-align: center; }
.inqform .msg.ok { color: #C6D19B; }
.inqform .msg.err { color: #E2A98E; }
@media (max-width: 480px) { .inqform .row2 { grid-template-columns: 1fr; } }

/* ════════ 데스크톱: 가치 섹션 변주 ════════ */
@media (min-width: 880px) {
  .vsec .in-grid { grid-template-columns: 1fr 1fr; gap: clamp(48px, 7vw, 92px); }
  .vsec.rev .vtext { order: 2; }
  .vsec.center .in-grid { grid-template-columns: 1fr; gap: clamp(34px, 4vw, 50px); justify-items: center; }
  .vsec.center .vtext { text-align: center; max-width: 640px; }
  .vsec.center .vtext p { max-width: 46ch; margin-left: auto; margin-right: auto; }
  .vsec.center .bdemo { max-width: 560px; width: 100%; }
}
