/*
Theme Name: MAKDesigns
Theme URI: https://makdesigns.ca
Author: Mohamad Khalaf
Author URI: https://makdesigns.ca
Description: Custom one-page theme for MAKDesigns - a web design studio for local businesses in Ottawa. Warm editorial design, custom cursor, kinetic type, and interactive work showcase.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: makdesigns
*/

:root{
    --bone:#F3EDE3; --bone-2:#EBE3D5;
    --ink:#1E1A16; --ink-soft:#544C42;
    --clay:#D2502E; --clay-deep:#B23E20;
    --stone:#C6BBA8; --pine:#162E29; --pine-soft:#21433B;
    --hair:rgba(30,26,22,.13);
    --hair-l:rgba(243,237,227,.15);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    background:var(--bone); color:var(--ink);
    font-family:'Hanken Grotesk',sans-serif; font-weight:400; line-height:1.6;
    -webkit-font-smoothing:antialiased; overflow-x:hidden; position:relative;
  }
  /* atmosphere */
  body::before{
    content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
    background:
      radial-gradient(60vw 50vh at 78% -8%, rgba(210,80,46,.10), transparent 70%),
      radial-gradient(55vw 45vh at 6% 12%, rgba(22,46,41,.07), transparent 70%),
      radial-gradient(70vw 60vh at 50% 115%, rgba(198,187,168,.16), transparent 70%);
  }
  body::after{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:.05;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  .wrap{max-width:1160px;margin:0 auto;padding:0 30px}
  a{color:inherit;text-decoration:none}

  /* CUSTOM CURSOR */
  .cursor,.cursor-dot{position:fixed;top:0;left:0;z-index:10000;pointer-events:none;border-radius:50%;mix-blend-mode:multiply}
  .cursor{width:42px;height:42px;border:1.5px solid var(--clay);transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s}
  .cursor-dot{width:6px;height:6px;background:var(--clay);transform:translate(-50%,-50%)}
  .cursor.hover{width:74px;height:74px;background:rgba(210,80,46,.12);border-color:transparent}
  body.cursor-on{cursor:none}
  body.cursor-on a,body.cursor-on button{cursor:none}
  @media (hover:none),(pointer:coarse){.cursor,.cursor-dot{display:none!important}}

  .label{font-size:11px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--clay);display:inline-flex;align-items:center;gap:11px}
  .label::before{content:"";width:24px;height:1px;background:var(--clay)}

  .btn{position:relative;display:inline-flex;align-items:center;gap:10px;background:var(--clay);color:var(--bone);border:none;padding:15px 28px;border-radius:999px;font-family:'Hanken Grotesk';font-weight:600;font-size:15px;cursor:pointer;transition:transform .3s cubic-bezier(.2,.7,.2,1),background .3s;white-space:nowrap;will-change:transform}
  .btn::after{content:"→";transition:transform .3s}
  .btn:hover{background:var(--clay-deep)}
  .btn:hover::after{transform:translateX(5px)}
  .btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--hair)}
  .btn.ghost:hover{background:var(--ink);color:var(--bone);border-color:var(--ink)}

  /* reveal */
  .js .reveal{opacity:0;transform:translateY(30px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
  .js .reveal.in{opacity:1;transform:none}
  .js .reveal.s2{transition-delay:.1s}.js .reveal.s3{transition-delay:.2s}.js .reveal.s4{transition-delay:.3s}.js .reveal.s5{transition-delay:.4s}

  /* NAV */
  nav{position:sticky;top:0;z-index:90;transition:background .3s,border-color .3s,backdrop-filter .3s;border-bottom:1px solid transparent}
  nav.scrolled{background:rgba(243,237,227,.78);backdrop-filter:blur(14px);border-bottom:1px solid var(--hair)}
  .nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
  .mark{font-family:'Fraunces';font-weight:600;font-size:23px;letter-spacing:-.01em}
  .mark span{color:var(--clay)}
  .nav-links{display:flex;gap:32px;font-size:14.5px;font-weight:500}
  .nav-links a{color:var(--ink-soft);transition:color .2s}
  .nav-links a:hover{color:var(--ink)}
  .nav-cta{font-size:14px;padding:11px 21px}
  @media(max-width:820px){.nav-links{display:none}}

  /* HERO */
  .hero{padding:clamp(72px,11vw,128px) 0 clamp(56px,8vw,96px);position:relative}
  .hero .label{margin-bottom:30px;opacity:0;animation:fade .9s .15s forwards}
  @keyframes fade{to{opacity:1}}
  .mask{overflow:hidden;display:block}
  .mask>span{display:block;transform:translateY(112%);animation:rise 1.05s cubic-bezier(.16,1,.3,1) forwards}
  .l2>span{animation-delay:.12s}.l3>span{animation-delay:.24s}
  @keyframes rise{to{transform:translateY(0)}}
  .hero h1{font-family:'Fraunces';font-weight:320;font-size:clamp(52px,11vw,138px);line-height:.92;letter-spacing:-.035em}
  .hero h1 em{font-style:italic;color:var(--clay);font-weight:400}
  .hero .sub{margin-top:36px;max-width:50ch;font-size:clamp(17px,2.1vw,21px);color:var(--ink-soft);opacity:0;animation:fade .9s .5s forwards}
  .hero .cta-row{margin-top:42px;display:flex;gap:14px;flex-wrap:wrap;opacity:0;animation:fade .9s .62s forwards}
  .scrollcue{margin-top:64px;display:flex;align-items:center;gap:12px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);opacity:0;animation:fade .9s .8s forwards}
  .scrollcue .line{width:46px;height:1px;background:var(--ink-soft);position:relative;overflow:hidden}
  .scrollcue .line::after{content:"";position:absolute;inset:0;background:var(--clay);animation:sweep 2.4s ease-in-out infinite}
  @keyframes sweep{0%{transform:translateX(-100%)}60%,100%{transform:translateX(100%)}}

  /* MARQUEE */
  .marquee{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:22px 0;overflow:hidden;background:var(--bone-2);white-space:nowrap}
  .mtrack{display:inline-flex;gap:0;animation:scroll 26s linear infinite;will-change:transform}
  .marquee:hover .mtrack{animation-play-state:paused}
  @keyframes scroll{to{transform:translateX(-50%)}}
  .mtrack span{font-family:'Fraunces';font-weight:330;font-size:clamp(26px,3.4vw,40px);letter-spacing:-.01em;padding:0 30px;display:inline-flex;align-items:center;gap:30px}
  .mtrack span::after{content:"✶";color:var(--clay);font-size:.6em}
  .mtrack .alt{font-style:italic;color:var(--clay)}

  section{padding:clamp(70px,9vw,116px) 0;position:relative}
  .sechead{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:54px;flex-wrap:wrap}
  .sechead h2{font-family:'Fraunces';font-weight:330;font-size:clamp(36px,5.8vw,66px);line-height:1;letter-spacing:-.025em;max-width:16ch}
  .sechead .idx{font-family:'Fraunces';font-size:14px;color:var(--ink-soft)}

  /* WORK */
  .work-list{border-top:1px solid var(--ink)}
  .work-row{display:grid;grid-template-columns:54px 1fr auto;gap:24px;align-items:center;padding:34px 8px;border-bottom:1px solid var(--hair);transition:padding-left .4s cubic-bezier(.2,.7,.2,1)}
  .work-row .n{font-family:'Fraunces';font-size:15px;color:var(--clay)}
  .work-row .meta h3{font-family:'Fraunces';font-weight:380;font-size:clamp(26px,4.4vw,46px);letter-spacing:-.015em;line-height:1;transition:color .3s}
  .work-row .meta p{font-size:14px;color:var(--ink-soft);margin-top:7px;letter-spacing:.02em}
  .work-row .go{font-size:13.5px;font-weight:600;color:var(--ink-soft);display:inline-flex;align-items:center;gap:7px;transition:color .3s}
  .work-row .go::after{content:"↗";transition:transform .3s}
  .work-row:hover{padding-left:26px}
  .work-row:hover .meta h3{color:var(--clay)}
  .work-row:hover .go{color:var(--clay)}
  .work-row:hover .go::after{transform:translate(4px,-4px)}
  @media(max-width:620px){.work-row{grid-template-columns:34px 1fr;gap:14px}.work-row .go{grid-column:2;justify-self:start;margin-top:6px}}

  /* WORK PREVIEW (cursor-following) */
  .wp{position:fixed;top:0;left:0;width:280px;height:340px;border-radius:18px;z-index:80;pointer-events:none;opacity:0;transform:translate(-50%,-50%) scale(.85) rotate(-3deg);transition:opacity .4s,transform .4s;overflow:hidden;box-shadow:0 30px 70px rgba(20,17,14,.35);display:flex;flex-direction:column;justify-content:space-between;padding:26px}
  .wp.show{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(-3deg)}
  .wp .wp-cat{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:rgba(243,237,227,.7)}
  .wp .wp-name{font-family:'Fraunces';font-weight:360;font-size:34px;line-height:1;color:var(--bone);letter-spacing:-.01em}
  .wp .wp-go{font-size:13px;font-weight:600;color:var(--bone);display:inline-flex;gap:7px;align-items:center}
  @media (hover:none),(pointer:coarse){.wp{display:none!important}}

  /* SERVICES */
  .svc-grid{display:grid;grid-template-columns:1fr;gap:1px;background:var(--hair);border:1px solid var(--hair);border-radius:18px;overflow:hidden}
  @media(min-width:680px){.svc-grid{grid-template-columns:1fr 1fr}}
  .svc{background:var(--bone);padding:38px 34px;transition:background .3s}
  .svc:hover{background:var(--bone-2)}
  .svc .k{font-family:'Fraunces';font-size:15px;color:var(--clay);font-variant-numeric:tabular-nums}
  .svc h3{font-family:'Fraunces';font-weight:500;font-size:24px;margin:16px 0 10px;letter-spacing:-.01em}
  .svc p{font-size:15px;color:var(--ink-soft)}

  /* PROCESS */
  .proc{display:grid;grid-template-columns:1fr;gap:42px 34px}
  @media(min-width:600px){.proc{grid-template-columns:repeat(2,1fr)}}
  @media(min-width:920px){.proc{grid-template-columns:repeat(3,1fr)}}
  .step .num{font-family:'Fraunces';font-weight:300;font-size:62px;color:var(--clay);line-height:1;letter-spacing:-.02em}
  .step .rule{width:36px;height:2px;background:var(--clay);margin:15px 0 17px;opacity:.5}
  .step h3{font-family:'Fraunces';font-weight:500;font-size:21px;margin:0 0 8px}
  .step p{font-size:14.5px;color:var(--ink-soft)}

  /* PRICING */
  .pricing{background:var(--pine);color:var(--bone);overflow:hidden}
  .pricing::before{content:"";position:absolute;inset:0;background:radial-gradient(50vw 50vh at 85% 10%,rgba(210,80,46,.22),transparent 65%);pointer-events:none}
  .pricing .wrap{position:relative}
  .pricing .sechead h2{color:var(--bone)}.pricing .sechead .idx{color:#9fb6ac}
  .price-card{background:rgba(33,67,59,.6);border:1px solid var(--hair-l);border-radius:26px;padding:clamp(34px,5vw,58px);display:grid;grid-template-columns:1fr;gap:36px;backdrop-filter:blur(6px)}
  @media(min-width:820px){.price-card{grid-template-columns:1.05fr .95fr}}
  .price-left .founding{display:inline-block;background:var(--clay);color:var(--bone);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;padding:7px 14px;border-radius:999px;margin-bottom:24px}
  .price-left .amt{font-family:'Fraunces';font-weight:320;font-size:clamp(66px,11vw,108px);line-height:.88;letter-spacing:-.035em}
  .price-left .amt .was{font-size:.3em;color:#9fb6ac;text-decoration:line-through;font-weight:400;margin-left:15px;letter-spacing:0}
  .price-left .care{margin-top:22px;font-size:17px;color:#cfe0d6}
  .price-left .care b{color:var(--bone);font-weight:600}
  .price-left .note{margin-top:17px;font-size:13px;color:#9fb6ac;max-width:38ch}
  .incl{list-style:none;display:flex;flex-direction:column;gap:17px}
  .incl li{display:flex;gap:14px;font-size:15.5px}
  .incl li .tick{flex:none;width:23px;height:23px;border-radius:50%;background:var(--clay);color:var(--bone);display:grid;place-items:center;font-size:12px;margin-top:1px}
  .incl li b{font-weight:600}.incl li span{color:#cfe0d6;display:block;font-size:13.5px;margin-top:2px}
  .price-card .btn{margin-top:8px}

  /* ABOUT */
  .about-lead{font-family:'Fraunces';font-weight:320;font-size:clamp(30px,4.6vw,52px);line-height:1.08;letter-spacing:-.025em;max-width:20ch;margin-bottom:54px}
  .about-lead em{font-style:italic;color:var(--clay)}
  .about-cols{display:grid;grid-template-columns:1fr;gap:38px;align-items:center}
  @media(min-width:820px){.about-cols{grid-template-columns:.78fr 1.22fr}}
  .about-photo{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:4/5;background:var(--bone-2);border:1px solid var(--hair);box-shadow:0 24px 60px rgba(20,17,14,.12)}
  .about-photo img{width:100%;height:100%;object-fit:cover;object-position:30% 22%;display:block}
  .about-photo .cap{position:absolute;left:16px;bottom:14px;background:rgba(30,26,22,.72);color:var(--bone);font-size:12px;font-weight:600;letter-spacing:.04em;padding:7px 13px;border-radius:999px;backdrop-filter:blur(4px)}
  .about-text p{font-size:16.5px;color:var(--ink-soft);max-width:52ch}
  .about-text p + p{margin-top:18px}

  /* CONTACT */
  .contact{text-align:center;padding-bottom:clamp(84px,10vw,124px)}
  .contact h2{font-family:'Fraunces';font-weight:320;font-size:clamp(44px,9vw,108px);line-height:.96;letter-spacing:-.035em}
  .contact h2 em{font-style:italic;color:var(--clay)}
  .contact .lines{margin-top:38px;display:flex;gap:32px;justify-content:center;flex-wrap:wrap;font-size:18px;font-weight:500}
  .contact .lines a{display:inline-flex;align-items:center;gap:9px;border-bottom:1px solid transparent;transition:border-color .25s,color .25s;padding-bottom:3px}
  .contact .lines a:hover{border-color:var(--clay);color:var(--clay)}
  .contact .btn{margin-top:44px}

  footer{border-top:1px solid var(--hair);padding:38px 0 58px}
  .foot-in{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
  .foot-in .mark{font-size:18px}
  .foot-in .small{font-size:13px;color:var(--ink-soft);letter-spacing:.02em}
