/* ============================================================================
   QUILL STUDIO — Inner-page components
   Shared vocabulary for: project portfolio + case studies, services, studio,
   process, journal, packages, contact, legal.
   ========================================================================== */

/* ---------- Page banner (inner hero) ----------------------------------- */
.page-banner { position: relative; padding-top: clamp(8rem, 14vh, 12rem); padding-bottom: clamp(3rem, 6vw, 6rem); overflow: hidden; }
.page-banner--media { min-height: 64svh; display: flex; align-items: flex-end; }
.page-banner__media { position: absolute; inset: 0; z-index: -2; }
.page-banner__media img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.06); }
.page-banner__media::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, rgba(8,8,10,0.65) 0%, rgba(8,8,10,0.2) 40%, rgba(8,8,10,0.92) 100%); }
.page-banner__lines { position:absolute; inset:0; z-index:-1; background-image: linear-gradient(var(--line) 1px, transparent 1px); background-size: 100% clamp(60px,8vw,110px); opacity: 0.5; mask-image: linear-gradient(#000, transparent); }
.page-banner h1 { font-size: var(--step-5); line-height: 0.96; max-width: 18ch; }
.page-banner .lead { max-width: 56ch; margin-top: 1.4rem; }
.breadcrumb { display: flex; gap: 0.6rem; align-items: center; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--paper-faint); margin-bottom: 1.4rem; }
.breadcrumb a:hover { color: var(--brass); }
.breadcrumb .sep { color: var(--brass); }

/* ---------- Prose / article -------------------------------------------- */
.prose { max-width: 72ch; }
.prose.center { margin-inline: auto; }
.prose > * + * { margin-top: 1.3rem; }
.prose p { color: var(--paper-dim); font-size: var(--step-1); line-height: 1.7; }
.prose p.drop::first-letter { font-family: var(--font-display); font-size: 3.4em; float: left; line-height: 0.8; padding: 0.05em 0.12em 0 0; color: var(--brass); }
.prose h2 { font-size: var(--step-3); margin-top: 2.6rem; }
.prose h3 { font-size: var(--step-2); margin-top: 2rem; color: var(--paper); }
.prose blockquote { border-left: 2px solid var(--brass); padding-left: 1.6rem; margin-block: 2rem; }
.prose blockquote p { font-family: var(--font-display); font-size: var(--step-2); color: var(--paper); font-style: italic; line-height: 1.3; }
.prose ul.ticks { margin-top: 1rem; }
.prose ul.ticks li { display: flex; gap: 0.8rem; padding: 0.5rem 0; color: var(--paper-dim); }
.prose ul.ticks li::before { content: "→"; color: var(--brass); flex: none; }
.prose a { color: var(--brass); text-decoration: underline; text-underline-offset: 3px; text-decoration-thickness: 1px; }
.prose figure { margin-block: 2.2rem; }
.prose figure img { border-radius: var(--radius); }
.prose figcaption { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--paper-faint); margin-top: 0.7rem; }

/* ---------- Filter chips ----------------------------------------------- */
.filters { display: flex; flex-wrap: wrap; gap: 0.7rem; }
.chip { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.6em 1.2em; border: 1px solid var(--line-strong); border-radius: 100px; color: var(--paper-dim); transition: all 0.35s var(--ease); }
.chip:hover { color: var(--paper); border-color: var(--paper-dim); }
.chip.active { background: var(--brass); border-color: var(--brass); color: var(--ink-900); }

/* ---------- Portfolio grid (filterable) -------------------------------- */
.portfolio { display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(1rem,2.5vw,2rem); }
@media (max-width: 760px){ .portfolio { grid-template-columns: 1fr; } }
.pf-card { position: relative; display: block; overflow: hidden; border-radius: var(--radius); aspect-ratio: 4/3; transition: opacity 0.5s, transform 0.5s var(--ease); }
.pf-card.big { grid-column: span 2; aspect-ratio: 16/9; }
@media (max-width: 760px){ .pf-card.big { grid-column: span 1; aspect-ratio: 4/3; } }
.pf-card img { width: 100%; height: 100%; object-fit: cover; filter: saturate(0.9) brightness(0.82); transition: transform 1.3s var(--ease), filter 0.7s; }
.pf-card:hover img { transform: scale(1.05); filter: saturate(1) brightness(1); }
.pf-card::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 45%, rgba(8,8,10,0.9)); }
.pf-meta { position:absolute; left:1.4rem; right:1.4rem; bottom:1.4rem; z-index:2; }
.pf-meta .c { font-family: var(--font-mono); font-size:0.66rem; letter-spacing:0.16em; text-transform:uppercase; color:var(--brass); }
.pf-meta h3 { font-size: var(--step-2); margin-top:0.3rem; }
.pf-meta .m { font-size: var(--step--1); color: var(--paper-dim); margin-top:0.2rem; }
.pf-card.is-hidden { display:none; }

