/*
Theme Name: Yperspace Rebuild
Theme URI: https://www.yperspace.com/
Author: OpenAI
Description: Responsive WordPress theme inspired by the Yperspace site.
Version: 1.9
Requires at least: 6.0
Tested up to: 6.5
Text Domain: yperspace-rebuild
*/

:root {
  --bg: #ffffff;
  --bg-soft: #f5f5f5;
  --text: #050505;
  --muted: #5f5f5f;
  --line: rgba(0,0,0,.12);
  --line-strong: rgba(0,0,0,.18);
  --max: 1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#ffffff;color:var(--text);font-family:Arial,Helvetica,sans-serif;line-height:1.6}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
p, li, div, span, h1, h2, h3, h4, h5, h6{color:inherit}
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.wrap{width:min(calc(100% - 32px),var(--max));margin:0 auto}
.wrap-full{width:100%;max-width:none}
.header-inner{display:flex;justify-content:space-between;align-items:center;padding:16px 0;gap:20px}
.site-title{letter-spacing:0;text-transform:none;display:inline-block}
.menu-toggle{display:none;background:none;border:1px solid var(--line);color:var(--text);padding:10px 12px;cursor:pointer}

.site-nav{margin-left:auto}
.site-nav ul{list-style:none;padding:0;margin:0}
.site-nav .primary-menu{display:flex;gap:20px;align-items:center}
.site-nav li{position:relative}
.site-nav a{display:block;padding:10px 0;letter-spacing:.06em;text-transform:uppercase;font-size:.92rem}
.site-nav .menu-item-has-children > a{padding-right:18px}
.site-nav .menu-item-has-children > a::after{content:'+';position:absolute;right:0;top:50%;transform:translateY(-50%);font-size:.9rem;color:var(--muted)}
.site-nav .sub-menu{display:none;position:absolute;top:100%;right:0;min-width:240px;padding:10px 0;background:rgba(255,255,255,.98);border:1px solid var(--line-strong);box-shadow:0 16px 40px rgba(0,0,0,.08)}
.site-nav .sub-menu li{width:100%}
.site-nav .sub-menu a{padding:10px 16px;white-space:nowrap;text-transform:none;letter-spacing:.04em}
.site-nav .sub-menu a:hover,
.site-nav .sub-menu a:focus-visible{background:#f1f1f1}
.site-nav li:hover > .sub-menu,
.site-nav li:focus-within > .sub-menu,
.site-nav li.is-open > .sub-menu{display:block}

.hero{min-height:82vh;display:grid;place-items:center;text-align:center;padding:60px 0}
.hero h1{font-size:clamp(2.5rem,9vw,6rem);font-weight:400;letter-spacing:.1em;margin:0 0 12px;text-transform:uppercase}
.hero p{margin:0;color:var(--muted);letter-spacing:.18em;text-transform:uppercase}
.section{padding:72px 0;border-top:1px solid var(--line)}
.section h2{font-size:1.8rem;font-weight:500;margin:0 0 18px;text-transform:uppercase;letter-spacing:.08em}
.lead{max-width:760px;color:var(--muted)}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{border:1px solid var(--line);padding:22px;background:#ffffff}
.placeholder{aspect-ratio:4/5;background:linear-gradient(135deg,#f1f1f1,#ffffff);border:1px solid var(--line)}
.page-hero{padding:80px 0 30px;text-align:center}
.page-hero h1{font-size:clamp(2rem,6vw,4rem);font-weight:400;letter-spacing:.1em;text-transform:uppercase;margin:0 0 10px}
.contact-list p,.awards-list li{color:var(--muted)}
.site-footer{border-top:1px solid var(--line);padding:28px 0;color:var(--muted);text-align:center}
.button{display:inline-block;border:1px solid var(--line);padding:12px 18px;text-transform:uppercase;letter-spacing:.08em}

.about-layout{display:grid;grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:36px;align-items:start}
.about-media{position:relative}
.about-image-space,.about-media img{width:100%;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--line);background:#ffffff}
.about-image-space{display:flex;align-items:end;justify-content:flex-start;padding:20px;background:linear-gradient(160deg,#f4f4f4,#ffffff)}
.about-image-label{font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.about-copy{max-width:720px}
.about-copy h2,.about-copy h3{letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.about-copy p{color:var(--text);margin:0 0 16px}
.about-intro{color:var(--muted)!important;margin-bottom:18px}
.about-default-copy{color:var(--muted)}
.center-title {
  text-align: center;
}
.center-button {
  display: block;
  width: fit-content;
  margin: 0 auto;
}
.collection-gallery {
  display: flex;
  flex-direction: column;
  gap: 48px;
  align-items: center;
}

.collection-gallery img {
  max-width: 100%;
  height: auto;
  display: block;
}
@media (max-width: 820px){
  .grid-2,.grid-3,.about-layout{grid-template-columns:1fr}
  .menu-toggle{display:block}
  .header-inner{flex-wrap:wrap}
  .site-nav{display:none;width:100%;margin-left:0}
  .site-nav.open{display:block}
  .site-nav .primary-menu{flex-direction:column;align-items:flex-start;padding:8px 0 14px;gap:0}
  .site-nav .primary-menu > li{width:100%;border-top:1px solid var(--line)}
  .site-nav .primary-menu > li:last-child{border-bottom:1px solid var(--line)}
  .site-nav a{padding:14px 0;width:100%}
  .site-nav .menu-item-has-children > a{padding-right:48px}
  .site-nav .menu-item-has-children > a::after{right:16px}
  .site-nav .sub-menu{position:static;min-width:0;width:100%;border:none;box-shadow:none;background:#f7f7f7;padding:0 0 8px 14px}
  .site-nav .sub-menu a{padding:12px 0;color:var(--muted)}
}

.eyebrow{margin:0 0 12px;color:var(--muted);letter-spacing:.22em;text-transform:uppercase;font-size:.82rem}
.page-hero-contact{padding-bottom:16px}
.contact-section{padding-top:44px}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:24px}
.contact-card{border:1px solid var(--line);background:#ffffff;padding:28px}
.contact-card h2{margin-bottom:12px}
.contact-copy{color:var(--muted);margin:0 0 18px}
.contact-email{font-size:1.15rem;letter-spacing:.04em;margin:0 0 24px}
.contact-email a{text-decoration:underline;text-underline-offset:3px}
.contact-socials{display:flex;flex-wrap:wrap;gap:12px}
.contact-form-shell{margin-top:18px;padding:18px;border:1px solid var(--line);background:#ffffff;min-height:220px}
.contact-form-shell p:last-child{margin-bottom:0}
.newsletter-section{padding-top:0}
.newsletter-box{border:1px solid var(--line);background:#ffffff;padding:28px}
.newsletter-shortcode-hint{margin-top:16px;padding:16px;border:1px dashed var(--line-strong);color:var(--muted)}
input[type="text"],input[type="email"],input[type="url"],input[type="tel"],textarea{width:100%;background:#ffffff;border:1px solid var(--line-strong);color:var(--text);padding:14px 16px;font:inherit}
textarea{min-height:160px;resize:vertical}
input[type="submit"],button[type="submit"],.wp-element-button{background:transparent;color:var(--text);border:1px solid var(--line-strong);padding:12px 18px;text-transform:uppercase;letter-spacing:.08em;cursor:pointer}
input[type="submit"]:hover,button[type="submit"]:hover,.wp-element-button:hover{background:#f1f1f1}
.wpcf7-form p{margin:0 0 14px}
.wpcf7-not-valid-tip{font-size:.9rem}
@media (max-width: 820px){
  .contact-grid{grid-template-columns:1fr}
  .contact-card,.newsletter-box{padding:22px}
  .contact-socials .button{width:100%;text-align:center}
}


.portfolio-hero{padding-bottom:20px}
.portfolio-section{padding-top:40px}
.portfolio-feature{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,520px);gap:36px;align-items:center}
.portfolio-copy h2,.portfolio-secondary h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:400;letter-spacing:.08em;text-transform:none;margin:0 0 12px}
.portfolio-copy .lead,.portfolio-secondary .lead{max-width:640px}
.portfolio-body{margin:18px 0 28px;color:var(--muted)}
.portfolio-body p{margin:0 0 14px;color:var(--muted)}
.portfolio-media{justify-self:end;width:100%}
.portfolio-image{width:100%;aspect-ratio:4/5;object-fit:cover;border:1px solid var(--line);background:#ffffff}
.portfolio-placeholder{display:flex;align-items:end;justify-content:flex-start;padding:20px;background:linear-gradient(160deg,#f4f4f4,#ffffff)}
.portfolio-secondary{padding-top:30px}
.portfolio-secondary-copy{margin-bottom:24px}
.portfolio-grid{align-items:stretch}
.portfolio-tile{display:flex;align-items:end;justify-content:flex-start;padding:20px;min-height:320px}
@media (max-width: 820px){
  .portfolio-feature{grid-template-columns:1fr;gap:24px}
  .portfolio-media{justify-self:stretch}
  .portfolio-tile{min-height:240px}
  .portfolio-collections-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 60px;
  max-width: 900px;
  margin: 0 auto;
}

.portfolio-collection-box {
  text-align: center;
}

.portfolio-collection-link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.portfolio-collection-link .portfolio-image {
  cursor: pointer;
}

.portfolio-collection-image img {
  width: 100%;
  max-width: 700px;
  height: auto;
  display: block;
  margin: 0 auto;
}

.portfolio-collection-content h2 {
  margin-top: 20px;
  font-size: 32px;
  font-weight: 400;
  text-align: center;
}

.collection-page {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.collection-page h1 {
  margin-bottom: 40px;
}

.collection-gallery {
  display: flex;
  flex-direction: column;
  gap: 20px;
  align-items: center;
}

.collection-gallery img {
  max-width: 100%;
  height: auto;
  display: block;
}
}


.footer-inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.footer-socials{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.social-icon{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid var(--line);border-radius:999px;color:var(--text);transition:transform .2s ease, border-color .2s ease, opacity .2s ease;text-decoration:none}
.social-icon:hover,.social-icon:focus-visible{transform:translateY(-2px);border-color:var(--text);opacity:1}
.social-icon svg{width:18px;height:18px;display:block}
.footer-copy{color:var(--muted);text-align:center}


.hero-home{position:relative;isolation:isolate;overflow:hidden;min-height:82vh;border:1px solid var(--line);background:#fff}
.hero-slider{display:grid;place-items:center}
.hero-slides,.hero-slide,.hero-home .hero-overlay{position:absolute;inset:0}
.hero-slides{z-index:0}
.hero-slide{opacity:0;transition:opacity 1.6s ease;background-size:cover;background-position:center center;background-repeat:no-repeat}
.hero-slide.is-active{opacity:1}
.hero-slide-text{background:#fff}
.hero-slide-image::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.18)}
.hero-home .hero-overlay{z-index:0}
.hero-home .hero-content{position:relative;z-index:1;padding:40px 20px;transition:color .6s ease,text-shadow .6s ease;text-align:center}
.hero-home .hero-content h1,.hero-home .hero-content p{transition:color .6s ease,text-shadow .6s ease;font-family:Arial,Helvetica,sans-serif;text-transform:uppercase;font-weight:400;margin:0}
.hero-home .hero-content h1{font-size:58px;line-height:1.05;letter-spacing:.08em}
.hero-home .hero-content p{font-size:24px;line-height:1.2;letter-spacing:.08em;margin-top:14px}
.hero-home .hero-content.hero-content-light h1,.hero-home .hero-content.hero-content-light p{color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.hero-home .hero-content.hero-content-dark h1,.hero-home .hero-content.hero-content-dark p{color:#000;text-shadow:none}
.hero-home img{-webkit-user-drag:none;user-select:none;pointer-events:none}
@media (max-width: 768px){
  .hero-home .hero-content h1{font-size:34px}
  .hero-home .hero-content p{font-size:16px;margin-top:10px}
}


.hero-home .hero-content{--hero-color:#000;}
.hero-home .hero-content.hero-content-light{--hero-color:#fff;}
.hero-home .hero-content.hero-content-dark{--hero-color:#000;}
.hero-home .hero-content h1,.hero-home .hero-content p{color:var(--hero-color) !important;}
@media (max-width: 768px){
  .hero-home .hero-content h1{font-size:34px !important;}
  .hero-home .hero-content p{font-size:16px !important;}
}


/* Hero typography override */
.hero-home .hero-content h1{font-family:"Cinzel", serif !important;font-size:109px !important;font-weight:400 !important;letter-spacing:0 !important;line-height:1.02 !important;text-transform:uppercase !important;}
.hero-home .hero-content p{font-family:"Cinzel", serif !important;font-size:46px !important;font-weight:400 !important;letter-spacing:0 !important;line-height:1.1 !important;text-transform:uppercase !important;}
@media (max-width: 768px){
  .hero-home .hero-content h1{font-size:56px !important;}
  .hero-home .hero-content p{font-size:24px !important;}
}

/* Title font aligned to v5 without changing colors */
.hero-home .hero-content h1{font-family:Arial,Helvetica,sans-serif !important;font-weight:400 !important;letter-spacing:.1em !important;text-transform:uppercase !important;}


/* Exact About page layout */
.about-page-wrap{width:min(calc(100% - 48px), 1320px);}
.about-exact{border-top:none;padding:48px 0 88px;}
.about-exact-grid{display:grid;grid-template-columns:minmax(320px, 520px) minmax(0, 1fr);gap:68px;align-items:start;}
.about-exact-media img{width:100%;height:auto;display:block;border:none;aspect-ratio:auto;object-fit:contain;}
.about-exact-copy{padding-top:22px;max-width:720px;}
.about-exact-copy h1{margin:0 0 26px;font-family: inherit;font-size:56px;line-height:1.02;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--text);}
.about-exact-copy p{margin:0 0 34px;font-family: inherit;font-size:30px;line-height:1.52;font-weight:400;color:var(--text);}
.about-exact-copy p:last-child{margin-bottom:0;}
@media (max-width: 1100px){
  .about-exact-grid{grid-template-columns:minmax(280px,420px) minmax(0,1fr);gap:44px;}
  .about-exact-copy h1{font-size:46px;}
  .about-exact-copy p{font-size:24px;}
}
@media (max-width: 820px){
  .about-page-wrap{width:min(calc(100% - 28px), 1320px);}
  .about-exact{padding:28px 0 54px;}
  .about-exact-grid{grid-template-columns:1fr;gap:28px;}
  .about-exact-copy{padding-top:0;max-width:none;}
  .about-exact-copy h1{font-size:34px;margin-bottom:18px;}
  .about-exact-copy p{font-size:18px;line-height:1.55;margin-bottom:20px;}
}
