/*
Theme Name: Protype Portfolio One Page
Theme URI: https://protype.studio
Author: Ibrahim Hamdi / Protype Foundry
Description: A modern minimalist one-page WordPress portfolio theme for type design, lettering, 3D typography, illustration, and logo work.
Version: 1.0.5
License: GPL v2 or later
Text Domain: protype-portfolio
*/

:root{
  --pt-bg:#f2f2f2;
  --pt-ink:#000000;
  --pt-muted:rgba(0,0,0,.56);
  --pt-soft:rgba(0,0,0,.10);
  --pt-card:#f2f2f2;
  --pt-accent:#0015ff;
  --pt-lemon:#dfff00;
  --pt-radius:28px;
  --pt-gutter:clamp(18px,3vw,46px);
  --pt-max:1760px;
  --pt-ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--pt-bg);
  color:var(--pt-ink);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size:16px;
  line-height:1.45;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img,video{display:block;max-width:100%;height:auto}
button,input,textarea{font:inherit;color:inherit}
::selection{background:var(--pt-accent);color:#fff}

.pt-noise{
  position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.055;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.65'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

.pt-site-header{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:14px var(--pt-gutter);
  mix-blend-mode:difference;
  color:#fff;
}
.pt-nav{
  max-width:var(--pt-max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:18px;
}
.pt-logo{font-weight:800;letter-spacing:-.045em;font-size:clamp(22px,2vw,34px);line-height:.92}
.pt-menu{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.pt-menu a{
  padding:9px 13px;border:1px solid rgba(255,255,255,.28);border-radius:999px;
  color:#fff;font-size:13px;line-height:1;backdrop-filter:blur(12px);
  transition:transform .3s var(--pt-ease), background .3s var(--pt-ease), color .3s var(--pt-ease);
}
.pt-menu a:hover{background:#fff;color:#000;transform:translateY(-2px)}
.pt-menu-toggle{display:none;background:transparent;border:1px solid rgba(255,255,255,.3);border-radius:999px;color:#fff;padding:10px 14px}

.pt-container{max-width:var(--pt-max);margin:0 auto;padding-left:var(--pt-gutter);padding-right:var(--pt-gutter)}
.pt-section{padding:clamp(64px,9vw,142px) 0;border-top:1px solid var(--pt-soft)}
.pt-eyebrow{font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--pt-muted);margin:0 0 18px}
.pt-title{font-size:clamp(42px,8.4vw,148px);line-height:.88;letter-spacing:-.07em;margin:0;font-weight:820;max-width:13ch}
.pt-section-title{font-size:clamp(34px,5.5vw,98px);line-height:.9;letter-spacing:-.06em;margin:0;font-weight:820;max-width:12ch}
.pt-copy{font-size:clamp(18px,1.8vw,28px);line-height:1.15;letter-spacing:-.035em;color:var(--pt-muted);margin:0;max-width:760px}
.pt-small{font-size:14px;color:var(--pt-muted);margin:0}

.pt-hero{min-height:100svh;display:flex;align-items:flex-end;padding:120px 0 var(--pt-gutter);position:relative;overflow:hidden}
.pt-hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden;background:#111}
.pt-hero-bg video,.pt-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.72;filter:saturate(.86) contrast(1.04)}
.pt-hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.16),rgba(0,0,0,.58));}
.pt-hero-inner{position:relative;z-index:2;width:100%;color:#fff}
.pt-hero-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(22px,4vw,72px);align-items:end}
.pt-hero .pt-title{max-width:11ch;color:#fff}
.pt-hero-panel{border:1px solid rgba(255,255,255,.22);border-radius:var(--pt-radius);padding:22px;background:rgba(255,255,255,.08);backdrop-filter:blur(18px)}
.pt-hero-panel p{color:rgba(255,255,255,.74);font-size:clamp(17px,1.4vw,22px);letter-spacing:-.02em;margin:0 0 22px}
.pt-cta-row{display:flex;gap:10px;flex-wrap:wrap}
.pt-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;border:1px solid var(--pt-ink);padding:13px 18px;background:var(--pt-ink);color:#fff;font-weight:700;line-height:1;transition:transform .35s var(--pt-ease), background .35s var(--pt-ease), color .35s var(--pt-ease)}
.pt-button:hover{transform:translateY(-3px);background:var(--pt-accent);border-color:var(--pt-accent)}
.pt-button.is-light{background:#fff;color:#000;border-color:#fff}
.pt-button.is-light:hover{background:var(--pt-lemon);border-color:var(--pt-lemon)}
.pt-button.is-ghost{background:transparent;color:inherit;border-color:rgba(255,255,255,.32)}
.pt-button.is-ghost:hover{background:#fff;color:#000;border-color:#fff}

.pt-marquee{overflow:hidden;border-top:1px solid var(--pt-soft);border-bottom:1px solid var(--pt-soft);padding:18px 0;background:rgba(255,255,255,.18)}
.pt-marquee-track{display:flex;width:max-content;animation:pt-marquee 28s linear infinite;gap:22px}
.pt-marquee span{font-size:clamp(28px,4vw,66px);line-height:.9;letter-spacing:-.055em;font-weight:820;white-space:nowrap}
@keyframes pt-marquee{to{transform:translateX(-50%)}}

.pt-intro-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,6vw,110px);align-items:start}
.pt-tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:28px}
.pt-tag{display:inline-flex;border:1px solid var(--pt-soft);border-radius:999px;padding:9px 12px;font-size:13px;background:rgba(255,255,255,.32)}

.pt-category-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:42px}
.pt-category-card{min-height:164px;border:1px solid var(--pt-soft);border-radius:24px;padding:18px;background:rgba(255,255,255,.32);display:flex;flex-direction:column;justify-content:space-between;transition:transform .35s var(--pt-ease), background .35s var(--pt-ease), color .35s var(--pt-ease)}
.pt-category-card:hover{transform:translateY(-6px);background:var(--pt-ink);color:#fff}
.pt-category-card strong{font-size:clamp(20px,2vw,34px);line-height:.95;letter-spacing:-.05em}
.pt-category-card span{font-size:13px;color:currentColor;opacity:.62}

.pt-work-top{display:flex;justify-content:space-between;gap:24px;align-items:end;margin-bottom:32px}
.pt-filterbar{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.pt-filter{border:1px solid var(--pt-soft);border-radius:999px;background:transparent;padding:10px 13px;cursor:pointer;font-size:13px;transition:.25s var(--pt-ease)}
.pt-filter:hover,.pt-filter.is-active{background:var(--pt-ink);color:#fff;border-color:var(--pt-ink)}
.pt-work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:14px}
.pt-work-card{grid-column:span 4;border-radius:var(--pt-radius);overflow:hidden;background:var(--pt-card);border:1px solid var(--pt-soft);min-height:360px;position:relative;isolation:isolate;transition:opacity .25s var(--pt-ease), border-color .25s var(--pt-ease)}
.pt-work-card:nth-child(6n+1),.pt-work-card:nth-child(6n+5){grid-column:span 8;min-height:520px}
.pt-work-card:hover{transform:none}
.pt-work-card.is-hidden{display:none}
.pt-work-media{height:100%;min-height:inherit;background:#ddd;position:absolute;inset:0;z-index:1;overflow:hidden}
.pt-work-media img,.pt-work-media video{width:100%;height:100%;object-fit:cover;transform:none!important;transition:none!important}
.pt-category-pill{position:absolute;z-index:3;left:14px;top:14px;border-radius:999px;padding:8px 10px;background:rgba(255,255,255,.72);border:1px solid rgba(0,0,0,.08);backdrop-filter:blur(14px);font-size:12px;line-height:1;color:#000;letter-spacing:-.01em}
.pt-gallery-card:hover .pt-category-pill{background:#fff}
.pt-image-gallery .pt-work-media:after{display:none}
.pt-image-gallery .pt-work-info,.pt-gallery-card .pt-work-info{display:none!important}
.pt-work-info{position:absolute;left:16px;right:16px;bottom:16px;color:#fff;display:flex;justify-content:space-between;gap:12px;align-items:end}
.pt-work-name{font-size:clamp(24px,3vw,56px);line-height:.9;letter-spacing:-.06em;font-weight:820;margin:0;max-width:10ch}
.pt-work-meta{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end;max-width:50%}
.pt-work-meta span{font-size:12px;line-height:1;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.12);backdrop-filter:blur(12px);border-radius:999px;padding:8px 10px}

.pt-gallery-card a{pointer-events:none}
.pt-instagram-embed{position:absolute;inset:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;overflow:hidden}
.pt-instagram-embed .instagram-media,.pt-instagram-embed iframe{min-width:100%!important;width:100%!important;max-width:none!important;height:100%!important;margin:0!important;border:0!important;box-shadow:none!important}
.pt-placeholder-tile{width:100%;height:100%;background:linear-gradient(135deg,#111,#555)}

.pt-services{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:40px}
.pt-service{border:1px solid var(--pt-soft);border-radius:24px;padding:22px;background:rgba(255,255,255,.28);min-height:260px;display:flex;flex-direction:column;justify-content:space-between}
.pt-service h3{font-size:clamp(24px,2.4vw,44px);line-height:.95;letter-spacing:-.05em;margin:0 0 20px}
.pt-service p{margin:0;color:var(--pt-muted)}

.pt-contact-card{border-radius:calc(var(--pt-radius) + 16px);background:var(--pt-ink);color:#fff;padding:clamp(28px,5vw,72px);display:grid;grid-template-columns:1fr .65fr;gap:34px;align-items:end;overflow:hidden;position:relative}
.pt-contact-card:before{content:"";position:absolute;right:-8%;top:-22%;width:42vw;height:42vw;border-radius:50%;background:var(--pt-accent);filter:blur(12px);opacity:.86}
.pt-contact-card>*{position:relative;z-index:2}
.pt-contact-card .pt-copy{color:rgba(255,255,255,.72)}
.pt-contact-actions{display:flex;flex-direction:column;gap:10px;align-items:stretch}
.pt-contact-actions .pt-button{border-color:rgba(255,255,255,.28)}

.pt-footer{padding:clamp(28px,5vw,72px) var(--pt-gutter);color:var(--pt-muted);border-top:1px solid var(--pt-soft);overflow:hidden}
.pt-footer-inner{max-width:var(--pt-max);margin:0 auto;display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:end;font-size:13px}
.pt-footer-logo{width:clamp(44px,5vw,76px);height:clamp(44px,5vw,76px);display:flex;align-items:center;justify-content:center;border:1px solid var(--pt-soft);border-radius:20px;background:rgba(255,255,255,.32);transition:transform .45s var(--pt-ease), background .35s var(--pt-ease)}
.pt-footer-logo:hover{transform:rotate(-4deg) translateY(-4px);background:#fff}
.pt-footer-logo img{max-width:68%;max-height:68%;width:auto;height:auto}
.pt-footer-stack{position:relative;height:92px;min-width:260px;justify-self:center}
.pt-footer-stack span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(var(--r));display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;border:1px solid var(--pt-soft);border-radius:999px;background:rgba(255,255,255,.58);padding:10px 18px;color:var(--pt-ink);font-weight:750;letter-spacing:-.04em;box-shadow:0 16px 44px rgba(0,0,0,.05);animation:pt-stack-float 4.8s ease-in-out infinite}
.pt-footer-stack span:nth-child(1){--r:-8deg;margin-top:-30px;animation-delay:0s}
.pt-footer-stack span:nth-child(2){--r:5deg;margin-left:-70px;animation-delay:.15s}
.pt-footer-stack span:nth-child(3){--r:-2deg;margin-top:26px;animation-delay:.3s}
.pt-footer-stack span:nth-child(4){--r:7deg;margin-left:78px;margin-top:-4px;animation-delay:.45s}
.pt-footer-stack span:nth-child(5){--r:-6deg;margin-left:32px;margin-top:48px;animation-delay:.6s}
@keyframes pt-stack-float{0%,100%{translate:0 0}50%{translate:0 -7px}}
.pt-footer-meta{display:flex;flex-direction:column;align-items:flex-end;gap:8px;text-align:right;max-width:420px}

.pt-reveal{opacity:0;transform:translateY(24px);transition:opacity .7s var(--pt-ease), transform .7s var(--pt-ease)}
.pt-reveal.is-visible{opacity:1;transform:none}

@media(max-width:1100px){
  .pt-hero-grid,.pt-intro-grid,.pt-contact-card,.pt-footer-inner{grid-template-columns:1fr}
  .pt-category-grid{grid-template-columns:repeat(3,1fr)}
  .pt-services{grid-template-columns:repeat(2,1fr)}
  .pt-work-card,.pt-work-card:nth-child(6n+1),.pt-work-card:nth-child(6n+5){grid-column:span 6;min-height:420px}
}
@media(max-width:760px){
  :root{--pt-radius:22px;--pt-gutter:16px}
  .pt-menu-toggle{display:inline-flex}
  .pt-menu{position:absolute;top:58px;right:var(--pt-gutter);left:var(--pt-gutter);display:none;flex-direction:column;align-items:stretch;background:rgba(0,0,0,.7);border:1px solid rgba(255,255,255,.22);border-radius:18px;padding:8px;backdrop-filter:blur(20px)}
  .pt-menu.is-open{display:flex}
  .pt-menu a{text-align:center}
  .pt-hero{min-height:94svh;padding-top:96px}
  .pt-work-top{display:block}
  .pt-filterbar{justify-content:flex-start;margin-top:18px}
  .pt-category-grid,.pt-services{grid-template-columns:1fr}
  .pt-footer-inner{align-items:start}
  .pt-footer-stack{justify-self:start;height:120px}
  .pt-footer-meta{align-items:flex-start;text-align:left}
  .pt-work-grid{display:block}
  .pt-work-card,.pt-work-card:nth-child(6n+1),.pt-work-card:nth-child(6n+5){min-height:390px;margin-bottom:12px}
  .pt-work-info{display:block}
  .pt-work-meta{justify-content:flex-start;max-width:100%;margin-top:12px}
  .pt-contact-card{padding:26px}
}

/* v1.0.3 — natural gallery media sizing.
   All categories keep the original image ratio. Logos stay as cropped cover tiles. */
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]){
  min-height:0 !important;
  height:auto !important;
  background:transparent;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media{
  position:relative !important;
  inset:auto !important;
  height:auto !important;
  min-height:0 !important;
  overflow:visible !important;
  background:transparent !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media img,
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media video{
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-instagram-embed{
  position:relative !important;
  inset:auto !important;
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  overflow:visible !important;
}
.pt-image-gallery .pt-gallery-card[data-pt-card~="logos"] .pt-work-media img,
.pt-image-gallery .pt-gallery-card[data-pt-card~="logos"] .pt-work-media video{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}


/* v1.0.5 — final color cleanup + natural gallery media.
   Light system color: light gray. Dark system color: solid #000000.
   Hover/accent colors remain unchanged. */
:root{
  --pt-bg:#f2f2f2;
  --pt-ink:#000000;
  --pt-muted:rgba(0,0,0,.56);
  --pt-soft:rgba(0,0,0,.10);
  --pt-card:#f2f2f2;
}
body{background:#f2f2f2;color:#000000}
.pt-hero .pt-eyebrow{color:rgba(242,242,242,.82) !important}
.pt-section{border-top-color:rgba(0,0,0,.10)}
.pt-marquee{background:rgba(242,242,242,.34)}
.pt-tag,.pt-category-card,.pt-service,.pt-footer-logo{background:rgba(242,242,242,.54)}
.pt-category-card:hover{background:#000000;color:#f2f2f2}
.pt-filter:hover,.pt-filter.is-active{background:#000000;color:#f2f2f2;border-color:#000000}
.pt-contact-card{background:#000000;color:#f2f2f2}
.pt-button{background:#000000;border-color:#000000;color:#f2f2f2}

/* Gallery: no card stroke/frame, no cover crop, real image ratio for every category except Logos. */
.pt-image-gallery{align-items:start !important}
.pt-image-gallery .pt-gallery-card{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]),
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]):nth-child(6n+1),
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]):nth-child(6n+5){
  min-height:0 !important;
  height:auto !important;
  overflow:visible !important;
  border-radius:0 !important;
  background:transparent !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media{
  position:static !important;
  inset:auto !important;
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  overflow:visible !important;
  border-radius:0 !important;
  background:transparent !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media img,
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-work-media video{
  display:block !important;
  width:100% !important;
  height:auto !important;
  max-width:100% !important;
  object-fit:contain !important;
  border-radius:0 !important;
}
.pt-image-gallery .pt-gallery-card:not([data-pt-card~="logos"]) .pt-instagram-embed{
  position:static !important;
  width:100% !important;
  height:auto !important;
  min-height:0 !important;
  overflow:visible !important;
  border-radius:0 !important;
}
.pt-image-gallery .pt-gallery-card[data-pt-card~="logos"]{
  border:0 !important;
  outline:0 !important;
  box-shadow:none !important;
}
.pt-image-gallery .pt-gallery-card[data-pt-card~="logos"] .pt-work-media img,
.pt-image-gallery .pt-gallery-card[data-pt-card~="logos"] .pt-work-media video{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}
.pt-category-pill{
  border:0 !important;
  background:rgba(242,242,242,.76) !important;
  color:#000000 !important;
}