/* ---------- Project case study ----------------------------------------- */
.facts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; border-block: 1px solid var(--line); padding-block: 2rem; }
@media (max-width: 760px){ .facts { grid-template-columns: 1fr 1fr; gap: 1.8rem 1rem; } }
.fact .k { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--paper-faint); }
.fact .v { font-family: var(--font-display); font-size: var(--step-1); margin-top: 0.4rem; }
.gallery { columns: 2; column-gap: clamp(1rem,2vw,1.6rem); }
@media (max-width: 700px){ .gallery { columns: 1; } }
.gallery img, .gallery figure { break-inside: avoid; margin-bottom: clamp(1rem,2vw,1.6rem); border-radius: var(--radius); width: 100%; }
.gallery .span2 { column-span: all; }
.fullbleed { width: 100vw; margin-left: 50%; transform: translateX(-50%); max-width: 100vw; }
.fullbleed img { width: 100%; height: clamp(40vh,60vh,80vh); object-fit: cover; }

/* next project */
.next-proj { position: relative; display: block; padding-block: clamp(3rem,6vw,6rem); text-align: center; overflow: hidden; }
.next-proj img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:0.3; transition: opacity 0.6s, transform 1.4s var(--ease); z-index:-1; }
.next-proj:hover img { opacity: 0.5; transform: scale(1.05); }
.next-proj .nx-label { font-family: var(--font-mono); font-size:0.7rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--brass); }
.next-proj h2 { font-size: var(--step-4); margin-top: 0.6rem; }

/* ---------- Service detail blocks -------------------------------------- */
.svc-block { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: clamp(2rem,5vw,5rem); align-items: center; padding-block: clamp(2.5rem,5vw,5rem); border-bottom: 1px solid var(--line); }
.svc-block:nth-child(even) > .svc-media { order: -1; }
@media (max-width: 880px){ .svc-block { grid-template-columns: 1fr; } .svc-block:nth-child(even) > .svc-media { order: 0; } }
.svc-media { border-radius: var(--radius-lg); overflow: hidden; aspect-ratio: 4/3; }
.svc-media img { width:100%; height:100%; object-fit:cover; transition: transform 1.2s var(--ease); }
.svc-block:hover .svc-media img { transform: scale(1.05); }
.svc-text .s-ix { font-family: var(--font-display); font-size: var(--step-3); color: var(--ink-700); }
.svc-text h2 { font-size: var(--step-3); margin: 0.4rem 0 1rem; }
.svc-text .deliverables { margin-top: 1.4rem; display: grid; grid-template-columns: 1fr 1fr; gap: 0.6rem 1.4rem; }
.svc-text .deliverables li { display:flex; gap:0.6rem; color: var(--paper-dim); font-size: var(--step-0); }
.svc-text .deliverables li::before { content:"—"; color: var(--brass); }
.price-pill { display: inline-flex; align-items: baseline; gap: 0.4rem; margin-top: 1.6rem; padding: 0.7em 1.2em; border: 1px solid var(--line-strong); border-radius: 100px; }
.price-pill .lbl { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--paper-faint); }
.price-pill .amt { font-family: var(--font-display); font-size: var(--step-1); color: var(--brass); }

/* ---------- Pricing table ---------------------------------------------- */
.ptable { width: 100%; border-collapse: collapse; }
.ptable th, .ptable td { text-align: left; padding: 1.1rem 1rem; border-bottom: 1px solid var(--line); }
.ptable th { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--paper-faint); font-weight: 400; }
.ptable td.price { font-family: var(--font-display); color: var(--brass); white-space: nowrap; }
.ptable tr:hover td { background: rgba(255,255,255,0.02); }
.ptable td .sub { display:block; color: var(--paper-faint); font-size: var(--step--1); }

/* ---------- Team -------------------------------------------------------- */
.team { display: grid; grid-template-columns: repeat(3, 1fr); gap: clamp(1.2rem,2.5vw,2rem); }
@media (max-width: 880px){ .team { grid-template-columns: 1fr 1fr; } }
@media (max-width: 520px){ .team { grid-template-columns: 1fr; } }
.member { }
.member .ph { aspect-ratio: 3/4; border-radius: var(--radius); overflow: hidden; position: relative; }
.member .ph img { width:100%; height:100%; object-fit:cover; filter: grayscale(1) contrast(1.05); transition: filter 0.7s, transform 1.1s var(--ease); }
.member:hover .ph img { filter: grayscale(0); transform: scale(1.04); }
.member h3 { font-size: var(--step-1); margin-top: 1rem; }
.member .role { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--brass); margin-top: 0.2rem; }
.member p { color: var(--paper-dim); font-size: var(--step--1); margin-top: 0.6rem; }

/* ---------- Timeline ---------------------------------------------------- */
.timeline { position: relative; margin-left: 1rem; border-left: 1px solid var(--line-strong); }
.tl-item { position: relative; padding: 0 0 2.4rem 2.2rem; }
.tl-item::before { content:""; position:absolute; left:-5px; top:6px; width:9px; height:9px; border-radius:50%; background: var(--brass); box-shadow: 0 0 0 4px var(--ink-850); }
.tl-item .yr { font-family: var(--font-display); font-size: var(--step-1); color: var(--brass); }
.tl-item h3 { font-size: var(--step-1); margin: 0.2rem 0 0.4rem; }
.tl-item p { color: var(--paper-dim); }

/* ---------- Awards / logo cloud ---------------------------------------- */
.awards { display: grid; grid-template-columns: repeat(2,1fr); gap: 0; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; }
@media (min-width: 760px){ .awards { grid-template-columns: repeat(4,1fr); } }
.award { padding: clamp(1.6rem,3vw,2.4rem); border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.award .yr { font-family: var(--font-mono); font-size: 0.7rem; color: var(--brass); letter-spacing: 0.1em; }
.award .t { font-family: var(--font-display); font-size: var(--step-1); margin-top: 0.4rem; }
.award .o { color: var(--paper-faint); font-size: var(--step--1); margin-top: 0.3rem; }

/* ---------- Testimonials ----------------------------------------------- */
.quotes { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px,1fr)); gap: 1.4rem; }
.quote-card { padding: clamp(1.8rem,3vw,2.6rem); border: 1px solid var(--line); border-radius: var(--radius); background: var(--ink-800); }
.quote-card .mark { font-family: var(--font-display); font-size: 3rem; line-height: 0.5; color: var(--brass); }
.quote-card blockquote { font-size: var(--step-1); color: var(--paper); margin: 1rem 0 1.6rem; line-height: 1.45; }
.quote-card .who { display: flex; align-items: center; gap: 0.9rem; }
.quote-card .who .av { width: 42px; height: 42px; border-radius: 50%; background: var(--ink-700); overflow: hidden; flex:none; }
.quote-card .who .nm { font-size: var(--step-0); }
.quote-card .who .rl { font-size: var(--step--1); color: var(--paper-faint); }

/* ---------- Journal cards ---------------------------------------------- */
.journal-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1.2rem,2.5vw,2rem); }
@media (max-width: 880px){ .journal-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px){ .journal-grid { grid-template-columns: 1fr; } }
.jcard { display: block; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; transition: border-color 0.5s, transform 0.5s var(--ease); }
.jcard:hover { border-color: var(--line-strong); transform: translateY(-5px); }
.jcard .jc-thumb { aspect-ratio: 16/10; overflow: hidden; }
.jcard .jc-thumb img { width:100%;height:100%;object-fit:cover; transition: transform 1.1s var(--ease); }
.jcard:hover .jc-thumb img { transform: scale(1.06); }
.jcard .jc-body { padding: clamp(1.3rem,2.5vw,1.8rem); }
.jcard .jc-tag { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing:0.14em; text-transform:uppercase; color: var(--brass); }
.jcard h3 { font-size: var(--step-1); margin: 0.6rem 0; line-height: 1.15; }
.jcard .jc-meta { font-family: var(--font-mono); font-size: 0.68rem; color: var(--paper-faint); letter-spacing: 0.05em; }

/* ---------- Contact map / details -------------------------------------- */
.map-frame { border-radius: var(--radius-lg); overflow: hidden; border: 1px solid var(--line); aspect-ratio: 16/10; filter: grayscale(1) invert(0.92) contrast(0.85); }
.map-frame iframe { width: 100%; height: 100%; border: 0; }

/* ---------- Callout / disclaimer --------------------------------------- */
.callout { border: 1px solid var(--line-strong); border-left: 2px solid var(--brass); border-radius: var(--radius); padding: clamp(1.4rem,3vw,2rem); background: rgba(201,163,90,0.04); }
.callout . co-title { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brass); margin-bottom: 0.7rem; }
.callout p { color: var(--paper-dim); font-size: var(--step--1); }

/* ---------- Two-up cards generic --------------------------------------- */
.cards-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.4rem; }
@media (max-width: 880px){ .cards-3 { grid-template-columns: 1fr; } }
.cards-2 { display: grid; grid-template-columns: repeat(2,1fr); gap: 1.4rem; }
@media (max-width: 760px){ .cards-2 { grid-template-columns: 1fr; } }
.icard { padding: clamp(1.6rem,3vw,2.2rem); border: 1px solid var(--line); border-radius: var(--radius); background: var(--ink-800); transition: border-color 0.5s, transform 0.5s var(--ease); }
.icard:hover { border-color: var(--line-strong); transform: translateY(-4px); }
.icard h3 { font-size: var(--step-1); margin-bottom: 0.6rem; }
.icard p { color: var(--paper-dim); font-size: var(--step-0); }
.icard .ic-ix { font-family: var(--font-mono); color: var(--brass); font-size: 0.72rem; letter-spacing: 0.14em; }
